在线客服
扫描二维码
下载博学谷APP
扫描二维码
关注博学谷微信公众号
MySQL数据库的基本使用之数据类型和约束,数据类型包含整数类型、浮点数、字符串、日期等。储存在数据库中的所有数据值均为正确的状态,如有不正确数据则称为已丧失数据完整性。

学习目标:掌握数据类型和数据约束的作用
数据库中的数据保存在数据表中,在表中为了更加准确的存储数据保证数据的正确有效,可以在创建表的时候为表添加一些强制性的验证,如:数据类型和约束。
1. 数据类型
数据类型是指在创建表的时候为表中字段指定数据类型,只有数据符合类型要求才能存储起来,使用数据类型的原则是:够用就行,尽量使用取值范围小而不用大这样可以更多的节省存储空间。
常用数据类型如下:
整数:int,bit
小数:decimal
字符串:varchar,char
日期时间: date, time, datetime
枚举类型(enum)
数据类型说明:
decimal表示浮点数,如 decimal(5, 2) 表示共存5位数,小数占 2 位.
char表示固定长度的字符串,如char(3),如果填充'ab'时会补一个空格为'ab ',3表示字符数
varchar表示可变长度的字符串,如varchar(3),填充'ab'时就会存储'ab',3表示字符数
对于图片、音频、视频等文件,不存储在数据库中,而是上传到某个服务器上,然后在表中存储这个文件的保存路径.
字符串 text 表示存储大文本,当字符大于 4000 时推荐使用, 比如技术博客.
2. 数据约束
约束是指数据在数据类型限定的基础上额外增加的要求.
常见的约束如下:
主键 primary key: 物理上存储的顺序. MySQL 建议所有表的主键字段都叫 id, 类型为 int unsigned.
非空 not null: 此字段不允许填写空值.
惟一 unique: 此字段的值不允许重复.
默认 default: 当不填写字段对应的值会使用默认值,如果填写时以填写为准.
外键 foreign key: 对关系字段进行约束, 当为关系字段填写值时, 会到关联的表中查询此值是否存在, 如果存在则填写成功, 如果不存在则填写失败并抛出异常.
3. 数据类型附录表
(1) 整数类型

(2)字符串

(3)时间类型

4. 小结
常用的数据类型:整数:int,bit、小数:decimal、字符串:varchar,char、日期时间: date, time, datetime、枚举类型(enum);常见的约束:主键约束 primary key、非空约束 not null、惟一约束 unique、默认约束 default、外键约束 foreign key。数据类型和约束保证了表中数据的准确性和完整性
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
数据分析培训学习多久?都学什么?
数据分析培训学习多久?以博学谷的Python数据分析与应用课程为例,学习数据分析只要22课时。那么学习内容有哪些呢?内容大概包括了Python数据分析的相关知识。感兴趣的小伙伴可以一起来看看课程介绍。
10712
2019-09-25 17:34:14
Python的应用领域有哪些?Python爬虫应用场景介绍
Python的应用领域有哪些?Python爬虫应用场景:Web开发、网络编程、爬虫开发、云计算开发、人工智能、自动化运维、金融分析、科学运算、游戏开发、桌面软件。Python语言较其他语言相对简单被称为胶水语言,Python免费开源且兼容众多平台,具有非常丰富的Python库,接下来我们一起来看看Python的应用领域。
13303
2019-10-24 10:44:24
Python中的“字典”怎么学?有没有详细的教程?
Python中的“字典”怎么学?有没有详细的教程?注意,此“字典”非新华字典,这个“字典”指的是键/值对之间用冒号隔开,项之间用逗号隔开,整个字典用大括号括起来。大家千万不能弄混,这是学习Python的知识点之一,接下来小编结合案例为大家详细讲解“字典”。
5833
2020-01-11 14:20:31
小白0基础能学Python吗?
小白0基础能学Python吗?很多程序员都不是计算机相关专业的,都是从零开始的,对于一个初学者都会疑惑,编程语言我到底该学什么语言,对于计算机方面基础好的学员来说,学习任何一门编程语言都比较容易。
5211
2020-07-15 14:29:32
开发中Django和Flask框架的区别是什么?
Django和Flask框架的区别是什么?Python中Django框架和Flask框架都是比较常见的,在开发应用系统时,使用框架可以提升开发效率,让应用开发更加规范、拓展性更强,程序员把更多的精力放在业务逻辑的实现上,而不是重复、而复杂的基础环境上。
6430
2020-08-24 16:15:31
