博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
char nvarchar varchar
阅读量:7089 次
发布时间:2019-06-28

本文共 1354 字,大约阅读时间需要 4 分钟。

1. char
     固定长度,最长n个字符。
 
2. varchar
     最大长度为n的可变字符串。
(n为某一整数,不同数据库,最大长度n不同)
 
char和varchar区别:
     varchar必char节省空间,但在效率上比char稍微差一些。
     说varchar比char节省空间,是因为varchar是可变字符串,比如:用varchar(5)存储字符串“abc”,只占用3个字节的存储空间,而用char(5)存储,则占用5个字节(“abc  ”)。
     说varchar比char效率稍差,是因为,当修改varchar数据时,可能因为数据长度不同,导致数据迁移(即:多余I/O)。其中,oracle对此多余I/O描述的表达是:“行迁移”(Row Migration)。
 
“行迁移”(Row Migration):
     
 
“当一行的记录初始插入时是可以存储在一个block中的,由于更新操作导致行增加了,而block的自由空间已经完全满了,这个时候就产生了行迁移。在这种情况下,oracle将会把整行数据迁移到一个新的block中,oracle会保留被迁移的行的原始指针指向新的存放行数据的block,这就意味着被迁移行的ROW ID是不会改变的。"
     其中要解释一下:block是oracle中最小的数据组织与管理单位,是数据文件磁盘储存空间单位,也是
数据库I/O最小单位(
也就是说,读和写都是一个block打大小,所以如果block没满时,更新内容长度变更的varchar字段,和更新内容长度没变的varchar字段,I/O次数是一样,不存在额外消耗,只有在block满时,才会出现额外I/O,所以char和varchar性能之间的性能差异,是相当细微的,绝大多数情况下可以忽略不计,所以上文描述的“稍”差的含义)
     所以,我的开发经验是:“
用varchar完全代替char吧,没什么好顾虑的”。
 
3. nvarchar
     nvarchar的特性,需要和varchar对比。
     nvarchar和varchar的不同主要是在对于数据的存储方式上:
     1). varchar:
按字节存储数据
          varchar(6),最多能存储6个字节的数据,比如:“哈哈哈”,“abcdef”......
备注:一个中文字符在数据库里占多少个字节,要看unicode的编码方式,比如:utf8在mysql上占3个字节,sqlserver的Chinese_PRC_CI_AS占2个字节...
     2). nvarchar:
按字符存储数据
          nvarchar(6),最多能存储6个字符/中文数据,比如:"哈哈哈哈哈哈",“abcdef”......
          nvarchar(m)最大存储的实际字节长度=n*m(n跟据编码方式而定),如果nvarchar存储的是英文字符,也是根据编码方式存储n的字节长度。也就是说,如果
nvarchar存储英文字符,会浪费一半以上的存储空间....
          
总结:
    
 1. char和varchar的性能差距是很小的,可以考虑忽略不计。
     2. 在大数据量应用中,使用char和nvarchar有可能导致大量的存储空间的浪费。

转载于:https://www.cnblogs.com/muxueyuan/p/4872447.html

你可能感兴趣的文章
Windows审核策略设置
查看>>
利用fiddler 对手机抓包
查看>>
CentOS7安装配置FTP服务器
查看>>
C++文件流打开方式的使用
查看>>
从Exchange 通往Office 365系列(十五)配置ADRMS与Exchange结合
查看>>
好用的软件之Xmind
查看>>
elasticsearch rpm安装以及配置修改
查看>>
我的友情链接
查看>>
U盘故障处理方法
查看>>
读写操作(补充)
查看>>
ORACLE学习笔记
查看>>
linux rpm问题:怎样查看rpm安装包的安装路径
查看>>
linux下mysql忘记root密码的解决方法
查看>>
勒索病毒,距离我们还有多远?
查看>>
为IBM 3650 M2 服务器配置RAID卡(一)
查看>>
从零开始linux下搭建tomcat服务器
查看>>
我的友情链接
查看>>
阿里云高级技术专家带你全面了解云主机性能评测
查看>>
揭秘人工智能(系列):人工智能带来的网络安全威胁
查看>>
《cut命令》-linux命令五分钟系列之十九
查看>>