开发者社区> 李世龙ing> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

msyql5.7数据类型和运算符

简介: mysql数据类型介绍 msyql介绍支持多种数据库,主要有数值类型,日期时间类型和字符串类型。 1.数值数据类型:包括整数类型 tinyint smallint mediumint int bigint 浮点小数据类型float和double,定小数类型desimal。
+关注继续查看

mysql数据类型介绍


msyql介绍支持多种数据库,主要有数值类型,日期时间类型和字符串类型。


1.数值数据类型:包括整数类型 tinyint smallint mediumint int bigint 浮点小数据类型float和double,定小数类型desimal。

2.日期时间类型:包括year time date datetime和timestamp。

3.字符串类型:包括char varchar binary varbinary blog text enum和set等 字符串又分为文本字符串和二进制字符串。


整数类型


数值型数值类型主要用来存储数字,mysql提供了多种数值数据类型,不同的数据类型提供笔值的取值范围,可以存储范围越大,其所需要的存储空间也会越大。mysql主要提供的整数类型有 tinyint smallint mediumint int bigint 整数类型的属性字符段可以添加auto_increment 自增约束条件。


eec1c02d253179e541569d2f6d2e0ae2.png-wh_


从表中可以看到,不同类型整数存储所需的字节数是不同的,占用字节数最近小的是TINYINT类型,占用字节最大的是BIGINT类型,相应的占字节越来越多的类型所能表示的数值范围越大。


82b7740038ba5df5402807bf7e774b46.png-wh_


id字段的数据类型为int(11),注意到后面的数字11,这表示的是该数据类型指定显示宽度,指定能够显示的数值中数字的个数。假设声明一个int类型的字段:

year int(4)

该声明指明,在year字段中的数据一般显示4位数字的宽度。


29a64b3d068c10fb7389836f69b843a1.png-wh_


创建表tmp1,其中字段x y z m n数据类型依次为tinyint smallint mediumint int bigint sql语句如下:

d32fd30c39f76f2282a301eda5e0cb99.png-wh_

可以看到,系统将添加不同默认显示宽度。这些显示宽度保证每一种数据类型可以取到取值范围内的所有值。

列如: tinyint有个符号数和无符号数的取值范围分别为可以取值到取值范围分别-128~127 和 0~255,由于负号占了一个数字位,因此tinyint默认的显示宽度为4.同理其他数据类型的默认显示宽度与其他默认显示宽度与其有符号数的最小值的宽度相同。


浮点数类型和定点数类型


mysql中使用浮点数和定点数来表示小数。浮点数类型有两种:单精度浮点类型和双精度浮点类型。定点类型只有一种:decimal。浮点类型和定点类型都用(M,N)来表示,其中M称为精度,表示总共的位数;N称为标度,是表示小数位数如图所示:


5e84f3e2c254c98793059438fcd35727.png-wh_

decimal类型不同于FLOAT和DOUBLE DECIMAL实际是以串存放的,DECIMAL可能的最大取值范围与DOUBLE一样,但是其有效的取值范围由M和D的取值范围。如果改变M而固定D,则其取值范围将随M的变大而变大。

提示!不论是定点还是浮点类型,如果用户指定的精度超出精度范围,则会四舍五入进行处理。


创建表tmp2 其中x y z 数据类型依次为FLOAT(5,1),DOUBLE(5,1)和DECIMAL(5,1)向表中插入数据5.12 5.15和5.123,sql语句如下:


dd56d8e8d605b6d229d52364903fdd18.png-wh_


可以看到在插入数据时,Mysql给出一个警告信息,使用show warnings;语句查看报警信息:


446903dc11457f63ae442f93c6ba0d58.png-wh_


可以看到FLOAT和DOUBLE在进行四舍五入时没有给出警告,给出z字段数值被截断的报告。

查看结果:


2ddcdbff26ef39a8c90e9b90592d5bbd.png-wh_

FLOAT和DOUBLE在不指定精度时,默认会按照实际的精度,DECIMAL如不指定精度,默认(10,00)。

浮点数相对点数的优点是长度一定的情况下,浮点数能够表示更大的数据范围;它的缺点会引起精度问题。


提示!在mysql中定点数以字符串形式存储,在对精度要求比较高的时候(如货币,科学数据等)使用decimal的数据类型比较好,另外两个浮点数进行减法和比较运算时也容易出问题,所以在使用浮点型时需要注意,并尽量避免做浮点数比较!


总结!数据库很重要我每天都坚持学习一些!


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
第四章《MySQL的数据类型和运算符》
第四章《MySQL的数据类型和运算符》
0 0
MySQL如何同时自增自减多个字段
MySQL如何同时自增自减多个字段
0 0
MySQL 转换函数与运算符
Table 12.14 转换函数(Cast Function) 名称 说明 BINARY 将 string 转换为二进制 string CAST() 将某个值转换为特定类型 CONVERT() 将某个值转换为特定类型 BINARY BINARY 运算符将紧随其后的 string 转换为 二进制字符串。
912 0
【Mysql 学习】算术运算及字符串,数值函数
逻辑运算 not 表示 非逻辑!not null 返回 的仍是nullmysql> select not 1,not 0, not null;+-------+-------+----------+| not 1 | not 0 | not null |+-...
626 0
【Mysql 学习】数值类型转换
数值类型转换问题,当从一个字段从double 变为 float 精度不变,而从float 转变为double 时会发生精度的改变,实验如下:mysql> create table t2 ( id1 float (5,2) default null, id2 do...
341 0
msyql5.7数据类型和运算符
mysql数据类型介绍 msyql介绍支持多种数据库,主要有数值类型,日期时间类型和字符串类型。 1.数值数据类型:包括整数类型 tinyint smallint mediumint int bigint 浮点小数据类型float和double,定小数类型desimal。
703 0
+关注
李世龙ing
架构师 售前工程师 产品经理 运维开发
文章
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载