上面定义的都是有符号的,当然了,也可以加上UNSIGNED关键字,定义成无符号的类型,那么对应的取值范围就要翻翻了,比如:TINYINT UNSIGNED的取值范围为0~255。
例如我们存储人的年龄,就是使用TINYINT UNSIGNED:
CREATE TABBLE tb1(age TINYINT UNSIGNED, );(2).浮点型
我在MySQL中建立了一个表,有一列为FLOAT(5, 3);做了以下试验:
1)插入123.45678,最后查询得到的结果为99.999;
2)插入123.456,最后查询结果为99.999;
3)插入12.34567,最后查询结果为12.346;
所以,在使用浮点型的时候,还是要注意陷阱的,要以插入数据库中的实际结果为准。
例如我们存储工作人员的工资就是使用FLOAT(8,2) UNSIGNED:
CREATE TABBLE tb1(salary FLOAT(8,2) UNSIGNED );二、日期时间类型
1)、MySQL用DATE和YEAR类型存储简单的日期值,使用TIME类型存储时间值。这些类型可以描述为字符串或不带分隔符的整数序列。如果描述为字符串,DATE类型的值应该使用连字号作为分隔符分开,而TIME类型的值应该使用冒号作为分隔符分开。需要注意的是,没有冒号分隔符的TIME类型值,将会被MySQL理解为持续的时间,而不是时间戳。
2)、除了日期和时间数据类型,MySQL还支持DATEYIME和TIMESTAMP这两种混合类型。它们可以把日期和时间作为单个的值进行存储。这两种类型通常用于自动存储包含当前日期和时间的时间戳,并可在需要执行大量数据库事务和需要建立一个调试和审查用途的审计跟踪的应用程序中发挥良好作用。如果我们对TIMESTAMP类型的字段没有明确赋值,或是被赋与了NULL值。MySQL会自动使用系统当前的日期和时间来填充它。
例如我们存储添加用户的出生年月就是使用:
CREATE TABBLE tb1(brithday DATE );三、字符串类型
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在存储的时候会截断尾部的空格,VARCHAR和TEXT不会。
5)、VARCHAR会使用1-3个字节来存储长度,TEXT不会。
6)、CHAR类型用于定长字符串,并且必须在圆括号内用一个大小修饰符来定义。这个大小修饰符的范围从 0-255。比指定长度大的值将被截短,而比指定长度小的值将会用空格作填补。
例如我们存储登录用户的用户名就是使用VARCHAR(20):
CREATE TABLE tb1(username VARCHAR(20) );实例:
CREATE TABLE tb1 (username VARCHAR(20),age TINYINT UNSIGNED,salary FLOAT(8,2) UNSIGNED,brithday DATE );创建数据表tb1和查看数据表结构的结果为:
我们向数据表tb1中插入记录:INSERT tb1 VALUES("Tom",22,5555.55,"1994-10-01");
执行的结果显示为:
四、复合类型
MySQL还支持两种复合数据类型ENUM和SET,它们扩展了SQL规范。虽然这些类型在技术上是字符串类型,但是可以被视为不同的数据类型。一个ENUM类型只允许从一个集合中取得一个值;而SET类型允许从一个集合中取得任意多个值。
(1)ENUM类型
ENUM(“member1″, "member2″, … “member65535″)
ENUM数据类型就是定义了一种枚举,最多包含65535个不同的成员。当定义了一个ENUM的列时,该列的值限制为列定义中声明的值。如果列声明包含NULL属性,则NULL将被认为是一个有效值,并且是默认值。如果声明了NOT NULL,则列表的第一个成员是默认值。
ENUM类型因为只允许在集合中取得一个值,有点类似于单选项。在处理相互排拆的数据时容易让人理解,比如人类的性别。ENUM类型字段可以从集合中取得一个值或使用NULL值,除此之外的输入将会使MySQ在这个字段中插入一个空字符串。另外如果插入值的大小写与集合中值的大小写不匹配,MySQL会自动使用插入值的大小写转换成与集合中大小写一致的值。
ENUM类型在系统内部可以存储为数字,并且从1开始用数字做索引。一个ENUM类型最多可以包含65536个元素,其中一个元素被MySQL保留,用来存储错误现的值是合法输入,除此之外其它任何输入都将失败。这说明通过搜索包含空字符串或对应数字索引为0的行就可以很容易地找到错误记录的位置。
(2)SET类型
SET(“member", "member2″, … “member64″)
SET数据类型为指定一组预定义值中的零个或多个值提供了一种方法,这组值最多包括64个成员。值的选择限制为列定义中声明的值。
SET类型与ENUM类型相似但不相同。SET类型可以从预定义的集合中取得任意数量的值。并且与ENUM类型相同的是任何试图在SET类型字段中插入非预定义的值都会使 MySQL插入一个空字符串。如果插入一个即有合法的元素又有非法的元素的记录,MySQL将会保留合法的元素,除去非法的元素。
一个 SET 类型最多可以包含64项元素。在SET元素中值被存储为一个分离的“位”序列,这些“位”表示与它相对应的元素。“位”是创建有序元素集合的一种简单而有效的方式。并且它还去除了重复的元素,所以SET类型中不可能包含两个相同的元素。希望从SET类型字段中找出非法的记录只需查找包含空字符串或二进制值为0的行。
复合数据类型的例子我们会在以后的博文中使用到,这里不再进行举例。
五、总结
通过对每种数据类型的用途,物理存储,表示范围等有一个概要的了解。这样在面对具体应用时,就可以根据相应的特来来选择合适的数据类型,使得我们能够争取在满足应用的基础上,用较小的存储代价换来较高的数据库性能。
选用数据类型的原则:
1)选择最小的可用的类型;
2)从速度方面考虑,选择固定的列 使用CHAR类型;
3)从节省空间考虑,选择动态的列,使用VARCHAR类型。
高性能数据库设计原则:
第一步:大致确定字段的数据类型,数字,字符串,时间等,比较直观。
第二步:确定特定的类型,比如说 :数字里有TINYINT、SMALLINT、INT、LONGINT等,选择最合适的一个(更小通常更好)
第三步:如有必要,请为字段设置默认值。
当然,索引优化肯定是必不可少的,不过这属于设计表完成之后的优化范围了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。