当前位置:首页 > 技术知识 > 正文内容

Oracle数据库字符集概述及修改方式

maynowei8个月前 (08-19)技术知识89

1、字符集概述

  • Oracle语言环境的描述包括三部分:language、territory、characterset(语言、地域、字符集)
  • language:主要指定服务器消息的语言,提示信息显示中文还是英文
  • territory:主要指定服务器的数字和日期的格式
  • characterset:是指字符集,一般国内数据库实际使用的字符集主要是ZHS16GBK、AL32UTF8
  • 只要两个数据库的字符集(characterset)一样,就可以相互导入导出数据

2、查询Oracle字符集

2.1、查询服务端字符集

NLS_NCHAR_CHARACTERSET 为国家字符集,主要是NCHAR、 NVARCHAR2 、NCLOB数据类型使用的字符集,一般是不用这几种数据类型的

 select * from nls_database_parameters;

2.2、查询客户端字符集

2.2.1、方式一

select * from nls_session_parameters;

2.2.2、方式二

select userenv('language') from dual;

3、修改Oracle字符集

  • 一般来说,除非万不得已,我们不建议修改oracle数据库server端的字符集
  • 如果需要修改字符集,通常需要导出数据库数据,重建数据库,再导入数据库数据的方式来转换
  • 也可以通过ALTER DATABASE CHARACTER SET语句修改字符集,但创建数据库后修改字符集是有限制的
  • 只有新的字符集是当前字符集的超集时才能修改数据库字符集,
    例如UTF8是US7ASCII的超集,修改数据库字符集可使用ALTER DATABASE CHARACTER SET UTF8
  • 如果想跳过超集的检查,则需要加INTERNAL_USE 关键字
    ALTER DATABASE CHARACTER SET INTERNAL_USE UTF8;

下面为修改字符集的步骤:

3.1、以sysdba角色连接到本地Oracle数据库

sqlplus / as sysdba

3.2、以sysdba角色连接到Oracle数据库实例

connect sys as sysdba;

3.3、开启"限制会话"模式以阻止新的会话连接到数据库

ALTER SYSTEM ENABLE RESTRICTED SESSION;

3.4、修改数据库字符集为ZHS16GBK

注意:执行该步骤时,需要关闭数据库的其他会话,否则会报错“ORA-12721:当其他会话处于活动状态时,无法执行操作”

ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;

3.5、查询数据库字符集的设置值

SELECT * FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER = 'NLS_CHARACTERSET';

3.6、关闭"限制会话"模式以允许新的会话连接到数据库

ALTER SYSTEM DISABLE RESTRICTED SESSION;

相关文章

单片机C语言编程,心得都在这里了

单片机写代码总踩坑,头文件被无视,老工程师的经验哪里来?前几天写8x8矩阵键盘的程序,搞了三天代码一直乱报错。后来发现自己连头文件是什么都不清楚,之前写的都是小程序,压根没碰过.h文件。看别人的程序都...

微软明年要停止SQL Server 2005的技术支持了

站长之家(Chinaz.com)12月28日消息据外媒消息称,微软将于明年停止为SQL Server 2005提供技术支持,即不再为其提供新的安全补丁、新功能、应用升级等服务。且表示在停止技术支持后,...

掌握C语言多线程:高效并发编程指南

一、多线程基础概念介绍多线程编程是现代软件开发中提高程序性能和响应性的重要技术。在C语言中,pthread(POSIX Threads)库是实现多线程编程的标准工具。本节将通俗易懂地介绍多线程的核心概...

C语言编写多线程,什么时候要使用互斥锁?为什么要使用互斥锁?

在多线程编程中,当多个线程同时访问共享资源(如变量、文件等)时,会出现竞态条件(Race Condition)问题,导致程序的行为不可预测。为了避免这种问题,需要使用互斥锁来保护共享资源的访问。互斥锁...

python-oracledb——利用python连接Oracle数据库的好用方法

这篇文章最早发布在CSDN了,最近想尝试使用一下头条,重新转移过来了。背景介绍之前使用的数据库一直是MySql,偶尔使用PostgreSQL,都是利用的数据库连接池使用;最近需要在Oracle数据库取...

oracle和mysql的优缺点对比(oracle和mysql哪个简单)

oracle的优缺点优点:开放性:oracle 能所有主流平台上运行(包括 windows)完全支持所有工业标准采用完全开放策略使客户选择适合解决方案对开发商全力支持;可伸缩性,并行性:Oracle...