≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > MySQL

MySQL学习笔记4:完整性约束限制字段

人气:400 时间:2020-07-09

这篇文章主要为大家详细介绍了MySQL学习笔记4:完整性约束限制字段,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编小韵来看看吧!

完整性约束是对字段进行限制,从而符合该字段达到我们期望的效果比如字段含有默认值,不能是NULL等
直观点说:如果插入的数据不满足限制要求,数据库管理系统就拒绝执行操作
设置表的主键
主键能够标识表中每条信息的唯一性,如同身份证号码和人的关系
人可以同名,但是身份证号码却是唯一的,
创建主键的目的在于快速查找到表中的某一条信息
单字段主键

代码如下:

 
mysql> create table student( 
-> id int primary key, 
-> name varchar(20), 
-> sex boolean 
-> ); 
Query OK, 0 rows affected (0.09 sec) 

创建了三个字段,其中id为主键
多字段主键
多字段主键由多个属性组合而成,在属性定义完之后统一设置主键

代码如下:

 
mysql> create table student2( 
-> id int, 
-> course_id int, 
-> score float, 
-> primary key(id,course_id) 
-> ); 
Query OK, 0 rows affected (0.11 sec) 

student2表有三个字段,其中id和course_id的组合可以确定唯一的一条记录
设置表的外键
表的外键与主键是相对应的,比如表A中的id是外键,表B中的id是主键
那么就可以称表B为父表,表A为子表
设置表外键的作用在于建立与父表的联系,比如表B中id为123的学生删除后,表A中id为123的记录也随着消失
这样做的目的在于保证表的完整性

代码如下:

 
mysql> create table student3( 
-> id int primary key, 
-> course_id int, 
-> teacher varchar(20), 
-> constraint fk foreign key(id,course_id) 
-> references student2(id,course_id) 
-> ); 
Query OK, 0 rows affected (0.12 sec) 

这里创建student3表,constraint后面的fk是外键别名,foreign key也就是设置外键的字段
references后的内容表示父表,和父表中的主键
需要注意的是,父表中的主键不能为空,并且主键和外键的数据类型要一致
设置表的非空约束
非空性很好理解,就是设置表中字段的值不能为空(NULL)
如果在已经设置此约束性条件的字段中插入空值,数据库系统则会报错

代码如下:

 
mysql> create table student4( 
-> id int not null, 
-> name varchar(20), 
-> sex boolean 
-> ); 
Query OK, 0 rows affected (0.10 sec) 

这里的not null就是约束条件
设置表的唯一性约束
唯一性是指表中该字段的值不能重复出现,设置表的唯一性约束
也就是给表中某个字段加上unique

代码如下:

 
mysql> create table student5( 
-> id int unique, 
-> name varchar(20) 
-> ); 
Query OK, 0 rows affected (0.10 sec) 

此处id字段便不可重复
设置表的属性值自动增加
auto_increment主要用于为表中插入的新记录自动生成唯一的ID
一个表只能有一个字段使用auto_increment约束
并且该字段必须为主键的一部分

代码如下:

 
mysql> create table student6( 
-> id int primary key auto_increment, 
-> name varchar(20) 
-> ); 
Query OK, 0 rows affected (0.12 sec) 

这里的id是主键,并且会自动增加id值,比如1,2,3,4……
需要注意的是,auto_increment约束的值必须是整数类型
设置表中属性的默认值
在表中插入一条新的记录时,如果没有为该字段赋值
那么数据库系统会自动为该字段赋上一条默认值

代码如下:

 
mysql> create table student7( 
-> id int primary key, 
-> score int default 0 
-> ); 
Query OK, 0 rows affected (0.10 sec) 

本文来自:http://www.q1010.com/177/10093-0.html

注:关于MySQL学习笔记4:完整性约束限制字段的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:MYSQL

您可能感兴趣的文章

  • MySQL中的Load data的使用方法
  • MySQL 事务处理及表锁定深入简析
  • MySQL表的七种类型详细介绍
  • MySQL数据库优化需要遵守的原则
  • MySQL如何按照中文排序解决方案
  • InnoDB引擎数据库主从复制同步新的分享
  • MySQL中自增auto_increment功能的相关设置及问题
  • MySQL日志文件在哪 如何修改MySQL日志文件位置
  • MySQL大表中重复字段的高效率查询方法
  • MySQL学习笔记3:表的基本操作介绍
上一篇:MySQL load data infile 的用法(40w数据 用了3-5秒导进MySQL)
下一篇:MySQL学习笔记3:表的基本操作介绍
热门文章
  • mysql 修改character_set_server为utf-8的简单示例
  • 解决MySQL丢失文件localhost.localdomain.pid、mysql.sock的示例
  • MySQL 数据类型binary和varbinary的简单示例
  • MySQL:reading initial communication packet问题解决方法
  • MySql 表类型MYISAM、InnoDB区别
  • bash: mysql: command not found 的解决方法
  • MYSQL默认用户名ROOT修改方法
  • MySQL 常用命令菜鸟教程
  • MySQL 使用命令行新建用户并授予权限
  • MySql 数据库物理文件存放位置查看示例
  • 最新文章
    • MySQL查看死锁与解除死锁的简单示例
    • MySQL 慢查询的功能实例
    • MySQL查看死锁与去除死锁的简单示例
    • MySQL找出未提交事务的SQL的简单示例
    • MySQL锁阻塞的的简单示例
    • MySQL中的binary类型使用操作的示例
    • SQL优化教程之in与range查询的简单示例
    • MySQL 的 21 个规范、优化最佳实践!
    • MySQL 字符类型大小写敏感的简单示例
    • 解决mybatis-plus分页传入参数后sql where条件没有limit分页信息的问题

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。