zoukankan      html  css  js  c++  java
  • ORACLE数据库汉字占几个字节问题

    近期在进行系统升级部署的时候,发现不同地区的数据库编码格式不一致,按照正常的编码设定,一个汉字占用2个字节,但是在有的系统,由于编码要求,可能一个汉字就会占用3个或者4个字节,如图所示

    引起这样的原因一般有两个:

    一:因为ORACLE数据库它可以存储字节或字符,例如 CHAR(12 BYTE) CHAR(12 CHAR)的意义是不同的.一般来说默认是存储字节,你可以查看数据库参数NLS_LENGTH_SEMANTICS的值。 

    二:ORACLE数据库汉字占用几个字节,要根据ORACLE中字符集编码决定,一般情况下,数据库的NLS_CHARACTERSET 为AL32UTF8或UTF8,即一个汉字占用三到四个字节。如果NLS_CHARACTERSET为ZHS16GBK,则一个字符占用两个字节.

     输入如下sql:

    select * from nls_database_parameters

    至于具体情况,可以通过LENGTHB或者VSIZE函数求得是占用字节数。

      

    LENGTH函数求得是占用字符数,LENGTHB或者VSIZE函数求得是占用字节数。

    LENGTH是计算字符的个数,输入的参数先被转为字符类型计算

     对于解决方案,将数据库nls_database_parameters表里头的NLS_CHARACTERSET进行相关的调整即可。

  • 相关阅读:
    Notes相关开发Tips
    gridView滚动条相关问题
    MyBatis学习(一)简单入门程序
    springMVC入门
    zoj 3702 Gibonacci number 找规律
    邻接表表示
    poj 1269 直线相交情况
    poj 3304 Segments 线段与直线相交的判断
    poj 1654 多边形面积
    zoj 3696 Alien's Organ 概率,泊松分布
  • 原文地址:https://www.cnblogs.com/shawWey/p/8874646.html
Copyright © 2011-2022 走看看