--------MySQL常用数据类型概括:
#1. 数字:整型:tinyint int bigint小数:float :在位数比较短的情况下不精准double :在位数比较长的情况下不精准decimal:(如果用小数,则用推荐使用decimal)精准-----------内部原理是以字符串形式去存 #2. 字符串:char(10):简单粗暴,浪费空间,存取速度快root存成root000000varchar:精准,节省空间,存取速度慢sql优化:创建表时,定长的类型往前放,变长的往后放比如性别 比如地址或描述信息>255个字符,超了就把文件路径存放到数据库中。比如图片,视频等找一个文件服务器,数据库中只存路径或url。#3. 时间类型:最常用:datetime#4. 枚举类型与集合类型enum 和set
一、整数类型
作用:存储年龄、等级、id、各种号码等
========================================tinyint(n) unsigned zerofill小整数,数据类型用于保存一些范围的整数数值范围:有符号:-128 ~ 127无符号:0~ 255PS: MySQL中无布尔值,使用tinyint(1)构造。========================================int(n) unsigned zerofill整数,数据类型用于保存一些范围的整数数值范围:有符号:-2147483648 ~ 2147483647无符号:0~ 4294967295========================================bigint(n) unsigned zerofill大整数,数据类型用于保存一些范围的整数数值范围:有符号:-9223372036854775808 ~ 9223372036854775807无符号:0~ 18446744073709551615
ps:tinyint int bigint默认都是有符号的,int类型后面的存储是显示宽度,而不是存储宽度。
二、浮点型
作用:存储薪资、身高、体重、体质参数等
-------------------------FLOAT------------------- FLOAT[(M,D)] [UNSIGNED] [ZEROFILL] #参数解释:单精度浮点数(非准确小数值),M是全长,D是小数点后个数。M最大值为255,D最大值为30#有符号:-3.402823466E+38 to -1.175494351E-38,1.175494351E-38 to 3.402823466E+38#无符号:1.175494351E-38 to 3.402823466E+38 #精确度: **** 随着小数的增多,精度变得不准确 ****-------------------------DOUBLE----------------------- DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]#参数解释: 双精度浮点数(非准确小数值),M是全长,D是小数点后个数。M最大值为255,D最大值为30#有符号:-1.7976931348623157E+308 to -2.2250738585072014E-3082.2250738585072014E-308 to 1.7976931348623157E+308#无符号:2.2250738585072014E-308 to 1.7976931348623157E+308#精确度:****随着小数的增多,精度比float要高,但也会变得不准确 ****====================================== --------------------DECIMAL------------------------ decimal[(m[,d])] [unsigned] [zerofill]#参数解释:准确的小数值,M是整数部分总个数(负号不算),D是小数点后个数。 M最大值为65,D最大值为30。#精确度:**** 随着小数的增多,精度始终准确 ****对于精确数值计算时需要用此类型decaimal能够存储精确值的原因在于其内部按照字符串存储。
三、日期类型
作用:存储用户注册时间,文章发布时间,员工入职时间,出生时间,过期时间等
语法:YEARYYYY(1901/2155)DATEYYYY-MM-DD(1000-01-01/9999-12-31)TIMEHH:MM:SS('-838:59:59'/'838:59:59')DATETIMEYYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 )TIMESTAMPYYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)
(1)year
mysql> create table t8(born_year year);#无论year指定何种宽度,最后都默认是year(4) Query OK, 0 rows affected (0.03 sec)#插入失败,超出范围(1901/2155) mysql> insert into t8 values-> (1900),-> (1901),-> (2155),-> (2156); ERROR 1264 (22003): Out of range value for column 'born_year' at row 1mysql> select * from t8; Empty set (0.01 sec)mysql> insert into t8 values-> (1905),-> (2018); Query OK, 2 rows affected (0.00 sec) #插入记录成功 Records: 2 Duplicates: 0 Warnings: 0mysql> select * from t8; +-----------+ | born_year | +-----------+ | 1905 | | 2018 | +-----------+ rows in set (0.00 sec)
(2)data、year、datatime
#创建t9表 mysql> create table t9(d date,t time,dt datetime); Query OK, 0 rows affected (0.06 sec)#查看表的结构 mysql> desc t9; +-------+----------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+----------+------+-----+---------+-------+ | d | date | YES | | NULL | | | t | time | YES | | NULL | | | dt | datetime | YES | | NULL | | +-------+----------+------+-----+---------+-------+ rows in set (0.14 sec)# 调用mysql自带的now()函数,获取当前类型指定的时间 如下结构 mysql> insert into t9 values(now(),now(),now()); Query OK, 1 row affected, 1 warning (0.01 sec)mysql> select * from t9; +------------+----------+---------------------+ | d | t | dt | +------------+----------+---------------------+ | 2018-06-09 | 09:35:20 | 2018-06-09 09:35:20 | +------------+----------+---------------------+ row in set (0.00 sec)
四、字符类型
#官网:https://dev.mysql.com/doc/refman/5.7/en/char.html #注意:char和varchar括号内的参数指的都是字符的长度#char类型:定长,简单粗暴,浪费空间,存取速度快字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)存储:存储char类型的值时,会往右填充空格来满足长度例如:指定长度为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字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)存储:varchar类型存储数据的真实内容,不会用空格填充,如果'ab ',尾部的空格也会被存起来强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字节限制,即已经足够使用)如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)检索:尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容
验证:
验证之前了解两个函数:
length():查看字节数
char_length():查看字符数
***************char填充空格来满足固定长度,但是在查询时却会很不要脸地删除尾部的空格(装作自己好像没有浪费过空间一样),然后修改sql_mode让其现出原形。
# 创建t1表,分别指明字段x为char类型,字段y为varchar类型 mysql> create table t1(x char(5),y varchar(4)); Query OK, 0 rows affected (0.16 sec)# char存放的是5个字符,而varchar存4个字符 mysql> insert into t1 values('你瞅啥 ','你瞅啥 '); Query OK, 1 row affected (0.01 sec)# 在检索时char很不要脸地将自己浪费的2个字符给删掉了,装的好像自己没浪费过空间一样,而varchar很老实,存了多少,就显示多少 mysql> select x,char_length(x),y,char_length(y) from t1; +-----------+----------------+------------+----------------+ | x | char_length(x) | y | char_length(y) | +-----------+----------------+------------+----------------+ | 你瞅啥 | 3 | 你瞅啥 | 4 | +-----------+----------------+------------+----------------+ row in set (0.02 sec)#略施小计,让char现原形mysql> SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH'; Query OK, 0 rows affected (0.00 sec)#查看当前mysql的mode模式 mysql> select @@sql_mode; +-------------------------+ | @@sql_mode | +-------------------------+ | PAD_CHAR_TO_FULL_LENGTH | +-------------------------+ row in set (0.00 sec)#原形毕露了吧。。。。 mysql> select x,char_length(x) y,char_length(y) from t1; +-------------+------+----------------+ | x | y | char_length(y) | +-------------+------+----------------+ | 你瞅啥 | 5 | 4 | +-------------+------+----------------+ row in set (0.00 sec)# 查看字节数 #char类型:3个中文字符+2个空格=11Bytes #varchar类型:3个中文字符+1个空格=10Bytes mysql> select x,length(x),y,length(y) from t1; +-------------+-----------+------------+-----------+ | x | length(x) | y | length(y) | +-------------+-----------+------------+-----------+ | 你瞅啥 | 11 | 你瞅啥 | 10 | +-------------+-----------+------------+-----------+ row in set (0.02 sec)
五、枚举类型和集合
枚举:enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female
集合:set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)
mysql> create table consumer(-> id int,-> name varchar(50),-> sex enum('male','female','other'),-> level enum('vip1','vip2','vip3','vip4'),#在指定范围内,多选一-> fav set('play','music','read','study') #在指定范围内,多选多-> ); Query OK, 0 rows affected (0.03 sec)mysql> insert into consumer values-> (1,'赵云','male','vip2','read,study'),-> (2,'赵云2','other','vip4','play'); Query OK, 2 rows affected (0.00 sec) Records: 2 Duplicates: 0 Warnings: 0mysql> select * from consumer; +------+---------+-------+-------+------------+ | id | name | sex | level | fav | +------+---------+-------+-------+------------+ | 1 | 赵云 | male | vip2 | read,study | | 2 | 赵云2 | other | vip4 | play | +------+---------+-------+-------+------------+ rows in set (0.00 sec)