【MySQL】数据类型之字符相关
"
目录
字符类型
官网:https://dev.mysql.com/doc/refman/5.7/en/char.html
注意:char与varchar括号内的参数指的是字符的固定长度
char类型
定长,简单粗暴,浪费空间,存取速度快
- 字符长度:0 ~ 255(一个中文是一个字符,是utf8编码的3个字节)
例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储. - 检索:在检索时,显示的结果会自动删除尾部的空格,除非打开pad_char_to_full_length SQL模式
(设置SQL模式:set sql_mode = 'pad_char_to_full_length'; 查询sql的默认模式:select @@sql_mode;)
varchar类型
变长,精确,节省空间,存取速度慢
- 字符长度:0 ~ 65535(如果大于21845会提示用其它类型,MySQL行最大限制为65535字节,字符编码为utf8:官方文档)
- 存储:varchar类型存储数据的真实内容,不会用空格填充,也不会在查询时过滤尾部的空格.
强调:varchar类型会在真实数据前加1-2bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2bytes最大表示65535长度,正好符合MySQL对row的最大字节限制,即已足够使用).
[如果真实数据<255bytes,则需要1bytes的前缀(1bytes=8bit 2**8最大表示的数字为255);如果真实数据>255bytes,则需要2bytes的前缀(2bytes=16bit 2**16最大表示的数字为65535)] - 检索:尾部有空格会保存下来,在检索时也会正常显示包含空格在内的内容.
char 与 varchar 的官方解释:

实测
测试之前先来了解两个函数:
- length() # 查看字节数
- char_length() # 查看字节数
-
# 创建测试表,分别指明字段x为char类型,字段y为varchar类型
-
mysql> create table test(x char(5), y varchar(5));
-
Query OK, 0 rows affected (0.11 sec)
-
-
# 插入数据,后面加空格
-
mysql> insert into test values("数据库 ", "数据库 ");
-
Query OK, 1 row affected (0.00 sec)
-
-
# 在检索时,char类型会过滤掉后面的空格,而varchar正常显示
-
mysql> select x, char_length(x), y, char_length(y) from test;
-
+-----------+----------------+------------+----------------+
-
| x | char_length(x) | y | char_length(y) |
-
+-----------+----------------+------------+----------------+
-
| 数据库 | 3 | 数据库 | 4 |
-
+-----------+----------------+------------+----------------+
-
1 row in set (0.00 sec)
-
-
# 设置SQL模式,使char类型原形毕露
-
mysql> set sql_mode = 'pad_char_to_full_length';
-
Query OK, 0 rows affected, 1 warning (0.00 sec)
-
-
# 查当前SQL模式
-
mysql> select @@sql_mode;
-
+-------------------------+
-
| @@sql_mode |
-
+-------------------------+
-
| PAD_CHAR_TO_FULL_LENGTH |
-
+-------------------------+
-
1 row in set (0.00 sec)
-
-
# 再次检索,发现char类型的数据是占满规定的长度的(在后面填充空格)
-
mysql> select x, char_length(x), y, char_length(y) from test;
-
+-------------+----------------+------------+----------------+
-
| x | char_length(x) | y | char_length(y) |
-
+-------------+----------------+------------+----------------+
-
| 数据库 | 5 | 数据库 | 4 |
-
+-------------+----------------+------------+----------------+
-
1 row in set (0.00 sec)
-
-
# 查看字节数
-
# char类型:3个中文字符 + 两个空格 = 11bytes
-
# varchar类型:3个中文字符 + 1个空格 = 10bytes
-
mysql> select x, length(x), y, length(y) from test;
-
+-------------+-----------+------------+-----------+
-
| x | length(x) | y | length(y) |
-
+-------------+-----------+------------+-----------+
-
| 数据库 | 11 | 数据库 | 10 |
-
+-------------+-----------+------------+-----------+
-
1 row in set (0.01 sec)
总结
常用字符串系列:char 与 varchar
虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡
其它字符串系列(效率:char > varchar > text):
- TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT
- BLOB 系列 TINYBLOB BLOB MEDIUMBLOB LONGBLOB
- BINARY系列 BINARY VARBINARY
TEXT系列:text数据类型用于保存变长的大字符串,可以最多到65535(2**16 - 1)个字符
mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.
枚举类型与集合类型
即字段的值只能在规定范围中选择,如单选框,多选框
enum枚举:即单选,只能在给定的范围内选一个值.(如:性别 sex boy/girl)
set集合:即多选,在给定的范围内可以选择一个或一个以上的值.(如:爱好1,爱好2,爱好3)
-
mysql> create table information(
-
-> name char(3),
-
-> sex enum("男", "女"),
-
-> hobby set("抽烟", "喝酒", "烫头")
-
-> );
-
Query OK, 0 rows affected (0.05 sec)
-
-
mysql> insert into information values
-
-> ("张三", "男", "抽烟,喝酒"),
-
-> ("李四", "女", "烫头");
-
Query OK, 2 rows affected (0.00 sec)
-
Records: 2 Duplicates: 0 Warnings: 0
-
-
mysql> select * from information;
-
+---------+------+---------------+
-
| name | sex | hobby |
-
+---------+------+---------------+
-
| 张三 | 男 | 抽烟,喝酒 |
-
| 李四 | 女 | 烫头 |
-
+---------+------+---------------+
-
2 rows in set (0.00 sec)
"
【MySQL】数据类型之字符相关的更多相关文章
- mysql 数据类型
1.整型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节 范围(-128~127) smallint(m) 2个字节 范围(-32768~32767) mediumint(m) ...
- MySQL 数据类型 详解
MySQL 数据类型 详解 MySQL 的数值数据类型可以大致划分为两个类别,一个是整数,另一个是浮点数或小数.许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 My ...
- MySQL数据类型的验证
CHAR char (M) M字符,长度是M*字符编码长度,M最大255. 验证如下: mysql)) default charset=utf8; ERROR (): ); use BLOB or T ...
- MySQL数据类型 int(M) 表示什么意思?详解mysql int类型的长度值问题
MySQL 数据类型中的 integer types 有点奇怪.你可能会见到诸如:int(3).int(4).int(8) 之类的 int 数据类型.刚接触 MySQL 的时候,我还以为 int(3) ...
- 浅谈MySQL数据类型
MySQL 数据类型 MySQL中定义数据字段的类型对你数据库的优化是非常重要的. MySQL支持多种类型,大致可以分为三类:数值.日期/时间和字符串(字符)类型. 一.数值类型 MySQL支持所有标 ...
- MySQL数据类型——数值类型
1.1.1 整型 整型 占用字节 范围 范围 tinyint 1 -27~27-1 -128~127 smallint 2 -215~215-1 -32768~32767 mediumint 3 -2 ...
- 【转】MySQL数据类型和常用字段属性总结
来源:http://www.jb51.net/article/55853.htm 这里先总结数据类型.MySQL中的数据类型大的方面来分,可以分为:日期和时间.数值,以及字符串.下面就分开来进行总结. ...
- Oracle、SQL Server、MySQL数据类型对比
1,标准SQL数据类型 BINARY 每个字符占一个字节 任何类型的数据都可存储在这种类型的字段中.不需数据转换(例如,转换到文本数据).数据输入二进制字段的方式决定了它的输出方式. BIT 1 个字 ...
- MySQL数据类型和常用字段属性总结
前言 好比C++中,定义int类型需要多少字节,定义double类型需要多少字节一样,MySQL对表每个列中的数据也会实行严格控制,这是数据驱动应用程序成功的关键.MySQL提供了一组可以赋给表中各个 ...
- MySql数据类型详解
可配合http://www.cnblogs.com/langtianya/archive/2013/03/10/2952442.html学习 MySql数据类型 1.整型(xxxint) MySQ ...
随机推荐
- 第三十七篇 入门机器学习——Numpy基础
No.1. 查看numpy版本 No.2. 为了方便使用numpy,在导入时顺便起个别名 No.3. numpy.array的基本操作:创建.查询.修改 No.4. 用dtype查看当前元素的数据类型 ...
- 【译】PHP 内核 — 字符串管理
[译]PHP 内核 - 字符串管理 (Strings management: zend_string 译文) 原文地址:http://www.phpinternalsbook.com/php7/int ...
- kali2018.4 下载地址
https://www.linuxidc.com/Linux/2018-10/155088.htm
- 1069 The Black Hole of Numbers (20分)
1069 The Black Hole of Numbers (20分) 1. 题目 2. 思路 把输入的数字作为字符串,调用排序算法,求最大最小 3. 注意点 输入的数字的范围是(0, 104), ...
- vue 使用 jsonp 请求数据
vue 使用 jsonp 请求数据 vue请求数据的时候,会遇到跨域问题,服务器为了保证信息的安全,对跨域请求进行拦截,因此,为了解决vue跨域请求问题,需要使用jsonp. 安装jsonp npm ...
- ubuntu 终端快捷方式汇总
terminal 是一个命令行终端,将启动系统默认的shell,shell是一个解释并执行在命令行提示符输入的命令的程序. 启动 terminal1 在 “面板主页” 的应用程序搜索栏中,输入命令gn ...
- 每天进步一点点------Allegro PCB命名规则
PCB命名规则-allegro 一.焊盘命名规则 1. 贴片矩形焊盘 命名规则:SMD+长(L)+宽(W)(mil) 举例:SMD90X60 2. 贴片圆焊盘 命名规则:SMDC+焊盘直径(D) ...
- grep Or And 操作
grep or 操作符 使用 \| 如果不使用grep命令的任何选项,可以通过使用 '|' 来分割多个pattern,以此实现OR的操作. grep 'pattern1\|pattern2' file ...
- Jarvis OJ - Baby's Crack - Writeup
Jarvis OJ - Baby's Crack - Writeup M4x原创,欢迎转载,转载请表明出处 这是我第一次用爆破的方法做reverse,值得记录一下 题目: 文件下载 分析: 下载后解压 ...
- Tex 一些命令
1. [!htp] 可以使这个内容跟随在前面的内容后面 假如前面是一段文字,后面是一幅图像,不知什么原因跑到其他地方去了.这时加个[!htp]可以使他紧紧跟在后面 ergdsgagdfgdfgfgaf ...