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

 

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/149491.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 小程序 消息推送配置token无效(解决方法)订阅消息

    小程序 消息推送配置token无效(解决方法)订阅消息代码://验证tokenfunctionverifyToken(){$signature=$_GET[“signature”];$timestamp=$_GET[“timestamp”];$nonce=$_GET[“nonce”];$token=’571247942′;//和token(令牌)一一对应$tmpArr=array($token,$timestamp,$nonce);sort($tmpArr,SORT_STR

  • linux教程,linux视频教程,linux…

    linux教程,linux视频教程,linux…IBM的linux学习资源—Linux编程和系统管理新手入门: http://www.ibm.com/developerworks/cn/linux/newto/Windows到Linux之旅:系列文章概述: http://www.ibm.com/developerworks/cn/linux/l-roadmap/index.html为Windows用户准备的简明L

  • DOCKER学习笔记(MAC)

    DOCKER学习笔记(MAC)

  • 抓包工具Charles基本用法

    抓包工具Charles基本用法我们在进行B/S架构的Web项目开发时,在前端页面与后台交互的调试的时候,通常使用在JSP中加入“debugger;”断点,然后使用浏览器的F12开发者工具来查看可能出错的地方的数据。或者使用HttpWatch来抓包分析。在开发移动端项目没有网页的情况下,就不能通过这种方式抓取数据进行分析了。这时可以使用Charles满足以上要求。Charles是一款Http代理服务器和Http监视器,当移动

  • layoutparams方法_layoutinflater是什么

    layoutparams方法_layoutinflater是什么http://www.2cto.com/kf/201606/514962.html在上一篇文章里,我总结了一下自定义控件需要了解的基础知识:View的绘制流程——《自定义控件知识储备-View的绘制流程》。其中,在View的测量流程里,View的测量宽高是由父控件的MeasureSpec和View自身的LayoutParams共同决定的。MeasureSpec是什么,上一篇文章里已经说

  • 【matlab】函数meshgrid的用法详解(生成网格矩阵)和ndgrid的区别及用法「建议收藏」

    【matlab】函数meshgrid的用法详解(生成网格矩阵)和ndgrid的区别及用法「建议收藏」meshgrid函数用来生成网格矩阵,可以是二维网格矩阵,也可以是三维。对于生成二维网格,用法为:[xy]=meshgrid(ab); %a和b是一维数组,如a=[123];b=[234];则生成的x和y都是二维的矩阵,x的每行都是123,共三行,y每列都是234,共三列。举个实例:Forexample, toevaluateth

发表回复

您的电子邮箱地址不会被公开。

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