Oracle字符集的使用及设置

Oracle字符编码对数据库的操作有一定的影响,尤其是VARCHAR2字段,如果字符编码默认为GBK,则存储方式为16位,单个汉字占用两字符;如果字符编码默认为UTF-8,则存储方式为32位,单个汉字将占用三个字符,如果两个数据库之间的字符编码不一致,则互相导入数据时会因存储内存不足以及多字节等问题导致未知问题(比如GBK下VARCHAR2(12)可以存储6个汉字,但在UTF-8下只能存储4个汉字)
SELECT USERENV(‘LANGUAGE’)FROM DUAL//查询字符集
Oracle字符编码设置
1. 设置前提,表未导入或者表未有数据时,一旦有数据,设置时也会因不同的编码冲突而报错
2. 操作SQLPLUS进行数据库的编码设置
3. 步骤如下:
CONN /AS SYSDBA
//连接到数据库的最高权限用户dba
SHUTDOWN IMMEDIATE;
//关闭数据库,关闭例程
STARTUP MOUNT;
//开启例程,数据库装载
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER DATABASE OPEN;
//更改数据库权限
ALTER DATABASE CHARACTER SET AL32UTF8/ZHS16GBK;
//更改数据库字符集编码AL32UTF8或者ZHS16GBK
此处会报错
ERROR at line 1:
ORA-12712: new character set must be a superset of old character set
提示我们的字符集:新字符集必须为旧字符集的超集,这时我们可以跳过超集的检查做更改:
ALTER DATABASE character set INTERNAL_USE ZHS16GBK;

SHUTDOWN IMMEDIATE;//关闭实例及数据库

STARTUP //启动数据库

SELECT USERENV(‘LANGUAGE’)FROM DUAL//查询字符集

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值