04,列类型与建表语句-1数值型

2018-11-10  本文已影响0人  小碧小琳

目的,要学会建表
需要学会的知识点:列类型

怎么建表?

分析:我们只要把第一行,表头建好了,这张表也就完成了。
至于下面的001,张三,这不是表的概念,而是表中存储的数据。

其实,建表过程,就是一个画表头的过程。
从术语上将,这张表有4个列,建表的过程,就是一个声明字段的过程。

那么建表和列类型又有什么关系呢?
分析:再看上面的表,A4纸是数据的存储空间,而A4纸的大小是固定的
请问:你准备给学号,姓名等留多宽?
(如果姓名留很宽,比如能存20个字,但是一般人的姓名,就三四个字,就会导致浪费空间。
如果留的过窄,导致存不下,就更有问题。)

对应的A4纸空间有限,硬盘空间也有限。
我们建列时,自然想到的是:能够容纳放置的内容,但是又不浪费。

存储同样的数据,不同的列类型,所占据的空间和效率,是不一样的。这就是我们建表前,要学习列类型的意义。

怎样选择合理的列类型,使其能合理的利用空间?

MySQL三大列类型

一、数值型(分为整型与浮点型)

整型:tinyint,smallint,mediumint,int,bigint。
(分别占,1,2,3,4,8个字节)

1、整型以tinyint为例

需要关心的事情有两个

对于什么时候明确用有符号的,什么时候用无符号的。这就涉及到int系列的声明时的参数了:(M) unsigned zerofill

1.1、unsigned参数

那么需要发问:对于声明tinyint,怎么让他0-255,怎么让他-128 - 127?

当我们建表时,数据默认是有符号的!因此,默认是-128~127的。

在列类型后加unsigned,表示其为无符号类型。

1.2、M参数必须和zerofill配合才有意义(代表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参数,让其成为无符号。比如对于奖金,不能为负数,只能为正数。

浮点数,占多大的空间呢?
答:

2、decimal

decimal,叫定点(把整数部分和小数部分,分开存储的),比float精确。
(decimal属于变长类型)

比如,在银行账户中,我们一般要求精确的存储用户的余额,这里看一下float 与decimal类型的对比。这里我们建立一个account的表,

对于id=1的用户,插入相同的数字1234567.23.看结果

明显能够看到结果,float存储有时会损失精度。像账户这样的敏感字段,建议用decimal类型存储。
(一般银行,用整型存储账户余额,存储的单位是“分”)

浮点数在计算机里表示是比较复杂的。

比如,对于234.87, --- 23.487
那么,小数点左边能达到多少,小数点右边又能达到多少?(可以暂时不用管,比较复杂。)

上一篇 下一篇

猜你喜欢

热点阅读