目的,要学会建表
需要学会的知识点:列类型
怎么建表?
分析:我们只要把第一行,表头建好了,这张表也就完成了。
至于下面的001,张三,这不是表的概念,而是表中存储的数据。
其实,建表过程,就是一个画表头的过程。
从术语上将,这张表有4个列,建表的过程,就是一个声明字段的过程。
那么建表和列类型又有什么关系呢?
分析:再看上面的表,A4纸是数据的存储空间,而A4纸的大小是固定的
请问:你准备给学号,姓名等留多宽?
(如果姓名留很宽,比如能存20个字,但是一般人的姓名,就三四个字,就会导致浪费空间。
如果留的过窄,导致存不下,就更有问题。)
对应的A4纸空间有限,硬盘空间也有限。
我们建列时,自然想到的是:能够容纳放置的内容,但是又不浪费。
存储同样的数据,不同的列类型,所占据的空间和效率,是不一样的。这就是我们建表前,要学习列类型的意义。
怎样选择合理的列类型,使其能合理的利用空间?
MySQL三大列类型
一、数值型(分为整型与浮点型)
整型:tinyint,smallint,mediumint,int,bigint。
(分别占,1,2,3,4,8个字节)
1、整型以tinyint为例
需要关心的事情有两个
- 1、占据多大空间?
1字节 - 2、能存多大的数?
-128~127
0~255
对于什么时候明确用有符号的,什么时候用无符号的。这就涉及到int系列的声明时的参数了:(M) unsigned zerofill
1.1、unsigned参数
那么需要发问:对于声明tinyint,怎么让他0-255,怎么让他-128 - 127?
当我们建表时,数据默认是有符号的!因此,默认是-128~127的。
在列类型后加unsigned,表示其为无符号类型。
1.2、M参数必须和zerofill配合才有意义(代表0填充)
比如,给学员增加一个学号列
- 学号不能为负
- 学号一般位数相同,即使不同,补到一个固定的长度(比如00013,02138)
不够位数,用0填充
如上图,如令M等于5,则配合zerofill使用,补0,补到5位。
观察snum的类型,可知zerofill则同时必是unsigned类型。
————————————————————————————————
对于上面问题,再次发问怎样选择合理的列类型,使其能合理的利用空间?
比如,
对于同学的年龄,我们用tinyint类型即可有效存储。
对于乌龟的年龄,我们用smallint类型可以有效表示。
对于中国的社保号,用int unsigned(四十多亿)来表示。
————————————————————————————————
2、浮点型
float(M,D) ,decimal(M,D)
M叫“精度” ==》 代表小数的“总位数”
D是“标度” ==》代表小数位(小数点右边的位数)
1、float类型
比如float(6,2)代表的是-9999.99 ~ +9999.99.
另外,可以给float用unsigned参数,让其成为无符号。比如对于奖金,不能为负数,只能为正数。
浮点数,占多大的空间呢?
答:
- 存储范围
float能存10^38. 10^-38。(不必细究存储范围,这是系统定下来的) - 占用空间
如果M小于等于24,那么就占4个字节,否则占8个字节。
2、decimal
decimal,叫定点(把整数部分和小数部分,分开存储的),比float精确。
(decimal属于变长类型)
比如,在银行账户中,我们一般要求精确的存储用户的余额,这里看一下float 与decimal类型的对比。这里我们建立一个account的表,
对于id=1的用户,插入相同的数字1234567.23.看结果
明显能够看到结果,float存储有时会损失精度。像账户这样的敏感字段,建议用decimal类型存储。
(一般银行,用整型存储账户余额,存储的单位是“分”)
浮点数在计算机里表示是比较复杂的。
比如,对于234.87, --- 23.487
那么,小数点左边能达到多少,小数点右边又能达到多少?(可以暂时不用管,比较复杂。)