爱程序网

MYSQL 数据类型

来源: 阅读:

标签:MYSQL/数据库/DBA/整形/字符串/

概述  

当你学习一门数据库语言的时候了解其数据类型尤为的重要,接下来会详细讲解MYSQL支持的每一种数据类型。

所有的测试基于MYSQL 5.6以上版本。

 

目录

数据类型

整形

 

以TINYINT为例,该数据类型是1个字节长度,一个字节=8bit,所以对于无符号存储的数值最大=11111111=2的8次方-1=255,对于有符号就是[-128-127]

 

在整形数值类型中比较常用到的有INT、BIGINT这两种类型,可以指定在数据类型后面加上类型的长度例如INT(3),默认INT数据类型是11位长度,即INT(11)。

CREATE TABLE Tb(ID INT,ID1 INT(3));DESC Tb;

 

 

还可以在定义数据类型的时候使用zerofill,即以0填充不够的空间。语法如下:

ALTER TABLE Tb modify ID1 INT(5) zerofill;INSERT INTO Tb VALUES(1,1);SELECT * FROM Tb;

DESC Tb;

 如果插入的数据长度大于数据类型的长度会不会截断呢?

INSERT INTO Tb VALUES(2,2222222);SELECT * FROM Tb;

如果不是填充字段,插入的数据长度大于字段数据类型的长度则无法插入。

INSERT INTO Tb VALUES(222222222222222,2222222);

整形中的AUTO_INCREMENT属性:一个表中只能存在一个AUTO_INCREMENT列,该列默认是非空,且该列必须定义成PRIMARY KEY 或者UNIQUE建,AUTO_INCREMENT值默认从1开始。

CREATE TABLE Ta(ID INT AUTO_INCREMENT  NOT NULL ,PRIMARY KEY(ID));DESC Ta;

INSERT INTO Ta VALUES();

 

浮点型

浮点数如果不写精度和标度(M,D)【数值总长M位(不包含小数点),小数点后D位】,会按照实际精度值显示,如果存在精度和标度,如果小数点的位数超过D会自动插入四舍五入的结果不会返回错误,如果总长度超过M-D位会插入失败。

 

CREATE TABLE TP(ID1 FLOAT,ID2 FLOAT(4,2),ID3 DOUBLE,ID4 DOUBLE(4,2));INSERT INTO TP VALUES(1.5678,1.5678,1.5678,1.5678);SELECT * FROM TP;

定点类型

定点数如果不写精度和标度会以默认值decimal(10,0)来存储,写精度和标度(M,D)【数值总长M位(不包含小数点),小数点后D位】,会按照实际精度值显示,如果存在精度和标度,如果小数点的位数超过D会自动插入四舍五入的结果并返回错误,如果总长度超过M-D位会插入失败。。

CREATE TABLE TP1(ID1 DECIMAL,ID2 DECIMAL(4,2));INSERT INTO TP1 VALUES(1.5678,1.5678);SELECT * FROM TP1;

插入的过程中会报数据被截断“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 'warning' at line 1”


位类型

位类型主要主要用来存放二进制数,SELECT查询默认显示10进制,可以使用bin()(显示二进制格式)、hex()(显示十六进制格式)函数来进行查询.

CREATE TABLE T(ID BIT(4));INSERT INTO T VALUES(2);SELECT BIN(ID),hex(ID) FROM T;

字符串类型

在mysql5.6中varchar数据类型默认一个中文算一个长度,一个英文也算一个长度。而函数length()默认一个英文算一个长度,一个中文算三个长度。

时间日期类型

默认系统日期:CURRENT_TIMESTAMP,当前日期now(),

时间值类型默认有两个属性,分别是CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP两种,使用情况分别如下:

1. CURRENT_TIMESTAMP 当要向数据库执行insert操作时,如果有字段属性设为 CURRENT_TIMESTAMP,则无论这个字段有木有set值都插入当前系统时间。2. ON UPDATE CURRENT_TIMESTAMP

当当前行有UPDATE操作时无论该操作是否是更新包含‘ON UPDATE CURRENT_TIMESTAMP’数学的字段,该字段的值也会被更改。

 

注意:当数据类型为“timestamp not null”时,当插入的数据为"空、null、字符串"都会转换成“0000-00-00 00:00:00”并返回警告信息,这个数据类型有点特殊定义了not null还是可以传null.

当数据类型为“datetime not null”时,当插入的数据为"空、字符串"都会转换成“0000-00-00 00:00:00”并返回警告信息,当插入的值为null时会出错无法插入。

“0000-00-00 00:00:00”该值在时间类型的字段中比较特殊,它是时间类型字段的默认值,所以它不受时间字段的范围的限制。

总结

 每个版本的数据类型在长度上面可能会存在差异,如果没把握可以使用help 命令查询当前版本的数据类型的信息,使用help 'data types'查询当前版本的所有数据类型,使用help 'char'可以查询char数据类型的信息。

 

 

 

备注:

    作者:pursuer.chen

    博客:http://www.cnblogs.com/chenmh

本站点所有随笔都是原创,欢迎大家转载;但转载时必须注明文章来源,且在文章开头明显处给明链接,否则保留追究责任的权利。

《欢迎交流讨论》

 

关于爱程序网 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助