当前位置: 首页 > news >正文

4.MySQL数据类型

目录

数据类型

​编辑数值类型

tinyint类型

bit类型

float类型

decimal类型

字符串类型

char类型

varchar

varchar和char的区别

日期和时间类型


数据类型

数值类型

说明一下:MySQL本身是不支持bool类型的,当把一个数据设置成bool类型时,数据库会自动将其转换成tinyint(1)的数据类型,其实这个就是变相的bool类型,因为tinyint(1)只有1和0两种取值,可以分别对应bool类型的true和false。

tinyint类型

数值越界测试

mysql> create table t1 (num tinyint);
Query OK, 0 rows affected (0.02 sec)mysql> insert into t1 values(1);
Query OK, 1 row affected (0.01 sec)mysql> insert into t1 values(2);
Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values(127);
Query OK, 1 row affected (0.01 sec)mysql> insert into t1 values(128);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> select * from t1;
+------+
| num  |
+------+
|    1 |
|    2 |
|  127 |
+------+
3 rows in set (0.00 sec)mysql> 

带符号的范围是-128~127,无符号的范围0-255,默认有符号 

有符号的只要插入的范围在-128~127之间的都不会报错,如果插入的范围大于这个区间就会报错。

128不在这个区间,所以不会显示,插入报错了。

tinyint类型(无符号)

mysql> create table t1 (num tinyint unsigned);
ERROR 1050 (42S01): Table 't1' already exists
mysql> create table t2(num tinyint unsigned);
Query OK, 0 rows affected (0.02 sec)mysql> insert into t2 values(128);
Query OK, 1 row affected (0.01 sec)mysql> insert into t2 values(129);
Query OK, 1 row affected (0.00 sec)mysql> insert into t2 values(-129);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t2 values(254);
Query OK, 1 row affected (0.01 sec)mysql> insert into t2 values(255);
Query OK, 1 row affected (0.00 sec)mysql> insert into t2 values(256);
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> insert into t2 values(0);
Query OK, 1 row affected (0.00 sec)

无符号的插入范围是在0~255之间 ,在该范围内都可以进行插入,不在这个范围之间不能插入。

建议:除非场景要求数值类型必须是无符号,否则尽量不要使用无符号,因为有符号的数值类型存不下的数据,其对应的无符号类型同样可能存不下,这时应该直接将数值类型进行提升。

bit类型
bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1

举例:

mysql> create table t3(id int,a bit(8));
Query OK, 0 rows affected (0.02 sec)
mysql> insert into t3 values(10,10);
Query OK, 1 row affected (0.00 sec)mysql> select *from t3;
+------+------+
| id   | a    |
+------+------+
|   10 | |
+------+------+
1 row in set (0.00 sec)

发生了一个很奇怪的现象,a的数据10没有出现????????

那接下来看下面这个例子:

咦咦咦???为什么插入了65会显示A呢??

根本原因是因为bit类型在显示时,是按照ASCII码对应的值进行显示的,而在ASCII码表中10对应的是控制字符LF,表示换行的意思。如果向表中插入记录时指定id和a的值均为65,由于ASCII码表中65对应的是字符A,因此插入记录后查看表就会发现a的值显示的是A。如下:

bit类型测试

如果我们有个这样的值,只能存放0 1 ,这个时候我们就可以定义bit(1),这样还可以节省空间。

mysql> create table t4(-> gender bit(1)-> );
Query OK, 0 rows affected (0.02 sec)mysql> insert into t4 values(0);
Query OK, 1 row affected (0.00 sec)mysql> insert into t4 values(1);
Query OK, 1 row affected (0.01 sec)mysql> select * from t4;
+--------+
| gender |
+--------+
|        |
|       |
+--------+
2 rows in set (0.00 sec)

当我们插入不是0 1 的数据时

  • 虽然MySQL提供了位类型bit,但一般不建议将数据类型设置成位类型,除非将来这个数据本身就只是给程序看的,并且数据本身非常占用资源。
  • 因为查询位类型数据时,默认会按照ASCII码对应的值进行显示,这对于将来数据库管理员维护数据库或程序员调试程序都是不太方便的。
float类型
float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节

案例:

小数:float(4,2)表示范围是-99.99~99.99,MySQL在保存值时会进行四舍五入。

此外,由于MySQL在保存值时会进行四舍五入,因此实际可插入float(4,2)的范围为-99.994~99.994,如果插入的数据不在该范围内,那么插入数据时就会产生报错。如下:

问题:当我们的float(4,2)如果是一个有符号的,则表示范围是-99.99~99.99,如果float(6,3)请问是多少呢??

当然和大家想的一样就是999.999~999.999

float无符号

mysql> create table t6(salary float(4,2) unsigned);
Query OK, 0 rows affected (0.02 sec)mysql> insert into t6 values(0);
Query OK, 1 row affected (0.00 sec)mysql> insert into t6 values(-2);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t6 values(3);
Query OK, 1 row affected (0.01 sec)mysql> insert into t6 values(99.995);
ERROR 1264 (22003): Out of range value for column 'salary' at row 1
mysql> insert into t6 values(99.994);
Query OK, 1 row affected (0.00 sec)mysql> select *from t6;
+--------+
| salary |
+--------+
|   0.00 |
|   3.00 |
|  99.99 |
+--------+
3 rows in set (0.00 sec)

无符号float类型的取值范围,实际就是把对应有符号float类型中的负数部分拿走了,因此float(4,2)的取值范围为0~99.99,实际可插入的范围是0~99.994 

decimal类型
  • decimal(5,2) 表示的范围是 -999.99 ~ 999.99
  • decimal(5,2) unsigned 表示的范围 0 ~ 999.99
  • decimalfloat很像,但是有区别:
  • floatdecimal表示的精度不一样

说明: float 表示的精度大约是 7 位。
decimal 整数最大位数 m 65 。支持小数最大位数 d 30 。如果 d 被省略,默认为 0. 如果 m 被省略,
默认是 10
建议:如果希望小数的精度高,推荐使用decimal

字符串类型

char类型
char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255
mysql> create table t8( char1 char(2) );
Query OK, 0 rows affected (0.02 sec)mysql> insert into t8 values('ab');
Query OK, 1 row affected (0.00 sec)mysql> insert into t8 values('hwh');
ERROR 1406 (22001): Data too long for column 'char1' at row 1
mysql> insert into t8 values('h');
Query OK, 1 row affected (0.00 sec)mysql> insert into t8 values('111');
ERROR 1406 (22001): Data too long for column 'char1' at row 1
mysql> insert into t8 values('11');
Query OK, 1 row affected (0.00 sec)

说明:
char(2) 表示可以存放两个字符,可以是字母或汉字,但是不能超过 2 个, 最多只能是 255
mysql> create table tt10(id int ,name char(256));
ERROR 1074 (42000): Column length too big for column 'name' (max = 255); use
BLOB or TEXT instead

在不同编码中,一个字符所占的字节个数是不同的,比如utf8中一个字符占3个字节,而gbk中一个字符占2个字节。MySQL限定字符的概念不是字节,这样用户就不用关心复杂的编码细节了

varchar
varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节

关于 varchar(len),len 到底是多大,这个 len 值,和表的编码密切相关:
varchar 长度可以指定为 0 65535 之间的值,但是有 1 - 3 个字节用于记录数据大小,所以说有效字节数是65532
当我们的表的编码是 utf8 时, varchar(n) 的参数 n 最大值是 65532/3=21844[ 因为 utf 中,一个字符占用3 个字节 ] ,如果编码是 gbk varchar(n) 的参数 n 最大是 65532/2=32766 (因为 gbk 中,一个字符占用2 字节)。
varchar和char的区别

如何选择定长或变长字符串?
  • 如果数据确定长度都一样,就使用定长(char),比如:身份证,手机号,md5
  • 如果数据长度有变化,就使用变长(varchar), 比如:名字,地址,但是你要保证最长的能存的进去。
  • 定长的磁盘空间比较浪费,但是效率高。
  • 变长的磁盘空间比较节省,但是效率低。
  • 定长的意义是,直接开辟好对应的空间
  • 变长的意义是,在不超过自定义范围的情况下,用多少,开辟多少。

日期和时间类型

常用的日期有如下三个:
  • date :日期 'yyyy-mm-dd' ,占用三字节
  • datetime 时间日期格式 'yyyy-mm-dd HH:ii:ss' 表示范围从 1000 9999 ,占用八字节
  • timestamp :时间戳,从1970年开始的 yyyy-mm-dd HH:ii:ss 格式和 datetime 完全一致,占用四字节

案例:

添加数据时,时间戳自动补当前时间

更新数据:时间戳也会自动更新

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 2023华为od机试C卷【围棋的气】python实现
  • 哈萨克语驾考学习软件求推荐?
  • Springboot项目基础开发模式+注解
  • 【香橙派系列教程】(十三) 香橙派的摄像头接入
  • 【Pyspark-驯化】一文搞懂Pyspark修改hive表描述以及增加列使用技巧
  • 简单的射箭小游戏网页源码
  • 表字段显示tip
  • 【数据结构题目】循环队列,以及队列实现栈的模拟
  • C语言 | Leetcode C语言题解之第332题重新安排行程
  • Android 下载安装配置
  • 探索Python模块搜索路径的奥秘
  • Python中的责任链模式:构建灵活的请求处理机制
  • Python知识点:使用FastAI进行快速深度学习模型构建
  • 初学java第一天:写一下熟悉的猜数字小游戏
  • C#类继承自泛型集合
  • 「面试题」如何实现一个圣杯布局?
  • 【跃迁之路】【444天】程序员高效学习方法论探索系列(实验阶段201-2018.04.25)...
  • Angular Elements 及其运作原理
  • co.js - 让异步代码同步化
  • DataBase in Android
  • Java,console输出实时的转向GUI textbox
  • Python学习之路16-使用API
  • React Native移动开发实战-3-实现页面间的数据传递
  • Webpack 4 学习01(基础配置)
  • 反思总结然后整装待发
  • 基于Javascript, Springboot的管理系统报表查询页面代码设计
  • 基于游标的分页接口实现
  • 记录:CentOS7.2配置LNMP环境记录
  • 简单基于spring的redis配置(单机和集群模式)
  • 如何使用Mybatis第三方插件--PageHelper实现分页操作
  • 删除表内多余的重复数据
  • 使用 Docker 部署 Spring Boot项目
  • 使用权重正则化较少模型过拟合
  • ionic入门之数据绑定显示-1
  • 昨天1024程序员节,我故意写了个死循环~
  • ​低代码平台的核心价值与优势
  • # Maven错误Error executing Maven
  • #LLM入门|Prompt#2.3_对查询任务进行分类|意图分析_Classification
  • #控制台大学课堂点名问题_课堂随机点名
  • (06)Hive——正则表达式
  • (13)Hive调优——动态分区导致的小文件问题
  • (webRTC、RecordRTC):navigator.mediaDevices undefined
  • (板子)A* astar算法,AcWing第k短路+八数码 带注释
  • (附源码)ssm旅游企业财务管理系统 毕业设计 102100
  • (算法)N皇后问题
  • (贪心) LeetCode 45. 跳跃游戏 II
  • (原創) 如何使用ISO C++讀寫BMP圖檔? (C/C++) (Image Processing)
  • (转)h264中avc和flv数据的解析
  • (转)详解PHP处理密码的几种方式
  • .Net Core 微服务之Consul(三)-KV存储分布式锁
  • .net core使用ef 6
  • .NET WebClient 类下载部分文件会错误?可能是解压缩的锅
  • .Net Winform开发笔记(一)
  • .net 程序发生了一个不可捕获的异常
  • .NET 动态调用WebService + WSE + UsernameToken