首页 > 数据库 >mysql数据类型的选择

mysql数据类型的选择

时间:2023-02-13 13:38:52浏览次数:51  
标签:CHAR 存储 SET 浮点数 ENUM 数据类型 选择 mysql 类型


1、整数和浮点数

如果不需要小数部分,就是用整数来保存数据;如果需要小数部分,就是用浮点数。对于浮点数据列,存入的数值会对该列定义的小数位进行四舍五入。
浮点类型包裹​​​FLOAT​​​和​​DOUBLE​​类型,精度要求较高时,使用DOUBLE类型。

2、浮点数和定点数

浮点数​​FLOAT、DOUBLE​​​相对于定点数​​DECIMAL​​​的优势是:在长度一定的条件下,浮点数能表示更大的数据范围。但是由于浮点数容易产生误差,因此对精确度的要求比较高时,建议使用​​DECIMAL​​存储。另外,两个浮点数进行减法和比较运算时容易出问题,因此在进行计算的时候一定要小心。如果进行数值比较,那么最好使用DECIMAL类型

3、日期与时间类型

若只需要记录年份,用​​YEAR​​​类型
若只需要记录时间,则只需使用TIME类型
若同时需要记录日期和时间,则可以使用​​​TIMESTAMP​​​或者​​DATETIME​​​类型。由于​​TIMESTAMP​​​列的取值范围小于​​DATETIME​​的取值范围,因此存储范围较大的日期最好使用DATETIME

4、CHAR和CARCHAR

  • ​CHAR​​​是固定长度字符,​​VARCHAR​​是可变长度字符。
  • ​CHAR​​​会自动删除插入数据的尾部空格,​​VARCHAR​​不会删除尾部空格
  • ​CHAR​​​是固定长度,所以处理速度比​​VARCHAR​​快,但是浪费存储空间。

5、ENUM与SET

​ENUM​​只能取单个值,它的数据列表是一个枚举集合。它的合法列表最多有65535个成员。因此,在需要从多个值中选取一个时,可以使用ENUM.比如性别字段适合定义为​ENUM​类型,每次只能从男或女中取一个值。
​​​SET​​​可取多个值。它的合法列表最多有64个成员。空字符串也是一个合法的​​SET​​值。在需要取多个值的时候,时合使用SET类型。比如,一个人的兴趣爱好,最好使用SET类型。
​​​ENUM​​​和​​SET​​​的值是以字符串的形式出现的,但是在​​MYSQL​​内部以数值的形式存储它们。

6、BLOB和TEXT

​BLOB​​​是二进制字符串,​​TEXT​​​是非二进制字符串,两者均可存放大容量的信息。​BLOB主要存储图片、音频信息等,而​TEXT​只能存储文本文件。


标签:CHAR,存储,SET,浮点数,ENUM,数据类型,选择,mysql,类型
From: https://blog.51cto.com/u_15961549/6053957

相关文章

  • mysql自增主键设置
    mysql自增主键设置在数据库应用中,经常希望在每次插入新纪录时,系统自动生成字段的主键值。可以通过为表主键添加​​AUTO_INCREMENT​​关键字来实现。默认情况下,在MYSQL中​......
  • mysql多字段分组
    文章目录​​mysql多字段分组​​​​groupby语法​​​​多字段分组​​​​GROUPBY与ORDERBY一起使用(分组排序)​​​​使用having过滤分组​​mysql多字段分组group......
  • docker 安装mysql
    1,dockerpullmysql:5.7.41具体镜像查看docker官网仓库2,创建容器在本地的映射文件夹mkdir-p/root/mysql/data/root/mysql/logs/root/mysql/conf3,创建mysql配置......
  • Redis五种数据类型及使用场景
    Redis有5种基础数据结构,分别为:string(字符串)、list(列表)、set(集合)、hash(哈希)和zset(有序集合)。Redis所有的数据结构都是一个key对应一个value,不同类型......
  • 聊聊Mysql
    大体来说,MySQL可以分为Server层和存储引擎层两部分:  Server层:包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如......
  • mac端忘记mysql登录密码,进行密码重置
    一、mac--系统偏好设置,找到最下方的mysql,点击关闭。二、点击stop命令或者在终端输入命令行,选择其中一个即可:sudo/usr/local/mysql/support-files/mysql.serverstop......
  • Mysql中的索引
    Mysql中的索引分类MySQL索引分为以下几种:1.唯一索引:一般用来保证字段唯一性,一般在主键和外键上应用。2.普通索引:早期的索引,一个表最多可以由32个索引,要求有唯一的索引......
  • MySQL-利用binlog恢复数据
    MySQL-利用binlog恢复数据  这一篇文章里,我们来记录使用mysql-binlog来恢复数据的整个过程   一、前期准备  1、建库建表  创建数据库blog以及下面的a......
  • 随机生成4位验证码,大写字母小写字母及数字可供随机选择(比如:nG3p)
    vararr=[];for(vari=48;i<=57;i++){arr.push(String.fromCharCode(i));}console.log(arr);for(varj=......
  • MySQL--半同步复制与参数slave_compressed_protocol
    问题场景MySQL版本:5.7.26-29-logPerconaServer(GPL)操作系统版本:CentOSLinuxrelease7.6.1810(Core)BINLOG产生速度:问题描述配置半同步的集群频繁报警,提示集群......