SQL数据库字段数据类型说明
SQL数据库常⽤字段数据类型说明
这⾥先总结数据类型。MySQL中的数据类型⼤的⽅⾯来分,可以分为:⽇期和时间、数值,以及字符串。下⾯就分开来进⾏总结。⽇期和时间数据类型
MySQL数据类型含义
date3字节,⽇期,格式:2014-09-18
time3字节,时间,格式:08:42:30
datetime8字节,⽇期时间,格式:2014-09-18 08:42:30
timestamp4字节,⾃动存储记录修改的时间
year1字节,年份
数值数据类型
整型
MySQL数据类型含义(有符号)
tinyint1字节,范围(-128~127)
smallint2字节,范围(-32768~32767)
mediumint3字节,范围(-8388608~8388607)
int4字节,范围(-2147483648~2147483647)
bigint8字节,范围(+-9.22*10的18次⽅)
上⾯定义的都是有符号的,当然了,也可以加上unsigned关键字,定义成⽆符号的类型,那么对应的取值范围就要翻翻了,⽐如:tinyint unsigned的取值范围为0~255。
浮点型
MySQL数据类型含义
float(m, d)4字节,单精度浮点型,m总个数,d⼩数位
double(m, d)8字节,双精度浮点型,m总个数,d⼩数位
decimal(m, d)decimal是存储为字符串的浮点数
我在MySQL中建⽴了⼀个表,有⼀列为float(5, 3);做了以下试验:
1.插⼊123.45678,最后查询得到的结果为99.999;
2.插⼊12
3.456,最后查询结果为99.999;
3.插⼊12.34567,最后查询结果为12.346;
所以,在使⽤浮点型的时候,还是要注意陷阱的,要以插⼊数据库中的实际结果为准。
字符串数据类型
MySQL数据类型含义
char(n)固定长度,最多255个字符
varchar(n)可变长度,最多65535个字符
tinytext可变长度,最多255个字符
text可变长度,最多65535个字符
mediumtext可变长度,最多2的24次⽅-1个字符
longtext可变长度,最多2的32次⽅-1个字符
1.char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使⽤了中⽂的时候(UTF8)意味着可以插⼊m个中⽂,但是实际会占⽤m*3个字节。
2.同时char和varchar最⼤的区别就在于char不管实际value都会占⽤n个字符的空间,⽽varchar只会占⽤实际字符应该占⽤的空间+1,并且实际空间+1<=n。
3.超过char和varchar的n设置后,字符串会被截断。
4.char的上限为255字节,varchar的上限65535字节,text的上限为65535。
5.char在存储的时候会截断尾部的空格,varchar和text不会。
6.varchar会使⽤1-3个字节来存储长度,text不会。
其它类型
enum数据类型就是定义了⼀种枚举,最多包含65535个不同的成员。当定义了⼀个enum的列时,该列的值限制为列定义中声明的值。如果列声明包含NULL属性,则NULL将被认为是⼀个有效值,并且是默认值。如果声明了NOT NULL,则列表的第⼀个成员是默认值。
2.set(“member”, “member2″, … “member64″)
set数据类型为指定⼀组预定义值中的零个或多个值提供了⼀种⽅法,这组值最多包括64个成员。值的选择限制为列定义中声明的值。
数据类型属性
上⾯⼤概总结了MySQL中的数据类型,当然了,上⾯的总结肯定是不全⾯的,如果要⾮常全⾯的总结这些内容,好⼏篇⽂章都不够的。下⾯就再来总结⼀些常⽤的属性。
1.auto_increment
auto_increment能为新插⼊的⾏赋⼀个唯⼀的整数标识符。为列赋此属性将为每个新插⼊的⾏赋值为上⼀次插⼊的ID+1。
MySQL要求将auto_increment属性⽤于作为主键的列。此外,每个表只允许有⼀个auto_increment列。例如:
代码如下:
id smallint not null auto_increment primary key
2.binary
binary属性只⽤于char和varchar值。当为列指定了该属性时,将以区分⼤⼩写的⽅式排序。与之相反,忽略binary属性时,将使⽤不区分⼤⼩写的⽅式排序。例如:
代码如下:
hostname char(25) binary not null
3.default
default属性确保在没有任何值可⽤的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插⼊函数或表达式值。此外,此属性⽆法⽤于BLOB或TEXT列。如果已经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值将依赖于字段的数据类型。例如:
代码如下:
subscribed enum('0', '1') not null default '0'
4.index
如果所有其他因素都相同,要加速数据库查询,使⽤索引通常是最重要的⼀个步骤。索引⼀个列会为该列创建⼀个有序的键数组,每个键指向其相应的表⾏。以后针对输⼊条件可以搜索这个有序的键数组,与搜索整个未索引的表相⽐,这将在性能⽅⾯得到极⼤的提升。
代码如下:
create table employees
(
id varchar(9) not null,
firstname varchar(15) not null,
lastname varchar(25) not null,
email varchar(45) not null,
phone varchar(10) not null,
index lastname(lastname),
primary key(id)
);
我们也可以利⽤MySQL的create index命令在创建表之后增加索引:
代码如下:
create index lastname on employees (lastname(7));
这⼀次只索引了名字的前7个字符,因为可能不需要其它字母来区分不同的名字。因为使⽤较⼩的索引时性能更好,所以应当在实践中尽量使⽤⼩的索引。
< null
如果将⼀个列定义为not null,将不允许向该列插⼊null值。建议在重要情况下始终使⽤not null属性,因为它提供了⼀个基本验证,确保已经向查询传递了所有必要的值。
6.null
为列指定null属性时,该列可以保持为空,⽽不论⾏中其它列是否已经被填充。记住,null精确的说法是“⽆”,⽽不是空字符串或0。
7.primary key
primary key属性⽤于确保指定⾏的唯⼀性。指定为主键的列中,值不能重复,也不能为空。为指定为主键的列赋予auto_increment属性是很常见的,因为此列不必与⾏数据有任何关系,⽽只是作为⼀个唯⼀标识符。主键⼜分为以下两种:
(1)单字段主键
如果输⼊到数据库中的每⾏都已经有不可修改的唯⼀标识符,⼀般会使⽤单字段主键。注意,此主键⼀旦设置就不能再修改。
(2)多字段主键
varchar2最大长度
如果记录中任何⼀个字段都不可能保证唯⼀性,就可以使⽤多字段主键。这时,多个字段联合起来确保唯⼀性。如果出现这种情况,指定⼀个auto_increment整数作为主键是更好的办法。
8.unique
被赋予unique属性的列将确保所有值都有不同的值,只是null值可以重复。⼀般会指定⼀个列为unique,以确保该列的所有值都不同。例如:
代码如下:
email varchar(45) unique
zerofill属性可⽤于任何数值类型,⽤0填充所有剩余字段空间。例如,⽆符号int的默认宽度是10;因此,当“零填充”的int值为4时,将表⽰它为0000000004。例如:
代码如下:
orderid int unsigned zerofill not null

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。