msyql5.7数据类型和运算符

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 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的数据类型比较好,另外两个浮点数进行减法和比较运算时也容易出问题,所以在使用浮点型时需要注意,并尽量避免做浮点数比较!


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


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
9天前
|
SQL 安全 关系型数据库
运算符——“MySQL数据库”
运算符——“MySQL数据库”
|
7月前
|
存储 关系型数据库 MySQL
MySql 数据类型 - 整型
MySql 数据类型 - 整型
44 1
|
8月前
|
关系型数据库 MySQL
MySQL的where表达式中的各种运算符的用法和细节
MySQL的where表达式中的各种运算符的用法和细节
63 0
|
关系型数据库 MySQL
MySQL单行函数之数值函数
ABS(x) 返回x的绝对值
116 0
MySQL单行函数之数值函数
|
SQL 安全 关系型数据库
MySQL运算符,SQL,算术比较逻辑位,优先级,正则表达式,完整详细可收藏
MySQL运算符,SQL,算术比较逻辑位,优先级,正则表达式,完整详细可收藏
302 0
MySQL运算符,SQL,算术比较逻辑位,优先级,正则表达式,完整详细可收藏
|
存储 SQL 安全
第四章《MySQL的数据类型和运算符》
第四章《MySQL的数据类型和运算符》
第四章《MySQL的数据类型和运算符》
|
关系型数据库 MySQL 数据库
MySQL数据库(19):查询中的运算符
MySQL数据库(19):查询中的运算符
101 0
|
SQL 关系型数据库 MySQL
MySQL如何同时自增自减多个字段
MySQL如何同时自增自减多个字段
163 0
MySQL如何同时自增自减多个字段
|
NoSQL 关系型数据库 MySQL
MySQL之like操作符
MySQL之like操作符
148 0
MySQL之like操作符
|
SQL NoSQL 关系型数据库
MySQL操作符之(and、or、in、not)
MySQL操作符之(and、or、in、not)
223 0
MySQL操作符之(and、or、in、not)