MySQL的数值类型

整数类型

整数类型包含TINYINT、SMALLINT、MEDIUMINT、INT、 BIGINT等。

存取范围类型存储大小默认显示宽度(个)范围(有符号)范围(无符号)用途TINYINT(m)1Bytem:4-128 - 1270 - 255小整数值

SMALLINT(m)2Bytem:6-32768 - 327670 - 65535大整数值

MEDIUMINT(m)3Bytem:9-8388608 - 83886070 - 16777215大整数值

INT\INTEGER(m)4Bytem:11-2147483648 - 21474836470 - 4294967295大整数值

BIGINT(m)8Bytem:20-9233372036854775808 - 92233720368547758070 - 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 1mysql> select * from test;

+----+------+------+------+------+------+

| id | a | b | c | d | e |

+----+------+------+------+------+------+

| 3 | 0001 | 1 | 1 | 1 | 1 |

+----+------+------+------+------+------+

1 row in set (0.00 sec)

范围超出

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

浮点类型

浮点类型包括FLOAT、DOUBLE、DECIMAL。

存取范围类型存储大小最大显示宽度(个)范围(有符号)范围(无符号)精确度FLOAT(m[,d])4Bytesm:255,d:30(-3.402 823 466 E+38,-1.175 494 351 E-38) - 00 - (1.175 494 351 E-38,3.402 823 466 E+38)点七位以内

DOUBLE(m[,d])8Bytesm:255,d:30(-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308) - 00 - (2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)点十五位以内

DECIMAL(m[,d])m+2(如果m

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: 0

mysql> 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: 0

mysql> 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可以存储整数数值的是_MySQL的数值类型相关推荐

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

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

  2. mysql创建数据库整数五种整形_mysql 整型数据类型

    mysql支持标准SQL中的数值类型,支持标准的整型类型INTEGER和SMALLINT,并且扩展了标准类型,也支持TINYINT.MEDIUMINT和BIGINT.下面的表格中是每个类型的存储范围. ...

  3. mysql 中存储引擎是什么意思_mysql常用的存储引擎是什么

    mysql常用的存储引擎是什么 发布时间:2020-12-02 09:35:04 来源:亿速云 阅读:62 作者:小新 这篇文章将为大家详细讲解有关mysql常用的存储引擎是什么,小编觉得挺实用的,因 ...

  4. mysql timestamp 默认值是什么#039;_MYSQL中TIMESTAMP类型的默认值

    MYSQL中TIMESTAMP类型可以设定默认值,就像其他类型一样.1.自动UPDATE 和INSERT 到当前的时间:表:/*DDL Information For - test.t1*/----- ...

  5. mysql可以存储标点么_MySQL命名、设计及使用规范--------来自标点符的《MySQL命名、设计及使用规范》...

    数据库环境 dev:开发环境,开发可读写,可修改表结构.开发人员可以修改表结构,可以随意修改其中的数据但是需要保证不影响其他开发同事. qa:测试环境,开发可读写,开发人员可以通过工具修改表结构. s ...

  6. mysql数据库数字类型_Mysql 数据库数值类型详解

    MySQL 支持所有标准SQL 中的数值类型,其中包括严格数值类型(INTEGER.SMALLINT.DECIMAL 和NUMERIC),以及近似数值数据类型(FLOAT.REAL 和DOUBLE P ...

  7. mysql的存储引擎详解_Mysql存储引擎详解

    存储引擎的介绍 关系型数据库表是用来存储和组织信息的数据结构,可以将表理解为由行和列组成的表格. 由于表的类型不同,我们在实际开发过程中,就有可能需要各种各样的表,不同的表就意味着存储不同类型的数据, ...

  8. mysql修改存储引擎报错_MySQL查看修改存储引擎总结

    本文总结了MySQL下查看.修改存储引擎的一些方法.测试.验证环境为MySQL 5.6 ,如有差异,请以实际版本为准 1:查看MySQL的存储引擎信息 1.1 使用show engines命令. Su ...

  9. mysql聚簇索引存储结构_MySQL聚簇索引的实际应用于结构描述

    以下的文章主要介绍的是高性能的MySQL索引策略之MySQL聚簇索引(Clustered Indexes),我们大家都知道MySQL聚簇索引(Clustered Indexes),在实际应用中比例还是 ...

最新文章

  1. 2022-2028年中国数码相机行业投资分析及前景预测报告
  2. HDU 6091 - Rikka with Match | 2017 Multi-University Training Contest 5
  3. jbpm_工作流框架笔记
  4. word2vec, LSTM Speech Recognition实战, 图数据库
  5. java split 坑_java String split 踩坑记
  6. 支持javascript的博客汇总
  7. 大数据之-Hadoop伪分布式_配置历史服务器---大数据之hadoop工作笔记0027
  8. 更改select里面的值
  9. win7电脑无线网卡服务器,win7如何安装无线网卡驱动|win7安装无线网卡驱动的方法...
  10. Apache配置虚拟主机
  11. 《HelloGitHub》第 71 期
  12. SQL解决过去M天内连续N天符合某条件问题
  13. React+Antd兼容ie浏览器,360安全浏览器兼容模式
  14. 推荐一款有趣的APP-种子习惯
  15. h5 移动开发 html页面跳转,iosh5混合开发项目仿app页面跳转优化
  16. Python爬虫:爬取某鱼颜值主播图片并保存到本地升级版!
  17. 天猫送给这些商家“首页置顶”丨 24张PPT详解天猫消费电子2018年商家策略
  18. 贝叶斯分析:抛硬币的概率真的是1/2吗
  19. 什么浏览器有html控制台,HTML标记突破出现在浏览器br,也可作为br,开发者控制台...
  20. 我在赶集网的两个月(完整版)

热门文章

  1. wxWidgets:wxRibbonPanel类用法
  2. boost::units模块实现测试显式和隐式单位转换
  3. boost::gil::detail::is_channel_integral用法的测试程序
  4. GDCM:DICOM文件的覆盖测试程序
  5. ITK:创建样本测量列表
  6. VTK:Qt之EventQtSlotConnect
  7. VTK:图片之BorderPixelSize
  8. Qt Creator添加Qt Designer插件
  9. QT的QHttpMultiPart类的使用
  10. 经典C语言程序100例之四四