本文介绍: MySQL的数据类型

1.数据类型分类

2.数值类型

2.1 tinyint类型 

数值越界测试:
mysql>
create table
tt1(num
tinyint
);
Query OK,
0
rows affected (
0.02
sec)
mysql>
insert into
tt1
values
(
1
);
Query OK,
1
row affected (
0.00
sec)
mysql>
insert into
tt1
values
(
128
);

越界插入,报错
ERROR
1264
(
22003
): Out of range value for column
‘num’
at row
1
mysql>
select
*
from
tt1;
+——+
| num |
+——+
|
1      
|
+——+
1
row
in set
(
0.00
sec)
说明
:

MySQL
中,整型可以指定是有符号的和无符号的,默认是有符号的。
可以通过
UNSIGNED
来说明某个字段是无符号的
无符号案例
mysql>
create table
tt2(num
tinyint unsigned
);
mysql>
insert into
tt2
values
(-
1
);

无符号,范围是:
0 – 255
ERROR
1264
(
22003
): Out of range value for column
‘num’
at row
1
mysql>
insert into
tt2
values
(
255
);
Query OK,
1
row affected (
0.02
sec)
mysql>
select
*
from
tt2;
+——+
| num |
+——+
|
255  
|
+——+
1
row
in set
(
0.00
sec)
其他类型自己推导
注意:尽量不使用
unsigned
,对于
int
类型可能存放不下的数据,
int unsigned
同样可能存放不
下,与其如此,还不如设计时,将
int
类型提升为
bigint
类型。

2.2 bit类型

基本语法:
bit
[(M)] :
位字段类型。
M
表示每个值的位数,范围从
1

64
。如果
M
被忽略,默认为
1

举例:  

mysql>
create table
tt4 ( id
int
, a
bit
(
8
));
Query OK,
0
rows affected (
0.01
sec)
mysql>
insert into
tt4
values
(
10
,
10
);
Query OK,
1
row affected (
0.01
sec)
mysql>
select
*
from
tt4; #
发现很怪异的现象,
a
的数据
10
没有出现
+——+——+
| id     | a      |
+——+——+
|
10    
|         |
+——+——+
1
row
in set
(
0.00
sec)

bit使用的注意事项:

bit字段在显示时,是按照ASCII码对应的值显示。

mysql>
insert into
tt4
values
(
65
,
65
);
mysql>
select
*
from
tt4;
+——+——+
| id     | a     |
+——+——+
|
10    
|        |
|
65    
| A     |
+——+——+

如果我们有这样的值,只存放01,这时可以定义bit(1)。这样可以节省空间。

mysql>
create table
tt5(gender
bit
(
1
));
mysql>
insert into
tt5
values
(
0
);
Query OK,
1
row affected (
0.00
sec)
mysql>
insert into
tt5
values
(
1
);
Query OK,
1
row affected (
0.00
sec)
mysql>
insert into
tt5
values
(
2
);

当插入
2
时,已经越界了
ERROR
1406
(
22001
): Data too
long
for column
‘gender’
at row
1

2.3小数类型

2.3.1 float类型

语法:
float
[(m, d)] [
unsigned
] : M
指定显示长度,
d
指定小数位数,占用空间
4
个字节
案例:
小数:
float(4,2)
表示的范围是
-99.99 ~ 99.99

MySQL
在保存值时会进行四舍五入。
mysql>
create table
tt6(id
int
, salary
float
(
4
,
2
));
Query OK,
0
rows affected (
0.01
sec)
mysql>
insert into
tt6
values
(
100
, –
99.99
);
Query OK,
1
row affected (
0.00
sec)
mysql>
insert into
tt6
values
(
101
, –
99.991
); #
多的这一点被拿掉了
Query OK,
1
row affected (
0.00
sec)
mysql>
select
*
from
tt6;
+——+——–+
| id     | salary |
+——+——–+
|
100  
| –
99.99
|
|
101  
| –
99.99
|
+——+——–+
2
rows
in set
(
0.00
sec)
案例:
如果定义的是
float(4,2) unsigned
这时,因为把它指定为无符号的数,范围是
0 ~ 99.99
mysql>
create table
tt7(id
int
, salary
float
(
4
,
2
)
unsigned
);
Query OK,
0
rows affected (
0.01
sec)
mysql>
insert into
tt7
values
(
100
, –
0.1
);
Query OK,
1
row affected,
1
warning (
0.00
sec)
mysql> show warnings;
+———+——+————————————————-+
| Level   |Code| Message                                            |
+———+——+————————————————-+
|Warning|
264
| Out of range value for column
‘salary’
at row
1
|
+———+——+————————————————-+
1
row
in set
(
0.00
sec)
mysql>
insert into
tt7
values
(
100
, –
0
);
Query OK,
1
row affected (
0.00
sec)
mysql>
insert into
tt7
values
(
100
,
99.99
);
Query OK,
1
row affected (
0.00
sec)

2.3.2 decimal

语法:

decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数

decimal(5,2)
表示的范围是
-999.99 ~ 999.99
decimal(5,2) unsigned
表示的范围
0 ~ 999.99
decimal

float
很像,但是有区别
:
float

decimal
表示的精度不一样
mysql>
create table
tt8 ( id
int
, salary
float
(
10
,
8
), salary2
decimal
(
10
,
8
));
mysql>
insert into
tt8
values
(
100
,
23.12345612
,
23.12345612
);
Query OK,
1
row affected (
0.00
sec)
mysql>
select
*
from
tt8;
+——+————-+————-+
| id     | salary      | salary2 |
+——+————-+————-+
|
100
|
23.12345695
|
23.12345612
| #
发现
decimal
的精度更准确,因此如果我们希望某
个数据表示高精度,选择
decimal
+——+————-+————-+
说明:
float
表示的精度大约是
7
位。
decimal
整数最大位数
m

65
。支持小数最大位数
d

30
。如果
d
被省略,默认为
0.
如果
m
被省略,
默认是
10
建议:如果希望小数的精度高,推荐使用
decimal

3.字符串类型

 3.1 char

语法:
char
(L):
固定长度字符串,
L
是可以存储的长度,单位为字符,最大长度值可以为
255

案例(char):

mysql>
create table
tt9(id
int
, name
char
(
2
));
Query OK,
0
rows affected (
0.00
sec)
mysql>
insert into
tt9
values
(
100
,
‘ab’
);
Query OK,
1
row affected (
0.00
sec)
mysql>
insert into
tt9
values
(
101
,

中国

);
Query OK,
1
row affected (
0.00
sec)
mysql>
select
*
from
tt9;
+——+——–+
| id     | name |
+——+——–+
|
100
| ab       |
|
101
|
中国    
|
+——+——–+

说明:
char(2)
表示可以存放两个字符,可以是字母或汉字,但是不能超过
2
个, 最多只能是
255
mysql>
create table
tt10(id
int
,name
char
(
256
));
ERROR
1074
(
42000
): Column length too big for column
‘name’
(max =
255
); use
BLOB
or
TEXT
instead

3.2 varchar

语法: 

varchar
(L):
可变长度字符串,
L
表示字符长度,最大长度
65535
个字节

案例:

mysql>
create table
tt10(id
int
,name
varchar
(
6
));

表示这里可以存放
6
个字符
mysql>
insert into
tt10
values
(
100
,
‘hello’
);
mysql>
insert into
tt10
values
(
100
,

我爱你,中国

);
mysql>
select
*
from
tt10;
+——+——————–+
| id    | name                |
+——+——————–+
|
100
| hello                 |
|
100
|
我爱你,中国   
|
+——+——————–+

说明:
关于
varchar(len),len
到底是多大,这个
len
值,和表的编码密切相关:
varchar
长度可以指定为
0

65535
之间的值,但是有
1 – 3
个字节用于记录数据大小,所以说有效字
节数是
65532
当我们的表的编码是
utf8
时,
varchar(n)
的参数
n
最大值是
65532/3=21844[
因为
utf
中,一个字符占

3
个字节
]
,如果编码是
gbk

varchar(n)
的参数
n
最大是
65532/2=32766
(因为
gbk
中,一个字符
占用
2
字节)。
mysql>
create table
tt11(name
varchar
(
21845
))charset=utf8;

验证了
utf8
确实是不
能超过
21844
ERROR
1118
(
42000
): Row size too large. The maximum row size for the used
table
type,
not
counting BLOBs,
is
65535
. You have to change some columns to
TEXT
or
BLOBs
mysql>
create table
tt11(name
varchar
(
21844
)) charset=utf8;
Query OK,
0
rows affected (
0.01
sec)

3.3 char和varchar的比较

如何选择定长或变长字符串?
如果数据确定长度都一样,就使用定长(
char
),比如:身份证,手机号,
md5
如果数据长度有变化
,
就使用变长
(varchar),
比如:名字,地址,但是你要保证最长的能存的进去。
定长的磁盘空间比较浪费,但是效率高。
变长的磁盘空间比较节省,但是效率低。
定长的意义是,直接开辟好对应的空间
变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。

3.4 日期和时间类型

常用的日期有如下三个:
date
:
日期
‘yyyy

mm

dd’
,占用三字节
datetime
时间日期格式
‘yyyy

mm

dd HH:ii:ss’
表示范围从
1000

9999
,占用八字节
timestamp
:时间戳,从
1970
年开始的
yyyy

mm

dd HH:ii:ss
格式和
datetime
完全一致,占用
四字节
案例:
//
创建表
mysql>
create table
birthday (t1
date
, t2
datetime
, t3
timestamp
);
Query OK,
0
rows affected (
0.01
sec)
//
插入数据:
mysql>
insert into
birthday(t1,t2)
values
(
‘1997-7-1’
,
‘2008-8-8 12:1:1’
);

插入两
种时间
Query OK,
1
row affected (
0.00
sec)
mysql>
select
*
from
birthday;
+————+———————+———————+
| t1            | t2                      | t3                       |
+————+———————+———————+
|
1997

07

01
|
2008

08

08 12
:01:01 |
2017

11

12 18
:28:55 |

添加数据时,时间戳自动补
上当前时间
+————+———————+———————+
//
更新数据:
mysql>
update
birthday
set
t1=
‘2000-1-1’
;
Query OK,
1
row affected (
0.00
sec)
Rows matched:
1
Changed:
1
Warnings:
0
mysql>
select
*
from
birthday;
+————+———————+———————+
| t1            | t2                       | t3                      |
+————+———————+———————+
|
2000

01

01
|
2008

08

08 12
:01:01 |
2017

11

12 18
:32:09 |

更新数据,时间戳会更新
成当前时间
+————+———————+———————+

3.5 enum 和 set

语法:
enum
:枚举,

单选

类型;
enum(‘
选项
1′,’
选项
2′,’
选项
3′,…);
该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“
数字

,因为这些选项的每个选项值依次对应如下数字:
1,2,3,….
最多
65535个;当我们添加枚举值时,也可以添加对应的数字编号。
set
:集合,

多选

类型;
set(‘
选项值
1′,’
选项值
2′,’
选项值
3′, …);
该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“
数字

,因为这些选项的每个选项值依次对应如下数字:
1,2,4,8,16,32

…. 最多64
个。
说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。
案例:
有一个调查表
votes
,需要调查人的喜好, 比如(登山,游泳,篮球,武术)中去选择
(
可以多选
)
, (男,女)[
单选
]
mysql>
create table
votes(
-> username
varchar
(
30
),
-> hobby
set
(

登山

,

游泳

,

篮球

,

武术

),

注意:使用数字标识每个爱好的时候,想想
Linux
权限,采用比特位位置来个
set
中的爱好对应起来
-> gender
enum
(



,



));

注意:使用数字标识的时候,就是正常的数组下标
Query OK,
0
rows affected (
0.02
sec)

插入数据:

insert into
votes
values
(

雷锋

,

登山
,
武术

,



);
insert into
votes
values
(
‘Juse’
,

登山
,
武术

,
2
);
select
*
from
votes
where
gender=
2
;
+———-+—————+——–+
| username | hobby | gender |
+———-+—————+——–+
| Juse     |
登山
,
武术  
|女        |
+———-+—————+——–+

有如下数据,想查找所有喜欢登山的人:

+———–+—————+——–+
| username | hobby | gender |
+———–+—————+——–+
|
雷锋      
|
登山
,
武术
|

|
| Juse     | 登山
,
武术
|

|
| LiLei     | 登山         | 男
|
| LiLei     | 篮球        | 男 |
| HanMeiMei |
游泳
|

|
+———–+—————+——–+

使用如下查询语句:

mysql>
select
*
from
votes
where
hobby=

登山

;
+———-+——–+——–+
| username | hobby | gender |
+———-+——–+——–+
| LiLei     |
登山   
|
男      
|
+———-+——–+——–+

不能查询出所有,爱好为登山的人。
集合查询使用
find_ in_ set
函数:
find_in_set(sub,str_list)
:如果
sub

str_list
中,则返回下标;如果不在,返回
0
str_list
用逗号分隔的字符串。
mysql>
select
find_in_set(
‘a’
,
‘a,b,c’
);
+—————————+
| find_in_set(
‘a’
,
‘a,b,c’
) |
+—————————+
|                               
1
|
+—————————+
mysql>
select
find_in_set(
‘d’
,
‘a,b,c’
);
+—————————+
| find_in_set(
‘d’
,
‘a,b,c’
) |
+—————————+
|                               
0
|
+—————————+

查询爱好登山的人:

mysql>
select
*
from
votes
where
find_in_set(

登山

, hobby);
+———-+—————+——–+
| username | hobby | gender |
+———-+—————+——–+
|
雷锋     
|
登山
,
武术
|

|
| Juse    |
登山
,
武术
|

|
| LiLei    | 登山         |

|
+———-+—————+——–+

原文地址:https://blog.csdn.net/wmh_1234567/article/details/135620067

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_59068.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注