Oralce中VARCHAR2()与NVARCHAR2()的区别介绍
技术  /  管理员 发布于 7年前   222
一、先来看看Oralce中VARCHAR2()和NVARCHAR2()的官方定义
官方文档定义如下:
VARCHAR2(size [BYTE | CHAR])
Variable-length character string having maximum length size bytes or characters. Maximum size is 4000 bytes or characters, and minimum is 1 byte or 1 character. You must specify size for VARCHAR2.
BYTE indicates that the column will have byte length semantics. CHAR indicates that the column will have character semantics.
NVARCHAR2(size)
Variable-length Unicode character string having maximum length size characters. The number of bytes can be up to two times size for AL16UTF16 encoding and three times size for UTF8 encoding. Maximum size is determined by the national character set definition, with an upper limit of 4000 bytes. You must specify size for NVARCHAR2.
二、中文翻译:
VARCHAR2(size [BYTE | CHAR])
具有最大长度的字节数(bytes)或字符数(char)的可变长度的字符类型。最大长度为4000字节/字符,最小长度是1字节/字符。你必须为VARCHAR2()
类型指定大小。
BYTE代表该列以字节计算长度,CHAR代表该列以字符计算长度。
NVARCHAR2(size)
具有最大长度的带有字符集属性的可变长度的字符类型。它的长度是AL16UTF16字符集的2倍,UTF8字符集的三倍。它的最大长度取决于字符集,上限位4000字节。您必须为NVARCHAR2()
类型指定大小。
三、实战演练
使用字符集为UTF8。
# 验证NVARCHAR2(size)与VARCHAR2(size CHAR)相似SQL> create table t_varchar2(name varchar2(6 CHAR));Table createdSQL> insert into t_varchar2 values('中国');1 row insertedSQL> insert into t_varchar2 values('中华人民共和');1 row insertedSQL> insert into t_varchar2 values('中华人民共和国');insert into t_varchar2 values('中华人民共和国')ORA-12899: 列 "SCOTT"."T_VARCHAR2"."NAME" 的值太大 (实际值: 7, 最大值: 6)SQL> create table t_nvarchar2(name nvarchar2(6));Table createdSQL> insert into t_nvarchar2 values('中国');1 row insertedSQL> insert into t_nvarchar2 values('中华人民共和');1 row insertedSQL> insert into t_nvarchar2 values('中华人民共和国');insert into t_nvarchar2 values('中华人民共和国')ORA-12899: 列 "SCOTT"."T_NVARCHAR2"."NAME" 的值太大 (实际值: 7, 最大值: 6)# 验证NVARCHAR2(sie)与VARCHAR(size CHAR)存在最大长度不同SQL> create table t_varchar2(name varchar2(4000 CHAR));Table createdSQL> create table t_nvarchar2(name nvarchar2(4000));create table t_nvarchar2(name nvarchar2(4000))ORA-00910: 指定的长度对于数据类型而言过长
四、区别总结:
NVARCHAR2(size)
与VARCHAR2(size CHAR)
相似,唯一的区别是NVARCHAR2(size)
的最大长度是4000字节(实验测试结果是,在utf8的字符集下,最大长度为2000字符),而VARCHAR2(size CHAR)
的最大长度是4000字符。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号