Oracle笔记二:字符集

简介

服务器端字符集

在创建数据库时,可以指定字符集(CHARACTER SET)和国家字符集(NATIONAL CHARACTER SET)。
1、字符集
(1)用来存储CHAR, VARCHAR2, CLOB, LONG等类型数据;
(2)用来标示诸如表名、列名以及PL/SQL变量等;
(3)用来存储SQL和PL/SQL程序单元等;
2、国家字符集
(1)用以存储NCHAR, NVARCHAR2, NCLOB等类型数据;
(2)国家字符集实质上是为oracle选择的附加字符集,主要作用是为了增强oracle的字符处理能力,因为NCHAR数据类型可以提供对亚洲使用定长多字节编码的支持,而数据库字符集则不能。国家字符集在oracle9i中进行了重新定义,只能在unicode编码中的AF16UTF16和UTF8中选择,默认值是AF16UTF16

不同字符集下一个汉字所占用字节数

SIMPLIFIED CHINESE_CHINA.ZHS16GBK :一个汉字占用两个字节
SIMPLIFIED CHINESE_CHINA.AL32UTF8: 一个汉字占用三个字节
可使用如下语句查看:
select lengthb(‘你’) from dual;

客户端字符集

客户端字符集定义了客户端字符数据的编码方式,任何发自或发往客户端的字符数据均使用客户端定义的字符集编码,客户端可以看作是能与数据库直接连接的各种应用,例如sqlplus,exp/imp,pl/sql developer等。客户端字符集是通过设置NLS_LANG参数来设定的。

查看数据库服务器端字符集方式

1、select userenv(‘language’) from dual;

在这里插入图片描述

2、select * from v$nls_parameters;

在这里插入图片描述

3、SELECT * FROM NLS_DATABASE_PARAMETERS;

在这里插入图片描述

修改数据库字符集

1、备份数据库:防止修改字符集导致数据错乱,无法恢复
2、使用管理员用户登入数据库
sqlplus sys as sysdba
3、由于要改动数据库基础配置,因而需先关闭数据库
shutdown immediate;
4、装载数据库,打开控制文件
STARTUP MOUNT;
5、更改配置并启动数据库
ALTER SESSION SET SQL_TRACE=TRUE;
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER SYSTEM SET AQ_TM_PROCESSES=0;
ALTER DATABASE OPEN;
6、更改字符集
1)gbk改为utf-8
ALTER DATABASE CHARACTER SET AL32UTF8;
2)utf-8改为gbk
SQL> ALTER DATABASE CHARACTER SETZHS16GBK;

第1行出现错误:
ORA-12712: new character set must be a superset of old characterset
提示我们的字符集:新字符集必须为旧字符集的超集,这时我们可以跳过超集的检查做更改:
SQL> ALTER DATABASE character set INTERNAL_USE ZHS16GBK;
(INTERNAL_USE可使Oracle数据库绕过子集与超集的校验.)
7、恢复参数
ALTER SESSION SET SQL_TRACE=FALSE;
8、重启数据库
shutdown immediate;
startup;
9、查看服务器端字符集
SELECT parameter, value FROM v$nls_parameters WHERE parameter LIKE ‘%CHARACTERSET’;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值