oracle查看字符集和修改字符集使用详解
一、什么是Oracle字符集
数据库字符集在创建数据库时指定,在创建后通常不能更改。在创建数据库时,可以指定字符集(CHARACTER SET)和国家字符集(NATIONAL CHARACTER SET)。
2.2.2多字节编码
3.1 EXP/IMP
Territory:指定默认日期、数字、货币等格式
可以查询以下数据字典或视图查看字符集设置情况
Oracle的字符集命名遵循以下命名规则:
Language:指定服务器消息的语言,影响提示信息是中文还是英文
Regedit.exe ---》 HKEY_LOCAL_MACHINE ---》SOFTWARE ---》 ORACLE--》HOME
NLS作用优先级别:Sql function > alter session > 环境变量或注册表 > 参数文件 > 数据库默认参数
UTF-8是unicode的8位编码方式,是一种变长多字节编码,这种编码可以用1、2、3个字节表示一个unicode字符,AL32UTF8,UTF8、UTFE是UTF-8编码字符集
(3)使用ALTER SESSION语句,在oracle会话中修改
(4)使用某些SQL函数
(1)变长多字节编码
nls_database_parameters、props$、v$nls_parameters
2.1 字符集
它的格式如下: NLS_LANG = language_territory.charset
(2)国家字符集实质上是为oracle选择的附加字符集,主要作用是为了增强oracle的字符处理能力,因为NCHAR数据类型可以提供对亚洲使用定长多字节编码的支持,而数据库字符集则不能。国家字符集在oracle9i中进行了重新定义,只能在unicode编码中的AL16UTF16和UTF8中选择,默认值是AL16UTF16
(2)修改环境变量NLS_LANG
(2)定长多字节编码
<Language><bit size><encoding>
Export 和 Import 是一对读写Oracle数据的工具。Export 将 Oracle 数据库中的数据输出到操作系统文件中, Import 把这些文件中的数据读到Oracle 数据库中,由于使用exp/imp进行数据迁移时,数据从源数据库到目标数据库的过程中有四个环节涉及到字符集,如果这四个环节的字符集不一致,将会发生字符集转换。
Oracle8i和oracle9i官方文档资料中备有子集-超级对照表(subset-superset pairs),例如:WE8ISO8859P1是WE8MSWIN1252的子集。由于US7ASCII是最早的Oracle数据库编码格式,因此有许多字符集是US7ASCII的超集,例如WE8ISO8859P1、ZHS16CGB231280、ZHS16GBK都是US7ASCII的超集。
2. 通过ALTER DATABASE CHARACTER SET语句修改字符集,但创建数据库后修改字符集是有限制的,只有新的字符集是当前字符集的超集时才能修改数据库字符集,例如UTF8是US7ASCII的超集,修改数据库字符集可使用ALTER DATABASE CHARACTER SET UTF8。
例如:NLS_LANG=AMERICAN_AMERICA.US7ASCII
2.5.1客户端字符集含义
影响Oracle数据库字符集最重要的参数是NLS_LANG参数。
AMERICAN是语言,AMERICA是地区,US7ASCII是客户端字符集
复制代码 代码如下:
NLS_INSTANCE_PARAMETE:显示由参数文件init<SID>.ora 定义的参数V$NLS_PARAMETERS:显示数据库当前NLS参数取值
(1)用以存储NCHAR, NVARCHAR2, NCLOB等类型数据
NLS_LANG=<language>_<territory>.<client character set>
每一个字符都使用固定长度字节的编码方案,目前oracle唯一支持的定长多字节编码是AL16UTF16,也是仅用于国家字符集某些字符用一个字节表示,其它字符用两个或多个字符表示,变长多字节编码常用于对亚洲语言的支持, 例如日语、汉语、印地语等
例如:WE8ISO8859P1(西欧、8位、ISO标准8859P1编码)
2.2 字符编码方案
(2)用来标示诸如表名、列名以及PL/SQL变量等
2.5.3客户端字符集设置方法
NLS_SESSION_PARAMETERS: 显示由NLS_LANG 设置的参数,或经过alter session 改变后的参数值(不包括由NLS_LANG 设置的客户端字符集)
其中:
按照上文所说,数据库字符集在创建后原则上不能更改。不过有2种方法可行。
1)UNIX环境
编辑oracle用户的profile文件
复制代码 代码如下:
2.2.1单字节编码
Charset: 指定字符集。Unicode是一个涵盖了目前全世界使用的所有已知字符的单一编码方案,也就是说Unicode为每一个字符提供唯一的编码。UTF-16是unicode的16位编码方式,是一种定长多字节编码,用2个字节表示一个unicode字符,AL16UTF16是UTF-16编码字符集。
2.3 字符集超级
2.4.3查询字符集参数
如:AMERICAN _ AMERICA. ZHS16GBK
$export NLS_LANG
1. 如果需要修改字符集,通常需要导出数据库数据,重建数据库,再导入数据库数据的方式来转换。
实质就是按照一定的字符编码方案,对一组特定的符号,分别赋予不同数值编码的集合。Oracle数据库最早支持的编码方案是US7ASCII。
Client character set:指定客户端将使用的字符集
例如:AL32UTF8(其中AL代表ALL,指适用于所有语言)、zhs16cgb231280(1)用来存储CHAR, VARCHAR2, CLOB, LONG等类型数据
2.2.3 unicode编码
2.5.4 NLS参数查询
使用下列方法可以修改NLS参数
(1)单字节7位字符集,可以定义128个字符,最常用的字符集为US7ASCII
2.5.2 NLS_LANG参数格式
(2)单字节8位字符集,可以定义256个字符,适合于欧洲大部分国家
所以两个数据库之间的字符集只要第三部分一样就可以相互导入导出数据,前面影响的只是提示信息是中文还是英文。
(3)用来存储SQL和PL/SQL程序单元等
2.4.1字符集
2.4.4修改数据库字符集
编辑注册表
它有三个组成部分(语言、地域和字符集),每个成分控制了NLS子集的特性。
2.5.5修改NLS参数
2.5 客户端字符集(NLS_LANG参数)
$NLS_LANG=“simplified chinese”_china.zhs16gbk
查询结果中NLS_CHARACTERSET表示字符集,NLS_NCHAR_CHARACTERSET表示国家字符集
即: <语言><比特位数><编码>当一种字符集(字符集A)的编码数值包含所有另一种字符集(字符集B)的编码数值,并且两种字符集相同编码数值代表相同的字符时,则字符集A是字符集B的超级,或称字符集B是字符集A的子集。
Oracle字符集是一个字节数据的解释的符号集合,有大小之分,有相互的包容关系。ORACLE 支持国家语言的体系结构允许你使用本地化语言来存储,处理,检索数据。它使数据库工具,错误消息,排序次序,日期,时间,货币,数字,和日历自动适应本地化语言和平台。
2.4 数据库字符集(oracle服务器端字符集)
2.4.2国家字符集:
Oracle提供若干NLS参数定制数据库和用户机以适应本地格式,例如有NLS_LANGUAGE,NLS_DATE_FORMAT,NLS_CALENDER等,可以通过查询以下数据字典或v$视图查看。
Territory:指定服务器的日期和数字格式,
二.字符集的相关知识:
NLS_DATABASE_PARAMETERS:显示数据库当前NLS参数取值,包括数据库字符集取值
比如: ZHS16GBK表示采用GBK编码格式、16位(两个字节)简体中文字符集
2)Windows环境
客户端字符集定义了客户端字符数据的编码方式,任何发自或发往客户端的字符数据均使用客户端定义的字符集编码,客户端可以看作是能与数据库直接连接的各种应用,例如sqlplus,exp/imp等。客户端字符集是通过设置NLS_LANG参数来设定的。
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://www.juheyunku.com/sql/oracle/1552.shtml
相关文章
热门TAG
命令 权重 外链 企业网站 白帽 php 织梦教程 dedecms修改内容 javascript 织梦 功能 标签 调用 详解 服务器 网站流量 实例解析 Dedecms 织梦cms HTML tags标签 python jquery教程 jquery windows SEO优化 蜘蛛 搜索引擎 网站收录 JSP最新文章
-
Window下Oracle Database 11g 发行
时间:2020-12-29
-
Oracle如何实现like多个值的
时间:2020-12-29
-
maven添加oracle依赖失败问题
时间:2020-12-29
-
OracleRAC基本概念及入门
时间:2020-12-29
-
Azure File Storage 基本用法
时间:2020-12-26
-
Oracle 权限(grant revoke)
时间:2020-12-26
-
Azure Queue Storage 基本用法
时间:2020-12-26
-
如何对比迁移前后的Orac
时间:2020-12-26
热门文章
-
Azure Queue Storage 基本用法 Azure Storage 之
时间:2020-12-26
-
Oracle存储过程编程详解
时间:2020-12-07
-
win10下oracle 11g安装图文教程
时间:2020-12-25
-
oracle 数据库学习 基本结构介绍
时间:2020-12-13
-
Azure File Storage 基本用法 Azure Storage 之 F
时间:2020-12-26
-
windows使用sqlpus连接oracle 数据库的教程图
时间:2020-12-25
-
Window下Oracle Database 11g 发行版2安装教程
时间:2020-12-29
-
Oracle解锁的方式介绍
时间:2020-12-14
-
linux下oracle设置开机自启动实现方法
时间:2020-12-13
-
Oracle学习记录之使用自定义函数和触发器
时间:2020-12-07
