MySql之char与varchar
MySql之char与varchar的差别
char是一种固定长度的类型,varchar则是一种可变长度的类型。它们的差别是:
1. char(M)类型的数据列里。每一个值都占用M个字节。假设某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)
在varchar(M)类型的数据列里,每一个值仅仅占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).
2.char的效率比varchar2的效率稍高。
3.眼下varchar是varchar2的同义词。
工业标准的varchar类型能够存储空字符串,可是oracle不这样做,虽然它保留以后这样做的权利。Oracle自己开发了一个数据类型varchar2,这个类型不是一个标准的varchar。它将在数据库中varchar列能够存储空字符串的特性改为存储null值。假设你想有向后兼容的能力,Oracle建议使用varchar2而不是varchar。
何时该用char,何时该用varchar2?
char与varchar2是一对矛盾的统一体,两者是互补的关系.
varchar比char节省空间。在效率上比char会略微差一些。即要想获得效率,就必须牺牲一定的空间。这也就是我们在数据库设计上常说的‘以空间换效率’。
varchar2 尽管比char节省空间,可是假设一个varchar2列常常被改动,并且每次被改动的数据的长度不同。这会引起‘行迁移’(Row Migration)现象。而这造成多余的I/O,是数据库设计和调整中要尽力避免的,在这样的情况下用char取代varchar2效果会更好一些。
以下是在mysql中的实验证明:
mysql> #tee 将命令框中的内容输入到指定文件
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| db1 |
| mysql |
| performance_schema |
| student |
| test |
+--------------------+
6 rows in set (0.02 sec)
mysql> use student;
Database changed
mysql> show tables;
+-------------------+
| Tables_in_student |
+-------------------+
| infotb |
+-------------------+
1 row in set (0.00 sec)
mysql> desc infotb;
+-------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+----------------+
| id | tinyint(4) | NO | PRI | NULL | auto_increment |
| name | varchar(20) | NO | | NULL | |
| sex | varchar(5) | YES | | NULL | |
| tel | varchar(20) | YES | | NULL | |
| ad | varchar(30) | YES | | NULL | |
+-------+-------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)
mysql> select * from infotb;
+----+----------+------+-------------+----------------+
| id | name | sex | tel | ad |
+----+----------+------+-------------+----------------+
| 13 | cyz | NULL | 123 | 123 |
| 15 | cool | NULL | cool | cool |
| 16 | this | NULL | is | great |
| 17 | 哈喽 | NULL | NULL | NULL |
| 22 | QQ群 | NULL | 111 | 河南 |
| 24 | 123 | NULL | 123 | 123 |
| 26 | 哈哈哈哈 | NULL | 123123 | 阿斯顿 |
| 27 | tom | NULL | 123 | NULL |
| 28 | tom2 | NULL | 1233 | NULL |
| 29 | tom | NULL | 123 | NULL |
| 30 | tom2 | NULL | 1233 | NULL |
| 31 | tom | NULL | 123 | NULL |
| 32 | tom2 | NULL | 1233 | NULL |
+----+----------+------+-------------+----------------+
22 rows in set (0.01 sec)
mysql> create table test (
-> ca char(4) not null defalut '',
-> vca varchar(4) not null defalut ''
-> );
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'defalut '',
vca varchar(4) not null defalut ''
)' at line 2
mysql> create table test (
-> ca char(4) not null default '',
-> vca varchar(4) not null default ''
-> );
Query OK, 0 rows affected (0.22 sec)
mysql> #练习char与varchar的差别
mysql> insert into test(ca,vca) value('aa ','aa ');
Query OK, 1 row affected (0.09 sec)
mysql> select * from test;
+----+-----+
| ca | vca |
+----+-----+
| aa | aa |
+----+-----+
1 row in set (0.00 sec)
mysql> #concat 连接字符串函数
mysql> select concat(ca,'!'),concat(vca,'!') from test;
+----------------+-----------------+
| concat(ca,'!') | concat(vca,'!') |
+----------------+-----------------+
| aa! | aa ! |
+----------------+-----------------+
1 row in set (0.18 sec)
mysql> #char和varchar分别称为定长和变长类型
mysql> #对于char(N),不够N个长度,用空格在尾部补够N个长度,浪费了尾部。
mysql> #而对于varchar(N),不用空格补齐,但在列内容前,有1-2个字节来标志该列的内容长度。
mysql> #char读取速度比較快。但浪费存储空间,末尾有空格的字符串读取时。空格读不出来
mysql> #varchar读取速度没有char快,但充分利用存储空间。可以存储随意字符。
mysql> exit;
#tee 将命令框中的内容输入到指定文件
MySql之char与varchar的更多相关文章
- MySQL中char、varchar和text的区别
三者空间占用方面: char:存储定长数据很方便,CHAR字段上的索引效率极高,可以有默认值,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间(自动用空格填 ...
- MySQL中char与varchar区别,varchar最大长度是多少?
一.首先来说下字符与字节的区别: 字符与字节它们完全不是一个位面的概念,所以两者之间没有"区别"这一说法.在不同编码里,字符和字节的对应关系是不同的.一般来说,半角英文状态下一个字 ...
- MySQL的char和varchar针对空格的处理
MySQL的char和varchar存储和查询中包含空格的实验 MySQL版本 一.测试char包含空格的存储和查询 测试发现,存储的数据,char数据类型的右侧空格存储的时候被删除了,但是左侧空格还 ...
- Mysql学习总结(29)——MySQL中CHAR和VARCHAR
MySQL数据库的字符(串)类不要以为字符类型就是CHAR,CHAR和VARCHAR的区别在于CHAR是固定长度,只要你定义一个字段是CHAR(10),那么不论你存储的数据是否达到了10个字节,它都要 ...
- [转载]MySQL之char、varchar和text的设计
[转载]MySQL之char.varchar和text的设计 来源:https://www.cnblogs.com/billyxp/p/3548540.html 首先我们先普及一下常识: 1.char ...
- 浅谈SQL Server、MySQL中char,varchar,nchar,nvarchar区别
最近一次的面试中,被面试官问到varchar和nvarchar的区别,脑海里记得是定长和可变长度的区别,但却没能说出来.后来,在网上找了下网友总结的区别.在这里做个备忘录: 一,SQL Server中 ...
- 万答#11,MySQL中char与varchar有什么区别
万答#11,MySQL中char与varchar有什么区别 1.实验场景 GreatSQL 8.0.25 InnoDB 2.实验测试 2.1 区别 参数 char varchar 长度是否可变 定长 ...
- mysql中char,varchar与text类型的区别和选用
关于char,varchar与text平时没有太在意,一般来说,可能现在大家都是用varchar.但是当要存储的内容比较大时,究竟是选择varchar还是text呢?不知道...... 于是去查阅了一 ...
- mysql中char与varchar的区别分析(补充一句,int和integer没区别)
转自:http://www.jb51.net/article/23575.htm 在mysql教程中char与varchar的区别呢,都是用来存储字符串的,只是他们的保存方式不一样罢了,char有固定 ...
随机推荐
- 45个有新意的Photoshop教程和技巧
图形制作者和网页设计师已经准备好迎接新的Adobe Photoshop 教程了.在大家喜欢背后有许多它的理由,诸如Adobe Photoshop很容易操作,学习起来十分简单,但最重要的一点是这款软件能 ...
- 应用删除后 Launchpad 上仍有应用图标无法删除的解决方法
应用删除后 Launchpad 上仍有应用图标上带有问号且无法删除时,可以将 launchpad 重置. 在终端输入: defaults write com.apple.dock ResetLaunc ...
- keystone v2 to v3
http://www.cloudkb.net/how-to-change-keystone-api-v2-v3/
- 借助LVS+Keepalived实现负载均衡(转)
原文:http://www.cnblogs.com/edisonchou/p/4281978.html 一.负载均衡:必不可少的基础手段 1.1 找更多的牛来拉车吧 当前大多数的互联网系统都使用了服务 ...
- 2d网络游戏的延迟补偿(Lag compensation with networked 2D games)
http://gamedev.stackexchange.com/questions/6645/lag-compensation-with-networked-2d-games ——————————— ...
- JAVA应用apache httpclient探测http服务
代码很简单,apache都已经提供了封装. import org.apache.commons.httpclient.HttpClient; import org.apache.commons.htt ...
- spring mvc为何多注入了个SimpleUrlHandlerMapping?
最近在调试项目时,debug DispatcherServlet时,发现handlerMappings属性包含了RequestMappingHandlerMapping.SimpleUrlHandle ...
- LightOJ 1112 Curious Robin Hood (单点更新+区间求和)
http://lightoj.com/volume_showproblem.php?problem=1112 题目大意: 1 i 将第i个数值输出,并将第i个值清0 2 i v ...
- C#取得当前目录 转载
/获取包含清单的已加载文件的路径或 UNC 位置. public static string sApplicationPath = Assembly.GetExecutingAssem ...
- Spring JTA应用JOTM & Atomikos III Atomikos
前面简单介绍了JOTM如何在Spring中配置,并如何使用它的JTA事务,本节将介绍Atomikos如何与Spring集成,并使用它的JTA事务. Atomikos,是一个基于Java的开源事务管理器 ...