(3.4)常用知识-char与varchar的选择
1.char与varchar的比较
(1)数据存储开销
【1】varchar列需要2个额外的字节来记录存储数据的长度
【2】每个可为null的char列,需要一些字节(空位图)来反应数据的为空性
【3】无论数据多少,char都占定义的长度分配的存储空间
【4】varchar是存储多少空间,就占多少空间,最大不能超过定义的空间,除此之外还需要2个额外的字节如【1】中所属。
【5】索引上的数据存储不需要额外的内部开销,索引数据的存储方式与数据也在数据的存储方式一样。
(2)NULL值
【1】char列的null占用存储空间
【2】varchar列的null不占存储空间
【3】插入同样数量的null,varchar比char效率高出很多
(3)插入数据
【1】无论是否有索引,char的效率都低于varchar的效率
(4)更新数据
【1】如果更新的列未建立索引,则char的效率低于varchar,但区别不大
【2】如果更新的列简历的索引,则char的效率低于varchar,且区别较大
(5)修改结构
【1】无论是增加还是删除,char与varchar的效率没有什么差异
【2】对于增加列的宽段而言,varchar基本上不花多少时间(因为本来就给它预留了那么多空间并且是根据实际存储数据来分配空间),char则需要花费很长时间(要考虑页分裂、或存储到ROW_OVERFLOW_DATA)
(6)数据检索
【1】无论是否有索引,varchar都比char的扫描要略优。(因为扫描的长度与页数)
2.如何选择char与varchar
(1)char使用情况
【1】列汇总的各行数据长度基本一致,长度变化小,不超过50字节
【2】数据变更频繁,检索需求少
【3】列长度不会经常变化,因为修改char类型的列宽代价很大
【4】不要出现大量null,因为char中null占存储空间
【5】列上不需要建过多索引,过多的索引对char列的数据变更影响较大
(2)varchar使用情况
【1】列中各行长度差异较大
【2】列中数据更新非常少(因为虽然是存多少占多少空间,但是为了避免增长导致使用row_overflow_data),但查询非常频繁
【3】列中没有数据,或为null、空值
3.其他影响因素
(1)列是否允许NULL值
如果允许,则需要考虑NULL值所占数据的比例,定义char null的列时,需要额外的开销来反应为NULL的情况,这回导致插入NULL值分配更多的空间,影响性能,当大表且NULL量较大时,性能影响非常明显。
(2)磁盘空间开销
使用char存储数据时,它占用的空间长度为列定义的长度,与实际数据长度无关,因此往往意味着会比varchar消耗更多存储空间
(3)内存大小
SQL SERVER 以页为单位,数据占用的页越多,往往以为着内存消耗更高,如果数据还没有加载到内存中则读取更多的数据页也意味着更多的磁盘I/O。
(4)数据传输
数据传输主要考虑服务器到客户端,或者是服务器之间的数据交互,或者是与其他系统的数据交互。
(3.4)常用知识-char与varchar的选择的更多相关文章
- char、varchar和nvarchar的区别
首先char.varchar和nvarchar.text.ntext都是数据库中的文本数据类型,再区分区分var前缀.n前缀的区别.而text.ntext已经普遍被varchar(MAX)和nvarc ...
- MySQL的char和varchar
一.VARCHAR与CHAR字符型数据的差异 在MySQL数据库中,用的最多的字符型数据类型就是Varchar和Char,这两种数据类型虽然都是用来存放字符型数据,但是无论从结构还是从数据的保存方式来 ...
- 2019-2-20Sqlserver数据库中char、varchar、nchar、nvarchar的区别及查询表结构
varchar 和 nvarchar区别: varchar(n)长度为 n 个字节的可变长度且非 Unicode 的字符数据.n 必须是一个介于 1 和 8,000 之间的数值.存储大小为输入数据的字 ...
- MySQL数据库char与varchar的区别分析及使用建议
在数据库中,字符 型的数据是最多的,可以占到整个数据库的80%以上.为此正确处理字符型的数据,对于提高数据库的性能有很大的作用.在字符型数据中,用的最多的就是 Char与Varchar两种类型.前面的 ...
- char 与 varchar 区别
MySQL中的字符串有两个常用的类型:char和varchar,二者各有优势,下面我们来详细分析一下. 转载加补充 在建立数据库表结构的时候,为了给一个String类型的数据定义一个数据库的数据库类 ...
- (3.10)常用知识-T-SQL优化
关键字:SQL优化 总结: 1.书写问题 2.表连接方式 3.索引的抉择 4.执行计划之参数嗅探,使用提示强制执行计划 5.子查询与表连接的效率 6.临时表.CTE.表变量的选择 7.常用sp与sel ...
- SQL中char、varchar、nchar、nvarchar 详解
char char是定长的,也就是当你输入的字符小于你指定的数目时,char(8),你输入的字符小于8时,它会再后面补空值.当你输入的字符大于指定的数时,它会截取超出的字符. varchar[ ...
- Sql Server char、varchar、nchar、nvarchar的区别
(1) 定义: char: 固定长度,存储ANSI字符,不足的补英文半角空格. nchar: 固定长度,存储Unicode字符,不足的补英文半角空格 varchar: 可变长度,存储ANSI字符,根据 ...
- 浅谈SQL Server、MySQL中char,varchar,nchar,nvarchar区别
最近一次的面试中,被面试官问到varchar和nvarchar的区别,脑海里记得是定长和可变长度的区别,但却没能说出来.后来,在网上找了下网友总结的区别.在这里做个备忘录: 一,SQL Server中 ...
随机推荐
- ETL工具之——kettle使用简介
ETL工具之——kettle使用简介 https://yq.aliyun.com/articles/157977?spm=5176.10695662.1996646101.searchclickres ...
- MySQL5.7数据转移至SQL Server详解
本文链接:https://blog.csdn.net/qq_37308779/article/details/80679358一.安装MySQL ODBC驱动为MySQL安装Connector/ODB ...
- Qt第三方库----QCustomPlot
一.软件下载 下载地址:http://www.qcustomplot.com/index.php/download 这里推荐下载第一个链接的内容: 注:这里的第三方库要放在非中文目录下. 二.配置 ( ...
- sh_07_函数的嵌套调用
sh_07_函数的嵌套调用 def test1(): print("*" * 50) def test2(): print("-" * 50) # 函数的嵌套调 ...
- 【Leetcode】买卖股票-贪心算法
题目: 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 设计一个算法来计算你所能获取的最大利润.你可以尽可能地完成更多的交易(多次买卖一支股票). 注意:你不能同时参与多笔交易(你必 ...
- Android图片缩放 指定尺寸
//使用Bitmap加Matrix来缩放 public static Drawable resizeImage(Bitmap bitmap, int w, int h) { ...
- JMS学习四(ActiveMQ消息过滤)
一.消息的选择器 不管是在消息发送端设置消息过期时间还是在接收端设置等待时间,都是对不满足的消息有过滤的作用,那消息选择器就是为过滤消息而生的下面来看看消息选择器: ActiveMQ提供了一种机制,使 ...
- linux xz压缩解压
1. 解压 xz 格式文件 方法一: 需要用到两步命令,首先利用 xz-utils 的 xz 命令将 linux-3.12.tar.xz 解压为 linux-3.12.tar,其次用 tar 命令将 ...
- React Native商城项目实战02 - 主要框架部分(tabBar)
1.安装插件,cd到项目根目录下执行: $ npm i react-native-tab-navigator --save 2.主框架文件Main.js /** * 主页面 */ import Rea ...
- webpack前置知识1(模块化开发)
webpack前置知识1(模块化开发) 新建 模板 小书匠 在开始对模块化开发进行讲解之前,我们需要有这么一个认识,即 在没有过多第三方干扰时,成本低收益高的事物更容易获得推广和信赖. 模块化开发就 ...