varchar2 类型「建议收藏」

varchar2 类型「建议收藏」1、varchar2在数据库表中的最大长度是4000bytesorcharacter,在oracleplsqlvarchar2最大支持长度为32767个字节SQL>declare 2       v_varvarchar2(32767); 3     begin 4       null; 5     end; 6     /

大家好,又见面了,我是你们的朋友全栈君。

1 、varchar2 在数据库表中的最大长度是4000 bytes or character,在 oracle plsql varchar2最大支持长度为32767个字节

SQL> declare
  2        v_var varchar2(32767);
  3      begin
  4        null;
  5      end;
  6      /

PL/SQL 过程已成功完成。

SQL> declare
  2        v_var varchar2(32768);
  3      begin
  4        null;
  5      end;
  6  /
      v_var varchar2(32768);
                     *
第 2 行出现错误:
ORA-06550: 第 2 行, 第 22 列:
PLS-00215: 字符串长度限制在范围 (1…32767)

SQL> declare
  2        v_var varchar2(32767 byte);
  3        v_char varchar2(32767 char);
  4      begin
  5        v_var := lpad(‘a’,32767,’a’);
  6        dbms_output.put_line(length(v_var));
  7        v_char := lpad(‘中’,32767,’中’);
  8       dbms_output.put_line(lengthb(v_var));
  9       v_var := lpad(‘中’,32768,’中’);
10    end;
11  /
declare
*
第 1 行出现错误:
ORA-06502: PL/SQL: 数字或值错误 :  字符串缓冲区太小
ORA-06512: 在 line 9

2 、索引的长度有限制

SQL> create table t ( a varchar2(4000), b varchar2(4000));

表已创建。

SQL> create index i on t(a,b);
create index i on t(a,b)
                  *
第 1 行出现错误:
ORA-01450: 超出最大的关键字长度 (6398)

3、

ORACLE中VARCHAR2类型的字段长度是按照byte来定义的。如果数据库使用的字符集是GBK,GB2312或者其他定长字符集的话,这个问题似乎可以被忽略,因为只要把数据库的字段长度/2就可以得到你要限制插入该字段的中文长度了。    但是,如果数据库的字符集是UTF-8呢,杯具了吧,人家是变长的。

其实人家ORACLE没这么笨,本来就可以用字符为单位来定义varchar2的长度的,这个时候需要注意在建表时这样写:createtable ABC_TABLE (A_FIELD varchar2(20 char)) 

这个varchar2(2 char)就表示了是用字符为单位来定义了,而默认情况下的varchar2(2)这样就是字节!

SQL> create table AB (A varchar2(2 char))  ;

表已创建。

SQL> insert into ab values(‘如果’);

已创建 1 行。

SQL> commit;

提交完成。

SQL> select *From ab;

A
—-
如果

SQL> create table ABc (A varchar2(2))  ;

表已创建。

SQL> insert into abc values(‘如果’);
insert into abc values(‘如果’)
                       *
第 1 行出现错误:
ORA-12899: 列 “SCOTT”.”ABC”.”A” 的值太大 (实际值: 4, 最大值: 2)

如果你不确定数据库里究竟是怎么定义,你想找出所有采用字节定义长度的字段,

select * from user_tab_columnswhere CHAR_USED=‘B’ 

这里的CHAR_USED的意思是:如果是字符定义-‘C’,字节定义-‘B’

4VARCHA2可能导致的问题是行迁移。

如果varchar2列被修改,而且修改后数据长度增大,这会引起‘行迁移’(Row Migration),造成多余的I/O。主要影响:行迁移和行链接,直接导致数据读取和写入IO增多

5 varhcar2和char的区别

SQL> create table t( a varchar2(3),b char(3));

表已创建。

SQL> insert into t values(‘a’,’a’);

已创建 1 行。

SQL> commit;

提交完成。

SQL> select *From t;

A   B
— —
a   a

SQL> select dump(a),dump(b) from t;

DUMP(A)
——————————————————————————–
DUMP(B)
——————————————————————————–
Typ=1 Len=1: 97
Typ=96 Len=3: 97,32,32

从dump中可以看出varchar2的存储长度是1,而char类型的长度是3,其余空间被空格填充;

参考:http://doingwell.iteye.com/blog/972938

http://www.linuxidc.com/Linux/2012-03/56006.htm

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/149490.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux fsync实例,Python os.fsync()方法「建议收藏」

    linux fsync实例,Python os.fsync()方法「建议收藏」Python的os.fsync()方法返回强制将文件描述符fd写入磁盘。如果使用Python文件对象f,首先要执行f.flush(),然后执行os.fsync(f.fileno()),以确保与f关联的所有内部缓冲区都被写入磁盘。语法以下是fsync()方法的语法-os.fsync(fd)参数fd−这是缓冲区同步的文件描述符(必需的)。返回值此方法没有返回值。示例以下示例显示了fsync()…

    2022年5月31日
    79
  • printwriter和outputstream_print和type的区别

    printwriter和outputstream_print和type的区别区别1:rintStream类和PrintWriter类 PrintStream主要操作byte流,而PrintWriter用来操作字符流。读取文本文件时一般用后者。java的一个字符(char)是16bit的,一个BYTE是8bit的 PrintStrean是写入一串8bit的数据的。 PrintWriter是写入一串16bit的数据的。 String缺省是用UNICOD

    2022年8月10日
    4
  • python怎么安装requests库-小白安装python的第三方库:requests库

    1.安装:按照教程中的步骤是:Step1:以管理员身份打开command控制台Step2:键入pipinstallrequests对其进行安装然而实际经历是:出现’pip’不是内部或外部命令,也不是可运行的程序或批处理文件。的字样报错经过参考网络上的各种解决方法后,鉴于自己的实际情况→电脑里的python3.6不是安装的,是VS顺带下载的,因此难免缺胳膊少腿,就采取了如下解决步骤。刚安…

    2022年4月1日
    956
  • java中的四舍五入——几种四舍五入的写法

    java中的四舍五入——几种四舍五入的写法//方式一:BigDecimal方式doublef=3.1315;BigDecimalb=newBigDecimal(newDouble(f).toString);doublef1=b.setScale(3,BigDecimal.ROUND_HALF_UP).doubleValue();注意:这里一定不要直接使用newBigDecimal(double)

    2022年7月9日
    17
  • Spring Boot第八章-数据缓存Cache

    Spring Boot第八章-数据缓存Cache

    2021年5月16日
    139
  • 分子排列不同会导致_《分子生物学》习题答案

    分子排列不同会导致_《分子生物学》习题答案《分子生物学》课后习题第1章绪论1.简述孟德尔、摩尔根和Waston等人对分子生物学发展的主要贡献。孟德尔是遗传学的奠基人,被誉为现代遗传学之父。他通过豌豆实验,发现了遗传学三大基本规律中的两个,分别为分离规律及自由组合规律。摩尔根发现了染色体的遗传机制,创立染色体遗传理论,是现代实验生物学奠基人。于1933年由于发现染色体在遗传中的作用,赢得了诺贝尔生理学或医学奖。Watson于1953年和克里…

    2022年7月11日
    16

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号