msyql5.7数据类型和运算符

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


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


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
网络协议 安全 Android开发
软件丨李跳跳们现在该如何跳呢?
前段时间,李跳跳等软件被某大厂发了律师函,之后,好些个跳广告软件都相继发布公众号说明,停止维护软件,并且下架了相关软件,那我们还能跳吗?该怎么跳呢?
1074 0
软件丨李跳跳们现在该如何跳呢?
|
11月前
|
数据可视化 JavaScript 前端开发
Python中交互式Matplotlib图表
【10月更文挑战第20天】Matplotlib 是 Python 中最常用的绘图库之一,但默认生成的图表是静态的。通过结合 mpld3 库,可以轻松创建交互式图表,提升数据可视化效果。本文介绍了如何使用 mpld3 在 Python 中创建交互式散点图、折线图和直方图,并提供了详细的代码示例和安装方法。通过添加插件,可以实现缩放、平移和鼠标悬停显示数据标签等交互功能。希望本文能帮助读者掌握这一强大工具。
|
11月前
|
测试技术 API 持续交付
微服务的版本控制
微服务的版本控制
255 6
|
11月前
|
自然语言处理 关系型数据库 MySQL
MySQL全文搜索
如何使用MySQL全文搜索功能。
174 0
|
算法 程序员 数据库连接
深入探索C++中的RAII原则:资源管理的艺术 (In-Depth Exploration of RAII in C++: The Art of Resource Management)...
深入探索C++中的RAII原则:资源管理的艺术 (In-Depth Exploration of RAII in C++: The Art of Resource Management)...
451 2
|
算法
FM算法介绍
概述 FM (Factorization Machine) 算法可进行回归和二分类预测,它的特点是考虑了特征之间的相互作用,是一种非线性模型,目前FM算法是推荐领域被验证的效果较好的推荐方案之一,在诸多电商、广告、直播厂商的推荐领域有广泛应用。
12098 0
|
搜索推荐
恒生电子联合蚂蚁金服、阿里云,发布新一代技术平台
5月16日,恒生电子联合蚂蚁金服、阿里云发布“新一代分布式服务开发平台”。
3463 0
|
搜索推荐 Windows
直接吹爆,这款关键词查找短视频素材片段!
不再需要手动浏览大量视频,只需要输入您要寻找的关键词,这个就能够为您快速、精准地找到相关的素材片段。
1258 0
|
缓存 JavaScript CDN
webpack打包优化之外部扩展(Externals)配置
webpack打包优化之外部扩展(Externals)配置
696 0
webpack打包优化之外部扩展(Externals)配置