【mysql】mysql中的数据类型知多少?

news2024/11/25 3:03:03

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:MySQL数据库入门,进阶应用实战必备
景天的主页:景天科技苑

文章目录

  • MySQL数据类型
    • 整形
    • DECIMAL
    • float
    • date
    • char
    • varchar
    • concat
    • TINYBLOB
    • 数据库内部方法
    • 枚举和集合

MySQL数据类型

mysql主要包括以下五大类:

整数类型:BIT、BOOL、TINY INT、SMALL INT、MEDIUM INT、 INT、 BIG INT

浮点数类型:FLOAT、DOUBLE、DECIMAL

字符串类型:CHAR、VARCHAR、TINY TEXT、TEXT、MEDIUM TEXT、LONGTEXT、TINY BLOB、BLOB、MEDIUM BLOB、LONG BLOB

日期类型:Date、DateTime、TimeStamp、Time、Year

其他数据类型:BINARY、VARBINARY、ENUM、SET、Geometry、Point、MultiPoint、LineString、MultiLineString、Polygon、GeometryCollection等。

整形

INT                                 整形                         4个字节    有符号范围(-21亿 ~ 21亿左右)  无符号(0~42亿) 大整型值
TINYINT                             一个非常小的整数       1个字节    有符号范围(-128~127) 无符号(0~255) unsigned   小整型值
SMALLINT                            一个小整数
MEDIUMINT                           一个中间大小的整数
INT or INTEGER                      一个正常大小的整数
BIGINT                              一个大的整数


FLOAT                               一个小的 (单精度) 浮点数,不能是无符号的那种
DOUBLE, DOUBLE PRECISION, REAL     一个正常大小 (双精度) 的浮点数,不能使无符号的那种

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

DECIMAL

DECIMAL, NUMERIC decimal无论写入数据中的数据是多少,都不会存在精度丢失问题,这就是我们要引入decimal类型的原因, decimal类型常见于银行系统、互联网金融系统等对小数点后的数字比较敏感的系统中
小数位超过长度时,四舍五入
在这里插入图片描述

整数位超过长度时,报错
在这里插入图片描述

float

float 小数位默认保留5位,double 小数位默认保留16位,decimal 默认保留整数,四舍五入
create table t5(f1 float , f2 double , f3 decimal);
insert into t5 values(1.7777777777777777777777777,1.7777777777777777777777777,1.7777777777777777777777777);
在这里插入图片描述

decimal 默认是10位总长度,不保留小数,保留整数,存在四舍五入
在这里插入图片描述

insert into t4 values(1.7,1.7,1.7); error 整数位最多保留2位 , 小数位最多保留3位;存在四舍五入
可以少,但不能多
在这里插入图片描述
在这里插入图片描述

date

DATE                             一个日期
DATETIME                         一个日期和时间的组合
TIMESTAMP                         一个时间戳
TIME                             一个时间
YEAR                             一个用两位或者4位数字格式表示的年份(默认是4位)

在这里插入图片描述
在这里插入图片描述

date  YYYY-MM-DD 年月日 (节假日,纪念日)
time  HH:MM:SS   时分秒 (体育竞赛,记录时间)
year  YYYY       年份   (历史,酒的年份)
datetime  YYYY-MM-DD HH:MM:SS  年月日 时分秒 (上线时间,下单时间)
create table t1(d date, t time , y year , dt datetime);
insert into t1 values("2020-11-3","9:19:30","2020","2020-11-3 9:19:30");
insert into t1 values(now(),now(),now(),now());

在这里插入图片描述

create table t2(dt datetime , ts timestamp);
insert into t2 values(20201103092530 , 20201103092530);
insert into t2 values(null,null); # 区别 timestamp 自动更新时间(以当前时间戳) datetime没有   MySQL8.0 timestamp插入null也不会更新当前时间,也是空
insert into t2 values(20390102101010 , 20390102101010); error # 超越2038 

可见,timestamp插入null时,插入的真是null
在这里插入图片描述

两者都允许为空,默认值也都为空
在这里插入图片描述

select current_timestamp; 获取当前时间戳,相当于now();
在这里插入图片描述

Timestamp和datetime的异同
相同点:

1.可自动更新和初始化,默认显示格式相同YYYY-MM-dd HH:mm:ss
不同点:
2. timestamp的时间范围是:‘1970-01-01 00:00:01’ UTC to ‘2038-01-19 03:14:07’ UTC ,自动时区转化,实际存储毫秒数,4字节存储
3. datetime的时间范围:‘1000-01-01 00:00:00’ to ‘9999-12-31 23:59:59’ ,不支持时区,8字节存储

char

CHAR 一个固定长度的字符串,存储时总是在其固定长度的空间里右对齐 255个 创建时,指定长度,默认设为1
在这里插入图片描述

超过长度插入不进去
在这里插入图片描述

varchar

VARCHAR 一个可变长度的字符串 0 - 21844个字符,创建时必须指定字符长度,不然创建失败
在这里插入图片描述
在这里插入图片描述

字符串 char(字符长度) varchar(字符长度)
char(11) 定长:固定开辟11个字符长度的空间(手机号,身份证号),开辟空间的速度上来说比较快,从数据结构上来说,需谨慎,可能存在空间浪费. max = 255
varchar(11) 变长:动态最多开辟11个字符长度的空间(评论,广告),开辟空间的速度上来说相对慢,从数据结构上来说,推荐使用,不存在空间浪费 max > 255
text 文本类型:针对于文章,论文,小说. max > varchar

create table t7(c char(11), v varchar(11) , t text);
insert into t7 values(“11111”,“11111”,“11111”);
insert into t7 values(“你好啊你好啊你好啊你好”,“你好啊你好啊你好啊你好”,“你好啊你好啊你好啊你好”);

concat

可以把各个字段拼接在一起
使用语法:
字段与要拼接的描述之间要有逗号,描述文字要加引号
select concat(‘描述文字’,字段,‘描述文字’,字段) from 表;

select concat(c,"<=>",v,"<=>",t) from t7;

在这里插入图片描述

TINYBLOB

TINYBLOB, TINYTEXT 一个BLOB或者TEXT列,最大长度255 (2^8 - 1)个字符
BLOB, TEXT 一个BLOB或者TEXT列,最大长度 65535 (2^16 - 1)个字符
在这里插入图片描述

MEDIUMBLOB, MEDIUMTEXT             一个BLOB或者TEXT列,最大长度 16777215 (2^24 - 1)个字符
LONGBLOB, LONGTEXT                 一个BLOB或者TEXT列,最大长度4294967295 (2^32 - 1) 个字符
ENUM                             一个枚举类型
SET                                 一个集合

show processlist 能看到所有库以及用户正在执行的sql

数据库内部方法

select user() #查看当前用户
select concat() #把各字段拼接起来
select database() #查看当前所用数据库
select now() #查看当前系统时间

在这里插入图片描述

枚举和集合

enum 枚举 : 从列出来的数据当中选一个 (性别)
set 集合 : 从列出来的数据当中选多个 (爱好) 可以去重

create table t8( 
id int , 
name varchar(10) ,
sex enum("男性","兽性","人妖") , 
money float(5,3) , 
hobby set("吃肉","抽烟","喝酒","打麻将","嫖赌")  
);

在这里插入图片描述

正常写法

insert into t8(id,name,sex , money , hobby) values(1,"张保障","兽性",2.6,"打麻将,吃肉,嫖赌");

插入集合的方法:是在一个字符串下,用逗号隔开
在这里插入图片描述

自动去重

insert into t8(id,name,sex , money , hobby) values(1,"张保障","兽性",2.6,"打麻将,吃肉,嫖赌,嫖赌,嫖赌,嫖赌,嫖赌,嫖赌");

在这里插入图片描述

异常写法 : 枚举和集合类型,不能选择除了列出来的数据之外的其他值 error 报错

insert into t8(id,name,sex , money , hobby) values(1,"张保障","人妖12",2.6,"打麻将,吃肉,嫖赌12");

在这里插入图片描述

超过设计的数据类型范围,不让插入
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1632726.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

重学java 26.面向对象 内部类⭐

“别担心&#xff0c;你一定能如愿。” —— 24.4.29 1.什么时候使用内部类&#xff1a; 当一个事物的内部&#xff0c;还有一个部分需要完整的结构去描述&#xff0c;而内部的完整结构又只为外部事物提供服务&#xff0c;那么整个内部的完整结构最好使用内部类 比如&#xff1…

React的useEffect

概念&#xff1a;useEffect是一个React Hook函数&#xff0c;组件渲染之后执行的函数 参数1是一个函数&#xff0c;可以把它叫做副作用函数&#xff0c;在函数内部可以放置要执行的操作参数2是一个数组&#xff08;可选参&#xff09;&#xff0c;在数组里放置依赖项&#x…

旧物焕新生:探索旧物回收小程序的开发与应用

随着社会的快速发展&#xff0c;我们的生活节奏日益加快&#xff0c;物质需求也在不断膨胀。然而&#xff0c;随之而来的却是资源的浪费和环境的压力。在这样的背景下&#xff0c;旧物回收小程序应运而生&#xff0c;为我们提供了一个绿色、环保、便捷的生活新选择。 旧物回收…

Android Kernel源码下载方法

Android Kernel的源码是git管理的&#xff0c;和之前下载的Android源码管理方式不一样&#xff0c;所以下载方式也不一样&#xff0c;直接用git下载就可以了&#xff1b;去网上搜的下载方式五花八门&#xff0c;有很多问题&#xff0c;因为服务器经常无法访问&#xff0c;也一直…

C++笔记:类和对象(二)->继承

上篇内容&#xff1a;C中的重载 继承 继承是什么 在类和对象(一)->封装中说了&#xff0c;封装是将对应的属性和行为封装到一个类中。 那什么是继承呢&#xff1f; 比如一个学校有老师和同学还有领导&#xff0c;那么我们最开始的想法就是每个职位都去封装一个类&#xff0c…

免费通配符证书的申请指南——从申请到启动https

如果您的网站拥有众多二级子域名&#xff0c;那么通配符证书证书是最好的选择。 免费通配符申请流程如下&#xff1a; 1 创建证书服务商账号 首先选择一个提供免费通配符的服务商&#xff0c;打开国产服务商JoySSL官网&#xff0c;创建一个账号&#xff08;注册账号时填写注册…

共享办公室——一种成熟的工作空间解决方案

在固定的框架外寻求灵活性与创新&#xff0c;共享办公室租赁提供了一个动态且富有成本效益的工作环境&#xff0c;适应了快节奏和变化多端的商务需求。 随着创业文化的蓬勃发展和远程工作模式的流行&#xff0c;共享办公室以其独特的优势迅速成为市场上的新秀。它推动了工作…

深入理解 ANR WatchDog 库

ANR WatchDog 是一个用于检测 Android 应用程序中的 ANR (应用程序无响应) 的开源库。本文将深入探讨这个库的工作原理、如何集成到你的应用中&#xff0c;以及它如何帮助你避免用户体验不佳的情况。 ANR WatchDog 库的工作原理 ANR WatchDog 通过一个简单的机制来检测ANR&am…

如何学习网络安全?网络安全零基础入门,看这一篇就够了!

一、概述&#xff1a; 网络安全是指网络系统的硬件、软件及其系统中的数据受到保护&#xff0c;不因偶然的或者恶意的原因而遭受到破坏、更改、泄露&#xff0c;系统连续可靠正常地运行&#xff0c;网络服务不中断。这涉及到保护企业数据、国家基础设施、知识产权以及维护网络…

伪装目标检测论文阅读 SAM大模型之参数微调:Conv LoRA

paper&#xff1a;link code&#xff1a;还没公开 摘要 任意分割模型(SAM)是图像分割的基本框架。虽然它在典型场景中表现出显著的零镜头泛化&#xff0c;但当应用于医学图像和遥感等专门领域时&#xff0c;其优势就会减弱。针对这一局限性&#xff0c;本文提出了一种简单有效…

Linux_Ubuntu18.04安装过程

目录 1. 虚拟机安装2. 虚拟机创建3. Ubuntu x64安装4. 开启重启问题 1. 虚拟机安装 版本&#xff1a;VMware-workstation-full-16.0.exe 下一步 接受 下一步 下一步&#xff0c;注意安装位置。 下一步 下一步 点击安装 等待安装完成。 2. 虚拟机创建 创建新的虚拟机 典型 稍后…

【Java那些事】关于前端收到后端返回的时间格式“2024-04-28T14:48:41“非想要的格式

问题&#xff1a; 后端操作后返回时间格式是"2024-04-28T14:48:41" 而我们想要的是&#xff1a;"2024-04-28 14:48:41", 两个解决方法&#xff1a; 方法一&#xff1a;使用 JsonFormat注解 Data AllArgsConstructor NoArgsConstructor public class Use…

前端高并发的出现场景及解决方法——技能提升——p-limit的使用

最近在写后台管理系统的时候&#xff0c;遇到一个场景&#xff0c;就是打印的页面需要根据传入的多个id&#xff0c;分别去请求详情接口。 比如id有10个&#xff0c;则需要调用10次详情接口获取到数据&#xff0c;最后对所有的数据进行整合后页面渲染。 相信大家或多或少都遇到…

MyBatis 插件介绍及应用

MyBatis 插件介绍及应用 MyBatis 是一个持久层框架&#xff0c;它允许开发者自定义 SQL 语句并将其映射到 Java 对象中。MyBatis 提供了一种灵活的数据库操作方式&#xff0c;但随着项目的复杂度增加&#xff0c;一些通用功能如分页、缓存、事务管理等可能需要重复编写。为了解…

仅1年!!影响因子10+飙升至30+,Springer旗下的潜力优刊,未来可期!

【SciencePub学术】今天小编给大家带来了一本医学类的高分优刊解读&#xff0c;隶属于Springer出版社&#xff0c;JCR1区&#xff0c;中科院1区TOP&#xff0c;创刊时间不长&#xff0c;但影响因子仅1年时间从10直接飙升至30&#xff0c;领域相符的学者可考虑&#xff01; Sign…

PaddlePaddle与OpenMMLab

产品全景_飞桨产品-飞桨PaddlePaddle OpenMMLab算法应用平台

基于LEAP模型的碳排放建模及行业、区域、国家等层面实践应用

线上方式&#xff1a;腾讯会议&#xff1b; 本期共计8次直播课&#xff0c;每节3小时。 5月24日-5月26日 每天&#xff08;8&#xff1a;30-11&#xff1a;30&#xff09;腾讯会议直播 5月31日-6月02日 每天&#xff08;8&#xff1a;30-11&#xff1a;30&#xff09;腾讯会…

Android 多媒体处理中ByteBuffer使用注意事项

Android多媒体处理中ByteBuffer使用注意事项 ByteBuffer 是 Java 中用来操作原始字节数据的类&#xff0c;它提供了一种灵活的方式来读取、写入和操作字节数据。以下是关于 ByteBuffer 的详细说明&#xff1a; 创建 ByteBuffer 你可以通过几种方式来创建 ByteBuffer&#xf…

新接口上线啦,近期我们增加了九个接口

天行数据近期新增了独立计次类接口&#xff1a;食物营养识别、数字识别、条形码识别和会员免费类接口&#xff1a;全国常用电话、健康小妙招、多音字查询、国际时区查询、英语格言等。 1、食物营养识别 通过输入图像资源&#xff0c;识别近两千种常见食物的详细营养成分及100…

转换图片为jpg格式?几个一键转换格式的方法

现在图片格式越来越多&#xff0c;我们经常需要对一些不符合要求的图片进行图片格式转换&#xff0c;否则就会出现打不开或者无法编辑处理的情况&#xff0c;那么对于一些不太懂电脑的小伙伴来说图片转格式会比较复杂&#xff0c;今天小编就来教大家几个简单的改变图片格式的方…