在进行web开发和oracle安装的过程当中常常有人对字符集搞不清楚,所以对此作一下总结。web
1.第一个问题:字符集之间的区别是什么呢?数据库
常见的字符集有:UTF-8和GBK浏览器
(1)GBK字符集服务器
(2)UTF-8字符集oracle
通常来讲,国内的系统若是要保存汉字,通常会选择使用GBK字符集,若是是想作网站等,全球可访问的系统,那么通常选择UTF-8。网站
2.数据库中哪些字符集须要设置?编码
数据库分客户端字符集和数据库服务器字符集。spa
而oracle的服务器字符集又有两种:常规字符集(通常意义上的数据库字符集)和国家字符集.net
1. 常规意义上的字符集(通常意义上的数据库字符集):code
(1)用来存储CHAR, VARCHAR2, CLOB, LONG等类型数据
(2)用来标示诸如表名、列名以及PL/SQL变量等
(3)用来存储SQL和PL/SQL程序单元等
(4)通常为:AL32UTF8 或者 ZHS16GBK
2. 国家字符集:
(1)用以存储NCHAR, NVARCHAR2, NCLOB等类型数据
(2)国家字符集实质上是为oracle选择的附加字符集,主要做用是为了加强oracle的字符处理能力,由于NCHAR数据类型能够提供对亚洲使用定长多字节编码的支持,而数据库字符集则不能。国家字符集在oracle9i中进行了从新定义,只能在unicode编码中的AF16UTF16和UTF8中选择,默认值是AF16UTF16
3.字符集查看方法
数据库字符集:select * from nls_database_parameters;
客户端字符集:select * from nls_instance_parameters;
数据库字符集的表示方式为:
SIMPLIFIED CHINESE_CHINA.AL32UTF8
SIMPLIFIED CHINESE_CHINA.ZHS16GBK
若是客户端字符集和数据库字符集不一致时,经过plSql登录时会提示以下错误:
4.客户端字符集设置方法
32位客户端: HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\
64位客户端:HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\ORACLE\KEY_OraClient11g_home1
5.建议的字符集是什么?
数据库字符集:SIMPLIFIED CHINESE_CHINA.ZHS16GBK(国内大部分数据库仍是oracle多,若是作网站的话仍是建议使用UTF-8字符集)
国家字符集:SIMPLIFIED CHINESE_CHINA.AL16UTF16
客户端字符集:SIMPLIFIED CHINESE_CHINA.ZHS16GBK
网页字符集:UTF-8
通过实验,不会出现乱码。
参考文章: