欢迎来到天天文库
浏览记录
ID:37711970
大小:20.99 KB
页数:6页
时间:2019-05-29
《MySQL中的数据类型》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、MySQL中的数据类型MySQL中的数据类型大的方面来分,可以分为:日期和时间、数值,以及字符串。下面就分开来进行总结。日期和时间数据类型MySQL数据类型含义date3字节,日期,格式:2014-09-18time3字节,时间,格式:08:42:30datetime8字节,日期时间,格式:2014-09-1808:42:30timestamp4字节,自动存储记录修改的时间year1字节,年份数值数据类型整型MySQL数据类型含义(有符号)tinyint1字节,范围(-128~127)smallint
2、2字节,范围(-32768~32767)mediumint3字节,范围(-8388608~8388607)int4字节,范围(-2147483648~2147483647)bigint8字节,范围(+-9.22*10的18次方)上面定义的都是有符号的,当然了,也可以加上unsigned关键字,定义成无符号的类型,那么对应的取值范围就要翻翻了,比如:tinyintunsigned的取值范围为0~255。浮点型MySQL数据类型含义float(m,d)4字节,单精度浮点型,m总个数,d小数位double(
3、m,d)8字节,双精度浮点型,m总个数,d小数位decimal(m,d)decimal是存储为字符串的浮点数我在MySQL中建立了一个表,有一列为float(5,3);做了以下试验:1.插入123.45678,最后查询得到的结果为99.999;2.插入123.456,最后查询结果为99.999;3.插入12.34567,最后查询结果为12.346;所以,在使用浮点型的时候,还是要注意陷阱的,要以插入数据库中的实际结果为准。字符串数据类型MySQL数据类型含义char(n)固定长度,最多255个字符va
4、rchar(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个字符的空间,而v
5、archar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。3.超过char和varchar的n设置后,字符串会被截断。4.char的上限为255字节,varchar的上限65535字节,text的上限为65535。5.char在存储的时候会截断尾部的空格,varchar和text不会。6.varchar会使用1-3个字节来存储长度,text不会。其它类型1.enum(“member1″,“member2″,…“member65535″)enum数据类型就是定义了一种枚举,最多包含6553
6、5个不同的成员。当定义了一个enum的列时,该列的值限制为列定义中声明的值。如果列声明包含NULL属性,则NULL将被认为是一个有效值,并且是默认值。如果声明了NOTNULL,则列表的第一个成员是默认值。2.set(“member”,“member2″,…“member64″)set数据类型为指定一组预定义值中的零个或多个值提供了一种方法,这组值最多包括64个成员。值的选择限制为列定义中声明的值。数据类型属性上面大概总结了MySQL中的数据类型,当然了,上面的总结肯定是不全面的,如果要非常全面的总结这
7、些内容,好几篇文章都不够的。下面就再来总结一些常用的属性。1.auto_incrementauto_increment能为新插入的行赋一个唯一的整数标识符。为列赋此属性将为每个新插入的行赋值为上一次插入的ID+1。MySQL要求将auto_increment属性用于作为主键的列。此外,每个表只允许有一个auto_increment列。例如:复制代码代码如下:idsmallintnotnullauto_incrementprimarykey2.binarybinary属性只用于char和varchar值
8、。当为列指定了该属性时,将以区分大小写的方式排序。与之相反,忽略binary属性时,将使用不区分大小写的方式排序。例如:复制代码代码如下:hostnamechar(25)binarynotnull3.defaultdefault属性确保在没有任何值可用的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插入函数或表达式值。此外,此属性无法用于BLOB或TEXT列。如果已经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值
此文档下载收益归作者所有