【Mysql】 数据类型
文章目录
- 【Mysql】 数据类型
- 数据类型分类
- 数值类型
- 1. tinyint类型
- 2. bit类型
- 3. 小数类型
- 字符串类型
- 1.char
- 2.varchar
- 3. 日期和时间类型
- 4. enum 和 set
【Mysql】 数据类型
mysql中数据类型的作用:
- 约束操作者的行为
- 更清晰的代码逻辑
- 不同的功用 – 例如,年龄使用数字,生日,姓名等消息使用子符串
更为重要的是类型约束,即如果操作者不按数据类型进行数据插入时,该条sql数据会被直接拒绝
数据类型分类
数值类型
1. tinyint类型
tinyint类型使用演示
如下:
我们知道,有符号的tinyint的存储范围就是 -128 ~ 127,当我们想插入数据128时,是直接报错的,而不像c/c++ ,会发生截断;
说明:
-
在MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的。
-
可以通过UNSIGNED来说明某个字段是无符号的
而如果想将tinyint 设置为无符号的,只需要在设置列字段时,在类型加上unsigned即可,变成无符号之后,tinyint的存储范围就变成了0 ~ 255;
id tinyint unsigned
2. bit类型
基本语法:
bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1。
而我们通过类型表中,是没有我们c++中的bool类型的,而实际上,bit(1)就可以表示mysql中的bool类型,即bit(1) 类型的变量的值不是0就是1;
但mysql中的bit类型神奇之处远不止如此
bit使用案例
我们先创建一个张表,然后插入几个数据
插入数据和查看表中显示:
神奇的事情,我们会发现使用bit()存储的变量是使用acill值的形式显示的,10就是我们的’ \n’
3. 小数类型
float 使用
float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节
例:
我们先创建一个工资表出来:
float(4,2) 即表示显示长度为4,小数位数为2为,数值范围 :-99.99 ~ 99.99
而后插入几条数据:
我们会发现mysql保存数据时,对于99.994,99.995这些超出数据范围的数据会先对其进行4舍5入,而后再判断是否合法;
说明:
- float类型,mysql在保存值时会进行4舍5入
- float类型使用unsigned时,并不会将tinyint类型一样数值类型会变大;
- 例:float(4,2) 数值范围为: 0 ~ 99.99
decimal使用
decimal(m, d) [unsigned] : 定点数m指定长度,d表示小数点的位数
说明:
- decimal使用起来和float是没什么区别的,但dicimal的精度比float要高很多
- 当小数位超过7位时,建议都使用decimal类型;
例:
我们会发现,当插入的数据大于8位小数时,使用float存储是不够精准的
说明:
- decimal整数最大位数m为65。支持小数最大位数d是30。如果d被省略,默认为0.如果m被省略,默认是10。 即decimal默认情况下decimal(10,0)
字符串类型
1.char
语法:
char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255
例子:
我们先创建一张表,类型为char(6)
接着我们插入几个数据进去:
我们印象当中utf8中,一个中文大概是3字节大小,而我们指定的大小不是为6吗
使用length函数(求字符串的字节数)查看一下字符串长度
也就是说,mysql中的一个字符,并不是我们c/c++的字符类型(char),mysql中的字符即可以是中文也可以是英文;所以我们char(6) ,表示的字符长度为6,而是字节大小为6;
2.varchar
语法:
varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节
- 注: 最大长度为65535个字节,以字节为单位;而char最大长度是以字符为单位的
而varchar实际使用上也是和char是一样的,但只是存储上细节不一样:
-
char() 是直接将指定长度的空间开辟出来
-
而varchar()是使用多少数据空间就开多少空间
-
例:char(6) ,varchar(6) ,插入数据 “中国”,char存储是使用的6个字符大小的空间(早就开好了),varchar存储是2个字符大小
-
比喻:char就好像c语言中的静态数组,一开始数组大小就固定了,就开好了固定大小的空间,而varchar就像动态数组,用多少开多少;
例:
创建与上面相同的表结构
查看所插入的数据
3. 日期和时间类型
-
date :日期 ‘yyyy-mm-dd’ ,占用三字节
-
datetime 时间日期格式 ‘yyyy-mm-dd HH:ii:ss’ 表示范围从 1000 到 9999 ,占用八字节
-
timestamp :时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节
例子:
创建一个生日表:
插入数据:
insert into birthday(t1,t2) values('1997-7-1','2008-8-8 12:1:1');
如下:
我们会发现我们没有插入t3 ,而t3默认是以当前的时间戳更新的;
查看一下具体表结构
下面我们将表数据进行修改一下,再查看一下表:
我们会发现当我们对表数据进行更新时,t3也会更新为最新的修改时间,这实际上是timestamp类型在作怪
说明:
- timestamp类型,插入数据时如果没有指定,数值就为当前的时间戳,更新数据时也没有指定的话,数值也会被更新为修改时的时间戳
- 或许有些数据库的版本的timestamp类型,默认是没有上面这些行为,就像我的数据库版本,书写timestamp类型,需要自己添加字段 not null default current_timestamp on update current_timestamp; 详情可以看看这篇文章 timestamp
4. enum 和 set
enum类型使用
语法:
enum:枚举,“单选”类型;enum('选项1','选项2','选项3',...);
例:
再往里面插入数据:
我们会发现,使用数字1也可以表示enum当中的第一个选项;
说明:
- 该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是**“数字”**,因为这些选项的每个选项值依次对应如下数字:1,2,3,…最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。
set类型使用
set:集合,“多选”类型;
set('选项值1','选项值2','选项值3', ...);
说明:
- 该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,… 最多64个
例:
有一个调查表votes,需要调查人的喜好, 比如(登山,游泳,篮球,武术)中去选择(可以多选),(男,女)[单选]
mysql> create table votes(
-> username varchar(30),
-> hobby set('登山','游泳','篮球','武术'), --注意:使用数字标识每个爱好的时候,想想Linux权限,采用比特位位置来个set中的爱好对应起来
-> gender enum('男','女')); --注意:使用数字标识的时候,就是正常的数组下标
如下:
接下来我们插入俩个数据:
insert into votes values('Juse','登山,篮球',2);
insert into votes values('小王',3,'男');
即实际上set中的数据也是数子存储存储的,3代表1,2俩个爱好的合成;
小结:
- enum类型可以使用于单项选择,set使用于多项选择;
如下:
[外链图片转存中…(img-M01iTbhF-1684973250081)]
接下来我们插入俩个数据:
insert into votes values('Juse','登山,篮球',2);
insert into votes values('小王',3,'男');
[外链图片转存中…(img-jlr5afO4-1684973250081)]
即实际上set中的数据也是数子存储存储的,3代表1,2俩个爱好的合成;
小结:
- enum类型可以使用于单项选择,set使用于多项选择;
- 虽然说enum和set都可以直接使用数字对数据进行表示,但是我们插入和查询数据时不推荐使用数字表示,可读性低;
相关文章:

【Mysql】 数据类型
文章目录 【Mysql】 数据类型数据类型分类数值类型1. tinyint类型2. bit类型3. 小数类型 字符串类型1.char2.varchar3. 日期和时间类型4. enum 和 set 【Mysql】 数据类型 mysql中数据类型的作用: 约束操作者的行为更清晰的代码逻辑不同的功用 – 例如,…...

mysql中如何使用乐观锁和悲观锁
MySQL中可以使用SELECT ... FOR UPDATE语句来实现悲观锁。这个语句会在查询时锁定被查询的行,在事务结束前都不会释放锁。 例如,我们可以使用以下的 SQL 语句来锁定一个特定的行: BEGIN; SELECT * FROM table WHERE id 1 FOR UPDATE; ... C…...

Logstash技术栈总结
Logstash 是一个可以传输和处理你的日志、事务或其他数据的功能强大的工具,可与各种部署集成。 它提供了大量插件,可帮助你解析,丰富,转换和缓冲来自各种来源的数据。 工作原理 Logstash 事件处理有三个阶段:inputs …...

解决:在单项目组件里面引入 base.scss/ base.less 等的外部文件不成功的问题
1、问题展示: 其一、问题描述: 在单文件组件里面使用封装在 base.scss 或 base.less 里面的样式用法一直不成功; 其二、代码: // 虽然已经标明了用的是 scss 的语法,但是页面调用 .scss 里的 style 样式还是不成功&a…...

论文分享 | WSBERT:Weighted Sampling for Masked Language Modeling
本次分享阿里巴巴达摩院语音实验室、新南威尔士大学与香港科技大学(广州)等在ICASSP2023会议发表的论文《Weighted Sampling for Masked Language Modeling》。该论文主要提出了两种简单有效的加权采样策略,来缓解掩码语言模型(ML…...

java 在线音乐网站系统Myeclipse开发mysql数据库struts2结构java编程计算机网页项目
一、源码特点 java 在线音乐网站系统 是一套完善的web设计系统,对理解JSP java编程开发语言有帮助struts2开发技术,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发,数据库为Mys…...

软件测试基础教程学习1
文章目录 软件测试概述1.1 什么是软件测试1.2 软件测试的目的1.3 对软件测试的理解1.4 软件测试的原则1.5 测试人员的职责1.6 测试人员的素质要求 软件测试概述 1.1 什么是软件测试 1)软件测试要发现软件的错误。 2)软件测试最终要以软件满足用户需求为…...

浅谈一下@Async和SpringSecurityContext可能会遇到的问题和解决方案
Async和SpringSecurityContext 场景回溯 在执行一个用时较长的批量插入业务的时候,我尝试使用Async异步对业务进行优化,但是却给我报了空指针的错误,定位之后发现 此处我是基于SpringSecurity来获取用户的 是currentUserService获取到的当前登陆用户为空导致的,但是当前确实是…...

VUE常见面试题
1.为什么要使用Vue? 答:Vue是一款优秀的前端框架,它可以帮助我们快速构建高效、可复用、易维护的Web应用程序,并提供了丰富的API和生态系统。 2. Vue有哪些生命周期钩子函数? 答:Vue有8个生命周期钩子函…...

字符串匹配算法--KMP算法--BM算法
该算法解决的是字符串匹配问题,即查看字符串中是否含有完整的匹配字符串。如在java的string的contains方法匹配问题最简单的就是暴力破解了。在java的contains也是这么实现的,效率是低一点的。如果想要更快的速度可以自己写KMP算法。 代码实现体验 Knut…...

swagger的简单介绍
目录 swagger是什么? swagger有什么用? Swagger包含的工具集: swagger的使用步骤: swagger的相关注解: Docket的源码 了解swagger的作用和概念了解前后端分离在SpringBoot中集成Swagger swagger是什么?…...

HNU-电路与电子学-小班3
第三次讨论 1 、直接用晶体管而不是逻辑门实现异或门,并解释这个电路是如何工作的。 (6个 MOS 管构成) 2 、通信双方约定采用 7 位海明码进行数据传输。请为发送方设计海明码校验位 生成电路,采用功能块和逻辑门为接收方设计海…...

[机缘参悟-98] :层次不同、维度不同、视角不同、结论不同
目录 全局VS具备, 总体V部分 认知的六个认知层次: 认知的六个立体化维度: 0、维空间,点思维 1、一维空间,直线思维 2、二维空间,平面思维 3、三维空间:立体思维。 4、四维空间ÿ…...

chatgpt-web发布之docker打包流程
docker打包流程 1、使用docker前置准备: 电脑下载docker桌面版,以及开启虚拟机步骤:https://blog.csdn.net/qq_34905631/article/details/126573826下载docker桌面版 :https://docs.docker.com/desktop/install/windows-install…...

动态优化会议地点
前言 在现在快节奏的工作节奏下,大家的活动范围越来越广,但是出行成本也相应提高。在集体会面的时候,如何选择合适的地点成为了一个棘手的问题。本文将介绍如何通过动态优化选择会议地点,以达到平均交通成本最低的目标。 动态优化…...

Golang每日一练(leetDay0076) 第k大元素、组合总和III
目录 215. 数组中的第K个最大元素 Kth-largest-element-in-an-array 🌟🌟 216. 组合总和 III Combination Sum iii 🌟🌟 🌟 每日一练刷题专栏 🌟 Rust每日一练 专栏 Golang每日一练 专栏 Python每日…...

可节省60% MCU开发成本的NV080D-S8,单片机语音芯片在恒温碗上的应用
社会在不断进步,科技在不断发展,如今的恒温碗不仅带有温度显示功能,更附带有语音播报,能更好地知晓当前饭菜,变凉或过烫的情况,有效避免伤害宝宝脆弱的肠胃; 广州九芯电子推出了一款,…...

Java并发常见面试题
参考:javauide、程序员大斌、面试宝典 1.并发与并行的区别 并发:两个及两个以上的作业在同一 时间段 内执行。并行:两个及两个以上的作业在同一 时刻 执行。2.同步和异步的区别 同步:发出一个调用之后,在没有得到结果之前, 该调用就不可以返回,一直等待。异步:调用在发…...

基于vue3+pinia2仿ChatGPT聊天实例|vite4.x仿chatgpt界面
使用vue3pinia2开发仿制chatgpt界面聊天实例Vue3-Chatgpt 基于Vue3.xPinia2VueRouterVue3-Markdown等技术构建仿ChatGPT网页端聊天程序。支持经典分栏界面布局、light/dark模式、全屏半屏显示、Markdown语法解析、侧边栏隐藏等功能。 技术框架 编辑工具:Cursor框架…...

JDK动态代理和CGLIB动态代理
JDK动态代理和CGLIB动态代理 JDK动态代理和CGLIB动态代理 JDK动态代理和CGLIB动态代理 ① JDK动态代理只提供接口的代理,不支持类的代理,要求被代理类实现接口。JDK动态代理的核心是InvocationHandler接口和Proxy类,在获取代理对象时&#x…...

Jetpack Hilt 框架的基本使用
什么是 Hilt? Hilt 是一个功能强大、用法简单的依赖注入框架,于 2020 年加入到 Jetpack 家族中。它是 Android 团队联系了 Dagger2 团队,一起开发出来的一个专门面向 Android 的依赖注入框架。相比于 Dagger2,Hilt 最明显的特征就…...

exec()在不同namespace执行结果的区别
记录一个很tricky的问题,下面这段code在执行func1时会出现NameError: name List is not defined,但执行func2时一切正常。 import typescontent """ from typing import Listclass GeneratedData:qna: List"""def func1…...

人工智能革命中的22个隐藏职业:推动科技行业的变革
作者 | Manas Sadangi 随着人工智能技术的不断发展,它正在创造一系列前所未有的就业机会。虽然数据科学家、机器学习工程师和人工智能研究人员等传统的人工智能角色得到了广泛认可,但在推动科技行业变革方面,还有一些鲜为人知的职业同样重要。…...

算法题3 — 求字符串中的最长子串
文章目录 题目示例示例1示例2示例3 解题解法1解法2 leetcode 题目 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例 示例1 输入: s “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。 示例…...

【FreeRTOS】——中断优先级设置中断相关寄存器临界段代码保护调度器挂起与恢复
目录 前言: 一、中断优先级设置 二、中断相关寄存器(STM32-Cortex M3) 三、临界段代码保护 四、任务调度器的挂起和恢复 总结: 前言: 博客笔记根据正点原子视频教程编辑,仅供学习交流使用࿰…...

1.2 什么是eBPF?(下)
四,eBPF的优势 4.1 eBPF程序的动态加载 eBPF程序可以动态地加载到内核中,或从内核中删除。这个要与内核模块的加载与卸载区分开来。这里顺便讨论下eBPF程序与内核模块的区别,如下: 而Linux内核模块是面向内核API编程的,可以直接运行在内核当中。eBPF程序是面向BPF体系结构…...

掌握哪些测试技术才能说自己已经学成了?
一、过硬的基础能力 其实所有的测试大佬都是从底层基础开始的,随着时间,经验的积累慢慢变成大佬。要想稳扎稳打在测试行业深耕,成为测试大牛,首当其冲的肯定就是拥有过硬的基础,所有的基础都是根基,后期所…...

什么是C语言?
C语言是一种高级编程语言,于1972年由Dennis Ritchie在贝尔实验室开发出来。它是一种通用的、结构化的编程语言,被广泛用于系统软件、嵌入式系统、游戏开发以及科学计算等领域。 C语言的设计目标是提供一种简洁、高效、可移植的编程语言,以便…...

SAP-物料主数据-质量管理视图字段解析
过账到质检库存:要勾选,否则收货后库存不进入质检库存HU检验:收货到启用HU管理的库位时产生检验批,例如某个成品物料是收货到C002库位,该库位启用了HU管理,那么此处要勾选。但是如果勾选了,却收…...

TOP RPA·脱普×实在丨日用品企业脱普签约实在智能,构建全域数据智能运营系统
近日,实在智能与脱普日用化学品(中国)有限公司(简称“脱普企业”)在脱普企业上海总部举行“全域数据智能运营”项目启动会,双方领导及项目组关键成员共同参会,就项目目标、实施进程、沟通机制等…...