oracle中汉字占几个字节

        大家是否经常遇到数据表某字段长度不够了。一般我们在存字符串时用VARCAHR2类型,而VARCHAR2有两种用法,一种是VARCHAR2(10 btye),另一种是VARCHAR2(10 char)。前者是默认值,表示10个字节,后者表示10个字符。

        一个汉字占几个字节和oracle库的字符集有关系。如果字符集是ZHS16GBK,一个汉字就占2个字节;如果字符集是AL32UTF8,一个汉字就是占3个字节

        如果查看oracle的字符集:

        

SELECT * FROM v$nls_parameters WHERE PARAMETER='NLS_CHARACTERSET';

        如果不想查看当前数据库的字符集,想知道当前oracle库一个汉字占几个字节,可以利用lengthb()函数,这是查看当前数据库一个汉字占几个字节

        length()函数是查看当前字符串占几个字符,也就是字符串长度。

select  lengthb('中国')  from dual; // 6个字节

你可能感兴趣的:(oracle,数据库)