MySQL的数值类型

整数类型

整数类型包含TINYINTSMALLINTMEDIUMINTINTBIGINT等。

存取范围

类型 存储大小 默认显示宽度(个) 范围(有符号) 范围(无符号) 用途
TINYINT(m) 1Byte m:4 -128 - 127 0 - 255 小整数值
SMALLINT(m) 2Byte m:6 -32768 - 32767 0 - 65535 大整数值
MEDIUMINT(m) 3Byte m:9 -8388608 - 8388607 0 - 16777215 大整数值
INT|INTEGER(m) 4Byte m:11 -2147483648 - 2147483647 0 - 4294967295 大整数值
BIGINT(m) 8Byte m:20 -9233372036854775808 - 9223372036854775807 0 - 18446744073709551615 极大整数值

m为其显示宽度,在为字段设置 zerofill约束条件时有效,否则将不会填充满整个显示宽度。

可选约束

unsigned:使用无符号存储。

zerofill:显示宽度不够时使用0进行填充。

显示宽度

使用一切数值类型时,指定其宽度均是为其指定显示宽度,并非存入的限制宽度。

以下示例将演示为TINYINT类型设置设置了显示宽度后,当宽度不够时将以指定字符进行填充。

mysql> CREATE TABLE `test` (->   `id` int(11) NOT NULL AUTO_INCREMENT,->   `a` tinyint(4) unsigned zerofill DEFAULT NULL,->   `b` smallint(6) unsigned DEFAULT NULL,->   `c` mediumint(9) DEFAULT NULL,->   `d` int(11) DEFAULT NULL,->   `e` bigint(20) DEFAULT NULL,->   PRIMARY KEY (`id`)-> ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
Query OK, 0 rows affected, 9 warnings (0.05 sec)
mysql> desc test;
+-------+------------------------------+------+-----+---------+----------------+
| Field | Type                         | Null | Key | Default | Extra          |
+-------+------------------------------+------+-----+---------+----------------+
| id    | int                          | NO   | PRI | NULL    | auto_increment |
| a     | tinyint(4) unsigned zerofill | YES  |     | NULL    |                |
| b     | smallint unsigned            | YES  |     | NULL    |                |
| c     | mediumint                    | YES  |     | NULL    |                |
| d     | int                          | YES  |     | NULL    |                |
| e     | bigint                       | YES  |     | NULL    |                |
+-------+------------------------------+------+-----+---------+----------------+
6 rows in set (0.00 sec)
mysql> INSERT INTO `test` (`a`, `b`, `c`, `d`, `e`) VALUES ('1', '1', '1', '1', '1');
Query OK, 1 row affected (0.00 sec)mysql> INSERT INTO `test` (`id`, `a`, `b`, `c`, `d`, `e`) VALUES ('3', '-1', '-1', '1', '1', '1');
ERROR 1264 (22003): Out of range value for column 'a' at row 1
mysql> INSERT INTO `test` (`a`, `b`, `c`, `d`, `e`) VALUES ('333', '333', '333', '333', '333');
ERROR 1264 (22003): Out of range value for column 'a' at row 1
mysql> select * from test;
+----+------+------+------+------+------+
| id | a    | b    | c    | d    | e    |
+----+------+------+------+------+------+
|  3 | 0001 |    1 |    1 |    1 |    1 |
+----+------+------+------+------+------+
1 row in set (0.00 sec)

范围超出

当范围超出时则不允许存取,抛出异常。

浮点类型

浮点类型包括FLOATDOUBLEDECIMAL

存取范围

类型 存储大小 最大显示宽度(个) 范围(有符号) 范围(无符号) 精确度
FLOAT(m[,d]) 4Bytes m:255,d:30 (-3.402 823 466 E+38,-1.175 494 351 E-38) - 0 0 - (1.175 494 351 E-38,3.402 823 466 E+38) 点七位以内
DOUBLE(m[,d]) 8Bytes m:255,d:30 (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308) - 0 0 - (2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 点十五位以内
DECIMAL(m[,d]) m+2(如果m<d则d+2) m:65,d:30 取决于m,d(m范围(1-65),d范围(0-30)) 取决于m,d(m范围(1-65),d范围(0-30)) 绝对精准

m为其整数部分显示个数,n为其小数部分显示个数。

DECIMAL底层由字符串进行存储,故精度不会出现偏差,也被称为定点类型。

精度问题

mysql> CREATE TABLE `test` (-> `id` INT NOT NULL,-> `a` FLOAT NULL,-> `b` DOUBLE NULL,-> `c` DECIMAL NULL,-> PRIMARY KEY (`id`));
Query OK, 0 rows affected (0.02 sec)
mysql> desc test;
+-------+---------------+------+-----+---------+-------+
| Field | Type          | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+-------+
| id    | int           | NO   | PRI | NULL    |       |
| a     | float         | YES  |     | NULL    |       |
| b     | double        | YES  |     | NULL    |       |
| c     | decimal(10,0) | YES  |     | NULL    |       |
+-------+---------------+------+-----+---------+-------+
4 rows in set (0.01 sec)
INSERT INTO `test` (`id`, `a`, `b`,`c`) VALUES ('1', '3.1415', '3.14159','3.14159');INSERT INTO `test` (`id`, `a`, `b`,`c`) VALUES ('2', '1.1111111111111111', '1.1111111111111111','1.1111111111111111');
mysql> select * from test;
+----+---------+--------------------+------+
| id | a       | b                  | c    |
+----+---------+--------------------+------+
|  1 |  3.1415 |            3.14159 |    3 |
|  2 | 1.11111 | 1.1111111111111112 |    1 |
+----+---------+--------------------+------+
2 rows in set (0.01 sec)
mysql> alter table test modify `c` DECIMAL(65,30) NULL;
Query OK, 2 rows affected (0.13 sec)
Records: 2  Duplicates: 0  Warnings: 0mysql> desc test;
+-------+----------------+------+-----+---------+-------+
| Field | Type           | Null | Key | Default | Extra |
+-------+----------------+------+-----+---------+-------+
| id    | int            | NO   | PRI | NULL    |       |
| a     | float          | YES  |     | NULL    |       |
| b     | double         | YES  |     | NULL    |       |
| c     | decimal(65,30) | YES  |     | NULL    |       |
+-------+----------------+------+-----+---------+-------+
4 rows in set (0.00 sec)mysql> select * from test;
+----+---------+--------------------+----------------------------------+
| id | a       | b                  | c                                |
+----+---------+--------------------+----------------------------------+
|  1 |  3.1415 |            3.14159 | 3.000000000000000000000000000000 |
|  2 | 1.11111 | 1.1111111111111112 | 1.000000000000000000000000000000 |
+----+---------+--------------------+----------------------------------+
2 rows in set (0.00 sec)mysql> INSERT INTO `test` (`id`, `a`, `b`,`c`) VALUES ('3', '1.1111111111111111', '1.1111111111111111','1.1111111111111111');
Query OK, 1 row affected (0.00 sec)mysql> select * from test;
+----+---------+--------------------+----------------------------------+
| id | a       | b                  | c                                |
+----+---------+--------------------+----------------------------------+
|  1 |  3.1415 |            3.14159 | 3.000000000000000000000000000000 |
|  2 | 1.11111 | 1.1111111111111112 | 1.000000000000000000000000000000 |
|  3 | 1.11111 | 1.1111111111111112 | 1.111111111111111100000000000000 |
+----+---------+--------------------+----------------------------------+
3 rows in set (0.00 sec)

位类型

BIT(M)可以用来存放多位二进制数,M范围从1~64,如果不写默认为1位。

注意:对于位字段需要使用函数读取

bin()显示为二进制

hex()显示为十六进制

mysql> create table `test`(num bit);
Query OK, 0 rows affected (0.03 sec)mysql> desc test;
+-------+--------+------+-----+---------+-------+
| Field | Type   | Null | Key | Default | Extra |
+-------+--------+------+-----+---------+-------+
| num   | bit(1) | YES  |     | NULL    |       |
+-------+--------+------+-----+---------+-------+
1 row in set (0.01 sec)mysql> insert into `test`(num) values (1);
Query OK, 1 row affected (0.01 sec)mysql> select * from test;
+------------+
| num        |
+------------+
| 0x01       |
+------------+
1 row in set (0.00 sec)mysql> select bin(num),hex(num) from test;
+----------+----------+
| bin(num) | hex(num) |
+----------+----------+
| 1        | 1        |
+----------+----------+
1 row in set (0.00 sec)mysql> alter table `test` modify num bit(5);
Query OK, 1 row affected (0.10 sec)
Records: 1  Duplicates: 0  Warnings: 0mysql> insert into `test`(num) values (8);
Query OK, 1 row affected (0.00 sec)mysql> select * from test;
+------------+
| num        |
+------------+
| 0x01       |
| 0x08       |
+------------+
2 rows in set (0.00 sec)mysql> select bin(num),hex(num) from test;
+----------+----------+
| bin(num) | hex(num) |
+----------+----------+
| 1        | 1        |
| 1000     | 8        |
+----------+----------+
2 rows in set (0.00 sec)

MySQL的数值类型相关推荐

  1. 数据库开发——MySQL——数据类型——数值类型

    MySQL中定义数据字段的类型对数据库的优化是非常重要的. MySQL支持多种类型,大致可以分为四类:数值.日期/时间.字符串(字符)类型.枚举类型与集合类型. 一.数值类型 MySQL支持所有标准S ...

  2. mysql 数据精确度,MySQL中数值类型的精度探析

    任何数据库里,数值都是最核心的数据类型了,也就只有字符串类型能和它掰掰手腕了.在MySQL中,支持的数值类型也很全面.看看官方说明: MySQL supports all standard SQL n ...

  3. mysql可以存储整数数值的是_MySQL的数值类型

    MySQL的数值类型 整数类型 整数类型包含TINYINT.SMALLINT.MEDIUMINT.INT. BIGINT等. 存取范围类型存储大小默认显示宽度(个)范围(有符号)范围(无符号)用途TI ...

  4. mysql可以存储整数数值的是_MySQL知识树 数值类型 整数

    数值类型 MySQL的数值类型包括整数类型.浮点数类型.定点数类型.位类型. 整数类型 MySQL支持的整数类型有tinyint.smallint.mediumint.int.bigint(范围从小到 ...

  5. mysql 空位补0_MySQL-13(表的创建、数值类型整型、float/decimal、ZEROFILL、BIT(M))

    #    1. 表的创建 基本语法: CREATE TABLE table_name( column1 datatype, column2 datatype, column3 datatype )ch ...

  6. mysql float 转换 int_Mysql 数值类型(int,float,tinyint.......)[转]

    首先说一下mysql的数值类型,MySQL支持所有标准SQL数值数据类型.这些类型包括严格数值数据类型(INTEGER.SMALLINT.DECIMAL和NUMERIC),以及近似数值数据类型(FLO ...

  7. MySQL中述职类型的长度问题

    int(M) M指示最大显示宽度.最大有效显示宽度是255.显示宽度与存储大小或类型包含的值的范围无关 在SQL语句中int代表你要创建字段的类型,int代表整型,11代表字段的长度. 这个11代表显 ...

  8. mysql数据库字段类型大全_mysql数据库字段类型详解

    MySQL支持大量的列类型,它可以被分为3类:数字类型.日期和时间类型以及字符串(字符)类型.本节首先给出可用类型的一个概述,并且总结每个列类型的存储需求,然后提供每个类中的类型性质的更详细的描述. ...

  9. mysql中int(16)_MySQL中int(M)和tinyint(M)数值类型中M值的意义

    在一开始接触MySQL数据库时,对于int(M)及tinyint(M)两者数值类型后面的M值理解是最多能够插入数据库中的值不能大于M: 后来工作后,也是一边学习一边使用,之后的理解是其中的M的意思是插 ...

最新文章

  1. 深入理解ES6 - var-let-const
  2. I/O多路复用之epoll(转)
  3. NHibernate1.02使用MsAccess2000Dialect 提供对 Access 数据库的支持
  4. Java 容器学习之 HashMap
  5. input重置为空后点击出现上次的值_上次玄乎的问题后续来了
  6. 惊艳!Uber 的豪华开源深度学习“全家桶”
  7. 全球AI挑战-场景分类的比赛源码(多模型融合)
  8. “服务器发送了一个意外的数据包。received:3,expected:20“问题的解决方法
  9. Contki 相关链接备忘
  10. 药物临床试验数据递交FDA的规定
  11. 统一认证 java_java统一身份认证系统
  12. SpringBoot:EasyExcel动态字段(不创建对象)多sheet、多文件|压缩包格式导出
  13. 神器vimium:比同级程序员成长更快,我主要靠它
  14. 【word】系统内置样式
  15. 2022制冷与空调设备运行操作考试模拟100题模拟考试平台操作
  16. eclipse pull异常 Pulling 1 respository (The pull operation was canceled)
  17. python解常微分方程龙格库_数值常微分方程-欧拉法与龙格-库塔法
  18. 单片机初学者电路常识
  19. 阿里巴巴收购中天微,中国“芯”指日可待!
  20. html5 we3c,TWDDMM8DRT供应

热门文章

  1. 学生上课睡觉班主任怎么处理_学生上课睡觉,你能正确处理吗?
  2. 《iOS 高级编程》之Tableview进阶指南
  3. 小米空气净化器滤芯RFID解密
  4. 英语语法-- 第二讲、Be动词的形式和用法
  5. java实现md5的验证
  6. 程序员兼职接单的平台列表
  7. [ 物联网篇 ] 14 - 联发科MTK8516 Yocto技巧
  8. 微信支付分支付免押订单租赁订单thinkphp5
  9. InStream和Stream
  10. 洛谷 P4869 albus就是要第一个出场(求一个数在线性基中的排名)