转 ORACLE数据库它可以存储 中文 字节或字符
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了转 ORACLE数据库它可以存储 中文 字节或字符,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2649字,纯文字阅读大概需要4分钟。
内容图文
![转 ORACLE数据库它可以存储 中文 字节或字符](/upload/InfoBanner/zyjiaocheng/470/53b5fccea81e4104b5b00ac203419669.jpg)
一:因为ORACLE数据库它可以存储字节或字符,例如 CHAR(12 BYTE) CHAR(12 CHAR)的意义是不同的.一般来说默认是存储字节,你可以查看数据库参数NLS_LENGTH_SEMANTICS的值。
1: SQL> show parameter nls_length_semantics;
2:
3: NAME TYPE VALUE
4: ------------------------- ----------- -------------
5: nls_length_semantics string BYTE
如果定义为VARCHAR2(50 CHAR),那么该列最多就可以存储50个汉字,如果定义字段为VARCHAR2(50) 或VARCHAR2(50 BYTE)那么它最多可以存储多少个汉字就要视数据库字符集编码决定
。
二:ORACLE数据库汉字占用几个字节,要根据ORACLE中字符集编码决定,一般情况下,数据库的NLS_CHARACTERSET 为AL32UTF8或UTF8,即一个汉字占用三到四个字节。如果NLS_CHARACTERSET为ZHS16GBK,则一个字符占用两个字节.
1: SQL> COL PARAMETER FOR A24;
2: SQL> COL VALUE FOR A24 3:
SQL> SELECT * FROM v$nls_parameters WHERE PARAMETER=‘NLS_CHARACTERSET‘;
4:
5: PARAMETER VALUE
6: ------------------------ ------------------------
7: NLS_CHARACTERSET UTF8
8:
9: SQL> 10:
至于具体情况,可以通过LENGTHB或者VSIZE函数求得是占用字节数。
1: SQL> SELECT LENGTH(‘您好‘) FROM DUAL;
2:
3: LENGTH(‘您好‘)
4: --------------
5: 2
6:
7:
SQL> SELECT LENGTHB(‘您好‘) FROM DUAL;
8:
9: LENGTHB(‘您好‘)
10: ---------------
11: 6
12:
LENGTH函数求得是占用字符数,LENGTHB或者VSIZE函数求得是占用字节数。
VSIZE returns the number of bytes in the internal representation of expr. If expr is null, then this function returns null. This function does not support CLOB data directly. However, CLOBs can be passed in as arguments through implicit data conversion.
LENGTH是计算字符的个数,输入的参数先被转为字符类型计算
The LENGTH functions return the length of char. LENGTH calculates length using characters as defined by the input character set. LENGTHB uses bytes instead of characters. LENGTHC uses Unicode complete characters. LENGTH2 uses UCS2 code points. LENGTH4 uses UCS4 code points.
作者:潇湘隐者
出处:http://www.cnblogs.com/kerrycode/
->解决办法
1。
SQL> select userenv(‘language‘) from dual;
USERENV(‘LANGUAGE‘) AMERICAN_AMERICA.AL32UTF8
3.修改Linux的NLS_LANG环境变量,修改Oracle指定的Linux用户下面“.base_profile”文件,加入如下: export NLS_LANG="AMERICAN_AMERICA.AL32UTF8"
4.执行.bash_profile,使环境变量设置生效,查看其值: $ echo $NLS_LANG MERICAN_AMERICA.AL32UTF8
至此,此次中文乱码的问题得已解决。
转 ORACLE数据库它可以存储 中文 字节或字符
标签:
本文系统来源:http://www.cnblogs.com/feiyun8616/p/5885848.html
内容总结
以上是互联网集市为您收集整理的转 ORACLE数据库它可以存储 中文 字节或字符全部内容,希望文章能够帮你解决转 ORACLE数据库它可以存储 中文 字节或字符所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。