美文网首页
04,列类型与建表语句-1数值型

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

作者: 小碧小琳 | 来源:发表于2018-11-10 21:37 被阅读0次

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

怎么建表?

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

相关文章

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

    目的,要学会建表需要学会的知识点:列类型 怎么建表? 分析:我们只要把第一行,表头建好了,这张表也就完成了。至于下...

  • 3. 整形列的字节与存储范围

    建表:声明列的过程 列:不同的列类型占的空间不一样 选列的原则:够用,又不浪费 列类型 数值型 ①整型 Tinyi...

  • Sql网络学习

    一、认识表: 行(记录) 列(域或者字段)数据类型: 字符型 数值型 日期型 其它类型...

  • 2019-03-27 常用管理SQL语句应用实践(3)

    SQL语句实践 1. DDL语句之管理表 1、建立表 执行student建表语句: 字段类型表得对应列的类型说明:...

  • clickhouse 21.x生产实践优化

    1 时间字段类型 建表时能用数值型或日期时间型表示的字段就不要用字符串,全String 类型在以Hive(hbas...

  • MySQL数据库学习day3

    回顾 字段类型(列类型):数值型,时间日期型和字符串类型 数值型:整型和小数型(浮点型和定点型) 时间日期型:da...

  • 创建数据表

    建表的语法create table 表名(字段1 数据类型 列的特征,字段2 数据类型 列的特征,...) 列的特...

  • 05条件语句与循环语句

    条件语句与循环语句 python 基本数据类型 数值类型,数值运算,序列类型 str list ...

  • ClickHouse——建表优化、参数设置

    一、数据类型 1.1、时间字段类型 建表时能用数值型或日期时间型表示的字段就不要用字符串,全String类型在以H...

  • odps 表数据同步到hive仓库

    1.复制建表语句。做适当修改,把字段类型换成hive支持的类型。启动hive,粘贴建表 分区表例子 CREATET...

网友评论

      本文标题:04,列类型与建表语句-1数值型

      本文链接:https://www.haomeiwen.com/subject/czvoxqtx.html