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

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

怎么建表?

分析:我们只要把第一行,表头建好了,这张表也就完成了。
至于下面的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
那么,小数点左边能达到多少,小数点右边又能达到多少?(可以暂时不用管,比较复杂。)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容