【MySQL | 第十二篇】重新认识MySQL数据类型

12.理解MySQL数据类型

12.1整数类型

  1. 整数类型有五种:tinyint、smallint、mediumint、int、bigint(1,2,3,4,8字节),存储范围为 -2^(N-1) 到 2^(N-1)-1
  2. 所有整数类型默认有符号数,即可正可负,可设置unsiged,表示无符号化,但可以使正数的上限提高一倍

12.2实数类型

  1. 实数就是带有小数部分的数字,也可以使用 delcial 存储比 bigint还大的整数
  2. 实数类型有三种:float、double、decimal
  3. 金额使用decimal存储,不能使用float或者double的原因:二进制存储,有误差

12.3字符串类型

  1. 字符串类型:varchar、char、blob、text、enum

  2. varchar:可变长度字符串(需要一个或者两个额外的字节记录字符串长度,列的长度小于或等于255个字节时需要一个字节来记录,大于255时需要两个字节来记录)

  3. char:定长字符串

    最大长度:

    • MySQL4.1版本之前,varchar(n),指的是n个字节,如果存放UTF8类型字符时,只能存n/3个字符(每个字符占3个字节)。
    • MySQL4.1版本开始,varchar(n),指的是n个字符,无论存放的是数字、字母还是汉字,都可以存放n个,但是字节数不能超过最大限制。
    • CHAR类型最大长度为255个字符(字符数量,而非字节数量)。
  4. blob:二进制存储,可变长字符串

  5. text:字符存储,可变长字符串,MYSQL不能将BLOB和TEXT列全部长度字符串进行索引,也不能用这些索引消除排序。

12.4时间类型

  1. 类型:date、datetime、timestamp(时分秒)、time(时分秒)、year(最小时间粒度是秒)
  2. MySQL没有提供合适的数据类型以存储比秒更小粒度的日期和时间格式,但可以使用其他方法,比如使用BIGINT(8字节,64位)存储微秒级别的时间戳,比如用DOUBLE存储秒之后的小数部分
相关推荐
看海的四叔5 分钟前
【SQL】SQL-常见窗口函数有哪些-上篇
数据库·hive·sql·mysql·数据分析·窗口函数
pele7 分钟前
如何处理ORA-01152报错_恢复未完成导致的数据文件仍需介质恢复
jvm·数据库·python
IntMainJhy14 分钟前
【flutter for open harmony】Flutter SQLite 本地数据库的鸿蒙化适配与实战指南
数据库·flutter·sqlite
qq_3721542316 分钟前
SQL如何避免隐式类型转换导致的慢查询_参数类型对齐与索引失效
jvm·数据库·python
qq_3422958217 分钟前
MySQL怎样在触发器中引用新旧数据行_NEW与OLD关键字详解
jvm·数据库·python
m0_7467523019 分钟前
如何配置Data Guard主备库目录结构不同_DB_FILE_NAME_CONVERT参数转换规则
jvm·数据库·python
weixin_4249993623 分钟前
CSS如何解决CSS冲突导致的BUG_使用CSS层叠层特性隔离样式
jvm·数据库·python
2301_8166602123 分钟前
将地址转换为可点击的 Google Maps 链接(支持动态生成)
jvm·数据库·python
步辞24 分钟前
rowspan属性跨页表格怎么处理_打印断页兼容建议【方法】
jvm·数据库·python
weixin_4585801224 分钟前
Python模型部署怎么做_FastAPI封装模型为RESTful接口
jvm·数据库·python