数据库的字符集的问题

本文详细介绍了数据库实例字符集、操作系统字符集及其在不同系统(如Windows、Linux)上的配置方法,强调了保持一致性的必要性以避免乱码问题。

字符集的三个方面,

数据库实例的字符集 

SQL> select userenv('language') from dual;
USERENV('LANGUAGE')
----------------------------------------------------
AMERICAN_AMERICA.AL32UTF8

windows的系统字符集

C:\Windows\system32>chcp
Active code page: 936

Linux系统的字符集

weblogic@YFCS68-141:~> locale
LANG=en_US.UTF-8
LC_CTYPE="zh_CN.GBK"
LC_NUMERIC="zh_CN.GBK"
LC_TIME="zh_CN.GBK"
LC_COLLATE="zh_CN.GBK"
LC_MONETARY="zh_CN.GBK"
LC_MESSAGES="zh_CN.GBK"
LC_PAPER="zh_CN.GBK"
LC_NAME="zh_CN.GBK"
LC_ADDRESS="zh_CN.GBK"
LC_TELEPHONE="zh_CN.GBK"
LC_MEASUREMENT="zh_CN.GBK"
LC_IDENTIFICATION="zh_CN.GBK"
LC_ALL=zh_CN.GBK

客户端的字符集

指定为

NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

 

在操作系统向数据库导入数据时,需要使nls_lang与操作系统的字符集一致,让数据库的存储自动转化即可,这样数据库与应用的系统的都不会出现乱码

转载于:https://www.cnblogs.com/whytohow/p/5412748.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值