Linux下oracle显示问号,Linux下oracle插入(导入)中文记录显示为问号问题及解决办法...

字符集

oracle官方关于字符集和NLS_LANG的解答:http://www.oracle.com/technology/tech/globalization/htdocs/nls_lang%20faq.htm

首先要明确什么是字符集?字符集是一个字节数据的解释的符号集合,有大小之分,有相互的包括关系,如us7ascii就是zhs16gbk的子集,从us7ascii到zhs16gbk不会有数据解释上的问题,不会有数据丢失,Oracle对这种问题也要求从子集到超集的导出受支持,反之不行。在所有的字符集中utf8应该是最大,因为它基于unicode,双字节保存字符(也因此在存储空间上占用更多),。

其次,一旦数据库创建后,数据库的字符集是不能改变的。因此,在设计和安装之初考虑使用哪一种字符集是十分重要的。数据库字符集应该是操作系统本地字符集的一个超集。存取数据库的客户使用的字符集将决定选择哪一个超集,即数据库字符集应该是所有客户字符集的超集。

nls_lang变量:

Windows下:在系统的环境变量里和注册表里可以找到进行设置

Linux下:在oracle用户下的.bash_profile文件里进行设置

NLS_LANG格式:

NLS_LANG = language_territory.charset

有三个组成部分(语言、地域和字符集),每个成分控制了NLS子集的特性。其中:language 指定服务器消息的语言。

territory 指定服务器的日期和数字格式。

charset 指定字符集

例如:

AMERICAN _ AMERICA. ZHS16GBK

linux系统语言:

/etc/sysconfig/i18n

在Red hat下面

你可能感兴趣的:(Linux下oracle显示问号,Linux下oracle插入(导入)中文记录显示为问号问题及解决办法...)