当前位置: 移动技术网 > IT编程>数据库>Mysql > Mysql 常见数据类型及约束

Mysql 常见数据类型及约束

2019年10月06日  | 移动技术网IT编程  | 我要评论
Mysql 常见数据类型及约束 最近在跟几个不太懂技术的同事(哈哈, 其实我也不懂), 要整一个数据库项目, 然后前端, 后端, 都没有像样的, 数据输出还不是由我们控制.... 这可难受了, 然后总数被围绕着, 怎么导入数据, 导出EXCEL .... 之类的, 或者是说导入数据不方便, 怎么字段 ...

mysql 常见数据类型及约束

最近在跟几个不太懂技术的同事(哈哈, 其实我也不懂), 要整一个数据库项目, 然后前端, 后端, 都没有像样的, 数据输出还不是由我们控制....

这可难受了, 然后总数被围绕着, 怎么导入数据, 导出excel .... 之类的, 或者是说导入数据不方便, 怎么字段还要有类型.... 每至于此, 我其实内心是崩溃的, 但非常理解. 不理解, 还能怎么办呢.(当然, 开个玩笑)

这里引出一个问题, 为啥要舌设置类型以及约束? 因为数据类型影响着数据存储的资源占用空间和保证数据的完整性. 经常让我头疼的是, 拿到一些都是公式嵌套的excel表, 一打开, 该进程直接凉凉, 或者是表没有唯一标识, 或是字段总在变化, 这可让我难受坏了, so, 规则的约定是非常重要的呀, 于是找了一些常用的, 做一个简单记录.

小结: 数据类型是为了"节约内存,提高计算", 数据约束是为了, 完整性(存储关系).

数据类型

常用数据类型

  • 整数: tinyint, smallint(2, 无符号, 0-32367), mediumint (3, 8388607), int...
  • 小数: decimal, float, double..
  • 字符串: char, varchar, text...
  • 时间日期: date, time, datetime
  • 枚举型: enum
  • decimal 表示浮点数, 如decimal(5,2)表示一个有5位数, 小数占2位
  • char 表示固定长度的字符串, 如char(5), 如果值是"yg", 则会自动补齐空格
  • varchar表可变长度字符串, 如, varchar(5), 值为"yg",则存储的仍是'yg'
  • text 表示存大文本, 一种说法是说, 字符大于4000时才会用

常见数据约束

  • primary key: 物理上的存储顺序, 主键, 一个表设置id字段, 类型为 int unsigned.

  • not null: 该字段不允许空值.
  • unique: 该字段不允许值重复.
  • default: 给该字段给定一个默认值.
  • foreign key: 表之间的"沟通"字段, 在insert 和delete是都要先在关联表中查询.

虽然外键约束可以保证数据的有效性, 做开发时也非常方便, 但在增删查改时, 会降低数据库性能, 不能随意增删数据(好比excel的数据嵌套了其它表), 操作上的确有些难受.

附-数据类型(常用)

整数类型

类型 字节 signed unsigned
tinyint 1 -128 ~ 127 0 ~ 255
smallint 2 -32768 ~ 32767 0 ~ 65535
mediumint 3 -838 8608 ~ 838 8608 0 ~ 1677 7215
int 4 -21 4748 3648 ~ 21亿 0 ~ 42亿
bigint 8 很大 0 ~ 真的大

字符串

类型 字节
char 0 ~ 65535
varchar 0 ~ 65535
text 0 ~ 很大

效率来说基本是char>varchar>text,但是如果使用的是innodb引擎的话,推荐使用varchar代替char。

char和varchar可以有默认值,text不能指定默认值。

数据库选择合适的数据类型存储还是很有必要的,对性能有一定影响. 对于int类型的,如果不需要存取负值,最好加上unsigned;对于经常出现在where语句中的字段,考虑加索引,整形的尤其适合加索引。

日期时间类型

类型 字节 演示
date 4 "2020-01-01"
time 3 "12:56:49"
datetime 8 "2020-01-01 12:12:12"
year 1 '2020'
timestamp 4 2019-10-05 22:21:23

小结

  • 数据类型是为了"节约内存,提高计算", 数据约束是为了, 完整性(存储关系).

  • mysql常用的数据类型: bit, int; decimal, float; char, varchar; date, time, date time; enum...
  • 尽量使用占位空间小的类型, 同时为提高查询效率, 可建立合适的索引.

  • mysql常见字段约束: primary key; not null; unique; default; foreign key.

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

  • Ubuntu上Vim安装NERDTree插件的详细操作步骤

    Ubuntu上Vim安装NERDTree插件的详细操作步骤

    nerdtree是vim的文件系统浏览器,使用此插件,用户可以直观地浏览复杂的目录层次结构,快速打开文件以进行读取或编辑,以及执行基本的文件系统操作。nerdt... [阅读全文]
  • MySQL 4种常用的主从复制架构

    MySQL 4种常用的主从复制架构

    一主多从复制架构在主库读取请求压力非常大的场景下,可以通过配置一主多从复制架构实现读写分离,把大量的对实时性要求不是特别高的读请求通过负载均衡分部到多个从库上(... [阅读全文]
  • 浅析MySQL 备份与恢复

    1、简介数据无价,mysql作为一个数据库系统,其备份自然也是非常重要且有必要去做。备份的理由千千万,预防故障,安全需求,回滚,审计,删了又改的需求等等,备份的... [阅读全文]
  • 保障MySQL数据安全的一些建议

    数据是企业核心资产,数据对企业而言是最重要的工作之一。稍有不慎,极有可能发生数据无意泄露,甚至被黑客恶意窃取的风险。每年业界都会传出几起大事件,某知名或不知名的... [阅读全文]
  • MySQL如何快速修改表的表结构

    快速修改mysql某张表的表结构--摘录自《mysql管理之道》alter table 表名 modify 列名 数据类型; 这个命令可以修改表结构此外,也可以... [阅读全文]
  • MySQL 行锁和表锁的含义及区别详解

    一、前言对于行锁和表锁的含义区别,在面试中应该是高频出现的,我们应该对mysql中的锁有一个系统的认识,更详细的需要自行查阅资料,本篇为概括性的总结回答。mys... [阅读全文]
  • MySQL 如何查询当前最新事务ID

    写在前面:在个别时候可能需要查看当前最新的事务 id,以便做一些业务逻辑上的判断(例如利用事务 id 变化以及前后时差,统计每次事务的响应时长等用途)。通常地,... [阅读全文]
  • 如何优雅、安全的关闭MySQL进程

    前言本文分析了 mysqld 进程关闭的过程,以及如何安全、缓和地关闭 mysql 实例,对这个过程不甚清楚的同学可以参考下。关闭过程1、发起 shutdown... [阅读全文]
  • 详解MySQL8.0​ 字典表增强

    详解MySQL8.0​ 字典表增强

    mysql中数据字典是数据库重要的组成部分之一,information_schema首次引入于mysql 5.0,作为一种从正在运行的mysql服务器检索元数据... [阅读全文]
  • 简述MySQL InnoDB存储引擎

    前言:存储引擎是数据库的核心,对于 mysql 来说,存储引擎是以插件的形式运行的。虽然 mysql 支持种类繁多的存储引擎,但最常用的当属 innodb 了,... [阅读全文]
验证码:
移动技术网