数据类型:
存储引擎决定了表的类型,而表内存放的数据也要有不一样的类型,每种数据类型都有本身的宽度,但宽度是可选的
参考:
http://www.runoob.com/mysql/mysql-data-types.html
http://dev.mysql.com/doc/refman/5.7/en/data-type-overview.html
mysql经常使用数据类型概览:
1.数值类型:
整数类型:tinyint smallint int bigint
浮点型:float double decimal
float :在位数比较短的状况下不精准(通常float得精确度也够用了)
double :在位数比较长的状况下不精准
0.000001230123123123
存成:0.000001230000
decimal:(若是用小数,则推荐使用decimal)
精准 内部原理是以字符串形式去存
2.日期类型:
最经常使用:datetime year date time datetime timestamp
3.字符串类型:
char(6) varchar(6)
char(10):简单粗暴,浪费空间,存取速度快,定长;
root存成root000000
varchar:精准,节省空间,存取速度慢,变长;
sql优化:建立表时,定长的类型往前放,变长的日后放
好比性别 好比地址或描述信息
>255个字符,超了就把文件路径存放到数据库中。
好比图片,视频等找一个文件服务器,数据库中只存路径或url。
4.枚举类型与集合类型:
enum('male','female')
set('play','music','read','study')html
1、数值类型:
1.整数类型:
整数类型:tinyint int bigint ...
做用:存储年龄,等级,id,各类号码等mysql
规则:
========================================
tinyint[(m)] [unsigned] [zerofill]
小整数,数据类型用于保存一些范围的整数数值范围:
有符号:
-128 ~ 127
无符号:
0 ~ 255
PS: MySQL中无布尔值,使用tinyint(1)构造。
========================================
int[(m)][unsigned][zerofill]
整数,数据类型用于保存一些范围的整数数值范围:
有符号:
-2147483648 ~ 2147483647
无符号:
0 ~ 4294967295
========================================
bigint[(m)][unsigned][zerofill]
大整数,数据类型用于保存一些范围的整数数值范围:
有符号:
-9223372036854775808 ~ 9223372036854775807
无符号:
0 ~ 18446744073709551615
========================================
验证:
1 mysql> create table t1(x tinyint); # 默认是有符号的 -128,127 2 mysql> insert into t1 values(-129),(128); 3 mysql> select * from t1; # 如果 超出范围 它会自动到 -128 127 4 +------+ 5 | x | 6 +------+ 7 | -128 | 8 | 127 | 9 +------+ 10 11 mysql> create table t2(x tinyint unsigned); # 无符号的 12 mysql> insert into t2 values(-1),(256); 13 mysql> select * from t2; 14 +------+ 15 | x | 16 +------+ 17 | 0 | 18 | 255 | 19 +------+ 20 21 mysql> create table t3(id int(1) unsigned); 22 mysql> desc t3; 23 +-------+-----------------+------+-----+---------+-------+ 24 | Field | Type | Null | Key | Default | Extra | 25 +-------+-----------------+------+-----+---------+-------+ 26 | id | int(1) unsigned | YES | | NULL | | 27 +-------+-----------------+------+-----+---------+-------+ 28 mysql> insert into t3 values(2555555555); 29 mysql> insert into t3 values(213123123213231232131212312); 30 mysql> select * from t3; 31 +------------+ 32 | id | 33 +------------+ 34 | 2555555555 | 35 | 4294967295 | 36 +------------+ 37 int 型 不须要加宽度; int(1) # 1 不是 指的存储宽度 而是 显示宽度 38 存储宽度:tinyint int 存储宽度 都固定死了 你不能修改 39 显示宽度: 指的是 查询时 select * from t4 ; 40 mysql> create table t5(id int(5) unsigned zerofill); 41 mysql> insert into t5 values(1); 42 mysql> select * from t5; 43 +-------+ 44 | id | 45 +-------+ 46 | 00001 | 47 +-------+ 48 mysql> insert into values(12345671222222222222); 49 mysql> select * from t5; # 超过5位了就正常显示了,因此说显示宽度对于int来讲没有意义; 50 +------------+ 51 | id | 52 +------------+ 53 | 00001 | 54 | 4294967295 | 55 +------------+ 56 默认得显示宽度: int(0-4294967295)(-2147483648-2147483647) 57 mysql> create table t6(id int unsigned); # 默认得无符号得宽度 是10 58 mysql> desc t6; 59 +-------+------------------+------+-----+---------+-------+ 60 | Field | Type | Null | Key | Default | Extra | 61 +-------+------------------+------+-----+---------+-------+ 62 | id | int(10) unsigned | YES | | NULL | | 63 +-------+------------------+------+-----+---------+-------+ 64 mysql> create table t7(id int); # 默认得有符号得宽度 是11 65 mysql> desc t7; 66 +-------+---------+------+-----+---------+-------+ 67 | Field | Type | Null | Key | Default | Extra | 68 +-------+---------+------+-----+---------+-------+ 69 | id | int(11) | YES | | NULL | | 70 +-------+---------+------+-----+---------+-------+ 71 1 row in set (0.03 sec)
注: int(3) 表示得是显示宽度,不是存储宽度 ,本身没有必要指定,
其余全部类型得,指定得宽度都表示存储宽度。
2.浮点型:
浮点类型:float double decimal=dec
做用:存储薪资、身高、体重、体质参数等
规则:
======================================
#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[(M,D)] [UNSIGNED] [ZEROFILL]
定义:
双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30
有符号:
-1.7976931348623157E+308 to -2.2250738585072014E-308
2.2250738585072014E-308 to 1.7976931348623157E+308
无符号:
2.2250738585072014E-308 to 1.7976931348623157E+308
精确度:
****随着小数的增多,精度比float要高,但也会变得不许确 ****
======================================
decimal[(m[,d])] [unsigned] [zerofill]
定义:
准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。
精确度:
**** 随着小数的增多,精度始终准确 ****
对于精确数值计算时须要用此类型
decaimal可以存储精确值的缘由在于其内部按照字符串存储。
======================================
验证:
1 mysql> create table t1(x float(256,31)); 2 ERROR 1425 (42000): Too big scale 31 specified for column 'x'. Maximum is 30. 3 mysql> create table t1(x float(256,30)); 4 ERROR 1439 (42000): Display width out of range for column 'x' (max = 255) 5 mysql> create table t1(x float(255,30)); #建表成功 6 Query OK, 0 rows affected (0.02 sec) 7 8 mysql> create table t2(x double(255,30)); #建表成功 9 Query OK, 0 rows affected (0.02 sec) 10 11 mysql> create table t3(x decimal(66,31)); 12 ERROR 1425 (42000): Too big scale 31 specified for column 'x'. Maximum is 30. 13 mysql> create table t3(x decimal(66,30)); 14 ERROR 1426 (42000): Too-big precision 66 specified for 'x'. Maximum is 65. 15 mysql> create table t3(x decimal(65,30)); #建表成功 16 Query OK, 0 rows affected (0.02 sec) 17 18 mysql> show tables; 19 +---------------+ 20 | Tables_in_db1 | 21 +---------------+ 22 | t1 | 23 | t2 | 24 | t3 | 25 +---------------+ 26 rows in set (0.00 sec) 27 28 mysql> insert into t1 values(1.1111111111111111111111111111111); #小数点后31个1 29 Query OK, 1 row affected (0.01 sec) 30 31 mysql> insert into t2 values(1.1111111111111111111111111111111); 32 Query OK, 1 row affected (0.00 sec) 33 34 mysql> insert into t3 values(1.1111111111111111111111111111111); 35 Query OK, 1 row affected, 1 warning (0.01 sec) 36 37 mysql> select * from t1; #随着小数的增多,精度开始不许确 38 +----------------------------------+ 39 | x | 40 +----------------------------------+ 41 | 1.111111164093017600000000000000 | 42 +----------------------------------+ 43 row in set (0.00 sec) 44 45 mysql> select * from t2; #精度比float要准确点,但随着小数的增多,一样变得不许确 46 +----------------------------------+ 47 | x | 48 +----------------------------------+ 49 | 1.111111111111111200000000000000 | 50 +----------------------------------+ 51 row in set (0.00 sec) 52 53 mysql> select * from t3; #精度始终准确,d为30,因而只留了30位小数 54 +----------------------------------+ 55 | x | 56 +----------------------------------+ 57 | 1.111111111111111111111111111111 | 58 +----------------------------------+ 59 row in set (0.00 sec)
注:精度最高得是 decimal double float
2、日期类型:
YEAR DATE TIME DATETIME TIMESTAMP
做用:存储用户注册时间,文章发布时间,员工入职时间,出生时间,过时时间等
规则:
YEAR
YYYY(1901/2155)
DATE
YYYY-MM-DD(1000-01-01/9999-12-31)
TIME
HH:MM:SS('-838:59:59'/'838:59:59')
DATETIME
YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)
TIMESTAMP
YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)
验证:
1 ============year=========== 2 MariaDB [db1]> create table t10(born_year year); #不管year指定何种宽度,最后都默认是year(4) 3 MariaDB [db1]> insert into t10 values 4 -> (1900), 5 -> (1901), 6 -> (2155), 7 -> (2156); 8 MariaDB [db1]> select * from t10; 9 +-----------+ 10 | born_year | 11 +-----------+ 12 | 0000 | 13 | 1901 | 14 | 2155 | 15 | 0000 | 16 +-----------+ 17 18 ============date,time,datetime=========== 19 MariaDB [db1]> create table t11(d date,t time,dt datetime); 20 MariaDB [db1]> desc t11; 21 +-------+----------+------+-----+---------+-------+ 22 | Field | Type | Null | Key | Default | Extra | 23 +-------+----------+------+-----+---------+-------+ 24 | d | date | YES | | NULL | | 25 | t | time | YES | | NULL | | 26 | dt | datetime | YES | | NULL | | 27 +-------+----------+------+-----+---------+-------+ 28 29 MariaDB [db1]> insert into t11 values(now(),now(),now()); 30 MariaDB [db1]> select * from t11; 31 +------------+----------+---------------------+ 32 | d | t | dt | 33 +------------+----------+---------------------+ 34 | 2017-07-25 | 16:26:54 | 2017-07-25 16:26:54 | 35 +------------+----------+---------------------+ 36 37 ============timestamp=========== 38 MariaDB [db1]> create table t12(time timestamp); 39 MariaDB [db1]> insert into t12 values(); 40 MariaDB [db1]> insert into t12 values(null); 41 MariaDB [db1]> select * from t12; 42 +---------------------+ 43 | time | 44 +---------------------+ 45 | 2017-07-25 16:29:17 | 46 | 2017-07-25 16:30:01 | 47 +---------------------+ 48 49 ============注意啦,注意啦,注意啦=========== 50 1. 单独插入时间时,须要以字符串的形式,按照对应的格式插入 51 2. 插入年份时,尽可能使用4位值 52 3. 插入两位年份时,<=69,以20开头,好比50, 结果2050 53 >=70,以19开头,好比71,结果1971 54 MariaDB [db1]> create table t12(y year); 55 MariaDB [db1]> insert into t12 values 56 -> (50), 57 -> (71); 58 MariaDB [db1]> select * from t12; 59 +------+ 60 | y | 61 +------+ 62 | 2050 | 63 | 1971 | 64 +------+ 65 66 ============综合练习=========== 67 MariaDB [db1]> create table student( 68 -> id int, 69 -> name varchar(20), 70 -> born_year year, 71 -> birth date, 72 -> class_time time, 73 -> reg_time datetime); 74 75 MariaDB [db1]> insert into student values 76 -> (1,'alex',"1995","1995-11-11","11:11:11","2017-11-11 11:11:11"), 77 -> (2,'egon',"1997","1997-12-12","12:12:12","2017-12-12 12:12:12"), 78 -> (3,'wsb',"1998","1998-01-01","13:13:13","2017-01-01 13:13:13"); 79 80 MariaDB [db1]> select * from student; 81 +------+------+-----------+------------+------------+---------------------+ 82 | id | name | born_year | birth | class_time | reg_time | 83 +------+------+-----------+------------+------------+---------------------+ 84 | 1 | alex | 1995 | 1995-11-11 | 11:11:11 | 2017-11-11 11:11:11 | 85 | 2 | egon | 1997 | 1997-12-12 | 12:12:12 | 2017-12-12 12:12:12 | 86 | 3 | wsb | 1998 | 1998-01-01 | 13:13:13 | 2017-01-01 13:13:13 | 87 +------+------+-----------+------------+------------+---------------------+
datetime与timestamp的区别
在实际应用的不少场景中,MySQL的这两种日期类型都可以知足咱们的须要,存储精度都为秒,但在某些状况下,会展示出他们各自的优劣。
下面就来总结一下两种日期类型的区别:
1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。
2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。在mysql服务器,
操做系统以及客户端链接都有时区的设置。
3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。所以,TIMESTAMP比DATETIME的空间利用率更高。
4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),
若是不作特殊处理,而且update语句中没有指定该列的更新值,则默认更新为当前时间。
3、字符串类型:
#官网:https://dev.mysql.com/doc/refman/5.7/en/char.html
#注意:char和varchar括号内的参数指的都是字符的长度
1.char类型:定长,简单粗暴,浪费空间,存取速度快
字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)
存储:
存储char类型的值时,会往右填充空格来知足长度
例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储
检索:
在检索或者说查询时,查出的结果会自动删除尾部的空格,除非咱们打开pad_char_to_full_length SQL模式(SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)
2.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:查看字符数
1. char填充空格来知足固定长度,可是在查询时却会很不要脸地删除尾部的空格(装做本身好像没有浪费过空间同样),而后修改sql_mode让其现出原形。
验证:
1 mysql> create table t1(x char(5),y varchar(5)); 2 Query OK, 0 rows affected (0.26 sec) 3 4 #char存5个字符,而varchar存4个字符 5 mysql> insert into t1 values('你瞅啥 ','你瞅啥 '); 6 Query OK, 1 row affected (0.05 sec) 7 8 mysql> SET sql_mode=''; 9 Query OK, 0 rows affected, 1 warning (0.00 sec) 10 11 #在检索时char很不要脸地将本身浪费的2个字符给删掉了,装的好像本身没浪费过空间同样,而varchar很老实,存了多少,就显示多少 12 mysql> select x,char_length(x),y,char_length(y) from t1; 13 +-----------+----------------+------------+----------------+ 14 | x | char_length(x) | y | char_length(y) | 15 +-----------+----------------+------------+----------------+ 16 | 你瞅啥 | 3 | 你瞅啥 | 4 | 17 +-----------+----------------+------------+----------------+ 18 row in set (0.00 sec) 19 20 #略施小计,让char现出原形 21 mysql> SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH'; 22 Query OK, 0 rows affected (0.00 sec) 23 24 #这下子char原形毕露了...... 25 mysql> select x,char_length(x),y,char_length(y) from t1; 26 +-------------+----------------+------------+----------------+ 27 | x | char_length(x) | y | char_length(y) | 28 +-------------+----------------+------------+----------------+ 29 | 你瞅啥 | 5 | 你瞅啥 | 4 | 30 +-------------+----------------+------------+----------------+ 31 row in set (0.00 sec) 32 33 #char类型:3个中文字符+2个空格=11Bytes 34 #varchar类型:3个中文字符+1个空格=10Bytes 35 mysql> select x,length(x),y,length(y) from t1; 36 +-------------+-----------+------------+-----------+ 37 | x | length(x) | y | length(y) | 38 +-------------+-----------+------------+-----------+ 39 | 你瞅啥 | 11 | 你瞅啥 | 10 | 40 +-------------+-----------+------------+-----------+ 41 row in set (0.00 sec)
2. 虽然 CHAR 和 VARCHAR 的存储方式不太相同,可是对于两个字符串的比较,都只比 较其值,忽略 CHAR 值存在的右填充,即便将 SQL _MODE 设置为 PAD_CHAR_TO_FULL_LENGTH 也同样,,但这不适用于like。
验证:
1 Values in CHAR and VARCHAR columns are sorted and compared according to the character set collation assigned to the column. 2 3 All MySQL collations are of type PAD SPACE. This means that all CHAR, VARCHAR, and TEXT values are compared without regard to any trailing spaces. “Comparison” in this context does not include the LIKE pattern-matching operator, for which trailing spaces are significant. For example: 4 5 mysql> CREATE TABLE names (myname CHAR(10)); 6 Query OK, 0 rows affected (0.03 sec) 7 8 mysql> INSERT INTO names VALUES ('Monty'); 9 Query OK, 1 row affected (0.00 sec) 10 11 mysql> SELECT myname = 'Monty', myname = 'Monty ' FROM names; 12 +------------------+--------------------+ 13 | myname = 'Monty' | myname = 'Monty ' | 14 +------------------+--------------------+ 15 | 1 | 1 | 16 +------------------+--------------------+ 17 row in set (0.00 sec) 18 19 mysql> SELECT myname LIKE 'Monty', myname LIKE 'Monty ' FROM names; 20 +---------------------+-----------------------+ 21 | myname LIKE 'Monty' | myname LIKE 'Monty ' | 22 +---------------------+-----------------------+ 23 | 1 | 0 | 24 +---------------------+-----------------------+ 25 row in set (0.00 sec)
3.总结: #经常使用字符串系列: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. 注意: # 注:末尾去空格 只适应等号 不适应 like name char(5) # 简单粗暴 来几个存5个 egon |alex |wxx | name varchar(5) # 先存长度 # 头不是固定1bytes 超过256 就变成了2bytes 65535 但mysql 固定了 #不能超过65535 ,对于大文件 不该该存在数据库, 数据库存 精简得 文件服务器 数据库服务器 4 + egon|4 + alex|3+ wxx char(5) 简单粗暴 存快 取快 缺点 浪费空间 #大部分状况 下 用 char varchar(5) 存慢 取慢 有头得存在 优势 省空间 # 存完以后 不查得话 就能够用varchar 建表得时候: 定长得数据 往前放,变长得数据日后放 一张表,char varchar 不要混着用4、枚举类型与集合类型: 字段的值只能在给定范围中选择,如单选框,多选框 enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female set 多选 在给定的范围内能够选择一个或一个以上的值(爱好1,爱好2,爱好3...) [db1]> create table consumer( -> name varchar(50), -> sex enum('male','female'), -> level enum('vip1','vip2','vip3','vip4','vip5'), #在指定范围内,多选一 -> hobby set('play','music','read','study') #在指定范围内,多选多 -> ); [db1]> insert into consumer values -> ('egon','male','vip5','read,study'), -> ('alex','female','vip1','girl'); [db1]> select * from consumer; +------+--------+-------+------------+ | name | sex | level | hobby | +------+--------+-------+------------+ | egon | male | vip5 | read,study | | alex | female | vip1 | | +------+--------+-------+------------+