当前位置:  数据库>oracle

Oracle数据库字符集研究

    来源: 互联网  发布时间:2017-06-01

    本文导语: Oracle服务器: select * from NLS_database_PARAMETERS where parameter like '%CHARACTERSET%';PARAMETER                      VALUE                                  ------------------------------ ----------------------------------------NLS_CHARACTERSET             ...

Oracle服务器:

select * from NLS_database_PARAMETERS where parameter like '%CHARACTERSET%';
PARAMETER                      VALUE                                 
------------------------------ ----------------------------------------
NLS_CHARACTERSET              WE8MSWIN1252                           
NLS_NCHAR_CHARACTERSET        AL16UTF16 

表t1:

desc t1;
Name Null Type         
---- ---- --------------
ID        NUMBER       
NAME      NVARCHAR2(100)

SQL Developer 查询和insert中文

C:sqldevelopersqldeveloperbinsqldeveloper.conf

AddVMOption -Doracle.jdbc.convertNcharLiterals=true

Preference -- > Environment, Encoding选择utf-8

ALTER SESSION SET NLS_LANGUAGE='SIMPLIFIED CHINESE';
TRUNCATE TABLE T1;
INSERT INTO T1 VALUES(1,N'啊');
insert into t1 values(2, '啊');
COMMIT;
col name format a10;
select * from t1;

ID NAME
---------- ----------
1 啊

2 ¿

N'啊'表示nvarchar类型的数据。

以下内容未测试过:

JDBC的配置

-Doracle.jdbc.defaultNChar=true
-Doracle.jdbc.convertNcharLiterals=true

Linux下SQLPlus

NLS_LANG=AMERICAN_AMERICA.AL32UTF8
LC_CTYPE="zh_CN.utf8"
ORA_NCHAR_LITERAL_REPLACE=true

varchar2的长度

varchar2 类型的字段长度以字符或字节来计算,如varchar2(10 byte), varchar2(10 char)。通常,byte/char都被省略,这时NLS_LENGTH_SEMANTICS定义了默认值。

show parameters NLS_LENGTH_SEMANTICS;
NAME                TYPE        VALUE
-------------------- ----------- ----
nls_length_semantics string      BYTE

数据库的字符集

select * from nls_database_parameters where parameter like '%CHARACTER%'
PARAMETER                VALUE       
------------------------- -----------
NLS_NUMERIC_CHARACTERS    .,         
NLS_CHARACTERSET          AL32UTF8   
NLS_NCHAR_CHARACTERSET    AL16UTF16   

AL32UTF8编码的字符长度是可变的,1-4字节,ASCII字符是1字节。如下所示:

desc t2;
Name  Null Type       
----- ---- -----------
TNAME      VARCHAR2(2)

select * from t2;
TNAME
-----
12   

可以看出数字1和2各占一个字节。

查看某字符在当前字符集下的字节数

select lengthb ('C'), lengthb('啊'), length('r') FROM DUAL;
LENGTHB('C') LENGTHB('啊') LENGTH('R')
------------ ------------ ------------
          1            3            2

 


    
 
 

您可能感兴趣的文章:

  • 在Red Hat Linux 9 和 Oracle 9.2 环境下,如何配制字符集,让Oracle能存入并显示日语里的假名?
  • 查询与修改Oracle字符集
  • oracle查看字符集后修改oracle服务端和客户端字符集的步骤
  • ORACLE 10G修改字符编码没有超字符集的限制
  • apache通过php的oci函数读取Oracle(字符集ZHS16GBK)时,显示乱码,如何解决?
  • 查看和修改Oracle服务器端字符集
  • Oracle字符集修改查看方法
  • 如何在RAC环境下修改Oracle字符集
  • oracle查询字符集语句分享
  • Oracle 8i字符集乱码问题析及其解决办法
  • 最好的修改Oracle字符集文档
  • Oracle中字符集的类型决定varchar2的字符长度
  • [Oracle] 彻底搞懂Oracle字符集
  • oracle查看字符集和修改字符集使用详解
  • 深入Oracle字符集的查看与修改详解
  • oracle截取字符(substr)检索字符位置(instr)示例介绍
  • 关于Oracle BLOB类型,一个String字符怎么写入BLOB字段?
  • Oracle中SQL语句连接字符串的符号使用介绍
  • Oracle中字符串连接的实现方法
  • Oracle将字符编码从GBK转到UTF8,如何操作比较稳妥?
  • 安装oracle9的时候字符无法显示??
  • oracle查询不含括号及不含指定字符的方法
  • Linux字符安装oracle
  • 怎么用jsp向oracle8提交长字符(15000字左右)?
  • 向Oracle数据库的CLOB属性插入数据报字符串过长错误
  • 操作系统 iis7站长之家
  • Linux下字符安装oracle好轻松
  • oracle使用instr或like方法判断是否包含字符串
  • Oracle用户密码含特殊字符时登陆失败问题
  • linux下字符安装oracle 10g!最后出现点问题!很急!
  • 我要向oracle中插入大文本,用的是lang类型的字段,但是只能插3000字,再多就抱错,说我字符串过长。谁遇到过此问题?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • 关于JDBC连接Oracle数据库,是否必须有Oracle客户端
  • ORACLE数据库常用字段数据类型介绍
  • win2000+jbuilder6+oracle817编出的程序,在win2000下执行很好,在win98下却访问不了oracle数据库
  • oracle数据库导出和oracle导入数据的二种方法(oracle导入导出数据)
  • Oracle发布Oracle SQL Developer 1.2数据库开发工具 帮助用户简化开发工作
  • 怎样调出ORACLE数据库中的数据,该如何连接?
  • Oracle收购TimesTen 提高数据库软件性能
  • 卸载oracle数据库
  • Oracle数据库恢复后心得
  • linux上安装oracle 数据库后,是否能写shell程序实现数据库的自动启动。
  • Linux下如何用C语言操作Oracle数据库相关的图书推荐
  • Oracle数据库运行Oracle form时避免出现提示信息
  • Oracle欲收购开源数据库MySQL未果
  • 如何在JBuilder中连接Oracle数据库?
  • Oracle数据库访问参数文件的顺序
  • 循序渐进学习Oracle数据库
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle 10g和Oracle 11g网格技术介绍
  • Oracle EBS R12 支持 Oracle Database 11g
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,