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有固定 ...
随机推荐
- 【LeetCode】204 - Count Primes
Description:Count the number of prime numbers less than a non-negative number, n. Hint: Let's start ...
- Careerup上的简历模板
So this is what a GOOD resume look like http://www.careercup.com/resume (需FQ)
- RPC进阶篇
RPC实现结构拆解 RPC过程调用详解:RPC 服务端通过 RpcServer 去导出(export)远程接口方法,而客户端通过 RpcClient 去引入(import)远程接口方法. 客户端像调用 ...
- 【转】 Linux Shell 命令--rename
重命名文件,经常用到mv命令,批量重命名文件rename是最好的选择,Linux的rename 命令有两个版本,一个是C语言版本的,一个是Perl语言版本的,判断方法:输入man rename 看到第 ...
- qqq
http://blog.sina.com.cn/s/blog_6f0774010100wawd.html http://www.2cto.com/kf/201302/189135.html http: ...
- Python面试必须要看的15个问题
本文由EarlGrey@编程派独家编译,转载请务必注明作者及出处. 原文:Sheena@codementor 译文:编程派 引言 想找一份Python开发工作吗?那你很可能得证明自己知道如何使用Pyt ...
- initWithSpriteFrameName和createWithSpriteFrameName
/** * Initializes a sprite with a sprite frame name. <br/> * A cc.SpriteFrame will be fetched ...
- Docker 入门教程(转)
add by zhj: 可以简单的认为docker是对LXC(Linux Container)封装,它提供一种比LXC高级的API.Docker使用Go语言开发,利用了Linux提供的LXC,AUFS ...
- Quora的技术探索(转)
原文:http://www.cnblogs.com/xiekeli/archive/2012/04/27/2473808.html 关于问答类的应用,最早接触的是stackoverflow和知乎 ,而 ...
- Maven+Spring Batch+Apache Commons VF学习
Apache Commons VFS资料:例子:http://www.zihou.me/html/2011/04/12/3377.html详细例子:http://p7engqingyang.iteye ...