iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql中怎么实现一个完整性约束
  • 381
分享到

mysql中怎么实现一个完整性约束

2024-04-02 19:04:59 381人浏览 独家记忆
摘要

这篇文章将为大家详细讲解有关Mysql中怎么实现一个完整性约束,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。约束条件作用:用于保证数据的完整性和一致性主要分

这篇文章将为大家详细讲解有关Mysql中怎么实现一个完整性约束,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

约束条件作用:用于保证数据的完整性和一致性

主要分为

PRIMARY KEY (PK)    #标识该字段为该表的主键,可以唯一的标识记录
FOREIGN KEY (FK)    #标识该字段为该表的外键
NOT NULL    #标识该字段不能为空
UNIQUE KEY (UK)    #标识该字段的值是唯一的,
AUTO_INCREMENT    #标识该字段的值自动增长(整数类型,而且为主键)
DEFAULT    #为该字段设置默认值
UNSIGNED #无符号
ZEROFILL #使用0填充

unique

mysql中称为单列唯一

#例子1:
create table department(
  id int,
  name char(10) unique
);
mysql> insert into department values(1,'it'),(2,'it');
ERROR 1062 (23000): Duplicate entry 'it' for key 'name'
#例子2:
create table department(
  id int unique,
  name char(10) unique
);
insert into department values(1,'it'),(2,'sale');
#第二种创建unique的方式
create table department(
  id int,
  name char(10) ,
  unique(id),
  unique(name)
);
insert into department values(1,'it'),(2,'sale');

联合唯一:只要两列记录,有一列不同,既符合联合唯一的约束

# 创建services表
mysql> create table services(
  -> id int,
  -> ip char(15),
  -> port int,
  -> unique(id),
  -> unique(ip,port)
  -> );
Query OK, 0 rows affected (0.05 sec)
mysql> desc services;
+-------+----------+------+-----+---------+-------+
| Field | Type   | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| id    | int(11)  | YES  | UNI | NULL    |       |
| ip    | char(15) | YES  | MUL | NULL    |       |
| port  | int(11) | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+
3 rows in set (0.01 sec)
#联合唯一,只要两列记录,有一列不同,既符合联合唯一的约束
mysql> insert into services values
  -> (1,'192,168,11,23',80),
  -> (2,'192,168,11,23',81),
  -> (3,'192,168,11,25',80);
Query OK, 3 rows affected (0.01 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> select * from services;
+------+---------------+------+
| id  | ip      | port |
+------+---------------+------+
|  1 | 192,168,11,23 |  80 |
|  2 | 192,168,11,23 |  81 |
|  3 | 192,168,11,25 |  80 |
+------+---------------+------+
3 rows in set (0.00 sec)
mysql> insert into services values (4,'192,168,11,23',80);
ERROR 1062 (23000): Duplicate entry '192,168,11,23-80' for key 'ip'

auto_increment

约束:约束的字段为自动增长,约束的字段必须同时被key约束

不指定id,则自动增长

# 创建student
create table student(
id int primary key auto_increment,
name varchar(20),
sex enum('male','female') default 'male'
);

mysql> desc student;
+-------+-----------------------+------+-----+---------+----------------+
| Field | Type         | Null | Key | Default | Extra     |
+-------+-----------------------+------+-----+---------+----------------+
| id  | int(11)        | NO  | PRI | NULL  | auto_increment |
| name | varchar(20)      | YES |   | NULL  |        |
| sex  | enum('male','female') | YES |   | male  |        |
+-------+-----------------------+------+-----+---------+----------------+
rows in set (0.17 sec)
#插入记录
mysql> insert into student(name) values ('老白'),('小白');
Query OK, 2 rows affected (0.01 sec)
Records: 2 Duplicates: 0 Warnings: 0
mysql> select * from student;
+----+--------+------+
| id | name  | sex |
+----+--------+------+
| 1 | 老白  | male |
| 2 | 小白  | male |
+----+--------+------+
rows in set (0.00 sec)

指定id的情况

mysql> insert into student values(4,'asb','female');
Query OK, 1 row affected (0.00 sec)
mysql> insert into student values(7,'wsb','female');
Query OK, 1 row affected (0.01 sec)
mysql> select * from student;
+----+--------+--------+
| id | name  | sex  |
+----+--------+--------+
| 1 | 老白  | male  |
| 2 | 小白  | male  |
| 4 | asb  | female |
| 7 | wsb  | female |
+----+--------+--------+
rows in set (0.00 sec)
# 再次插入一条不指定id的记录,会在之前的最后一条记录继续增长
mysql> insert into student(name) values ('大白');
Query OK, 1 row affected (0.00 sec)
mysql> select * from student;
+----+--------+--------+
| id | name  | sex  |
+----+--------+--------+
| 1 | 老白  | male  |
| 2 | 小白  | male  |
| 4 | asb  | female |
| 7 | wsb  | female |
| 8 | 大白  | male  |
+----+--------+--------+
rows in set (0.00 sec)

对于自增的字段,在用delete删除后,再插入值,该字段仍按照删除前的位置继续增长

mysql> delete from student;
Query OK, 5 rows affected (0.00 sec)
mysql> select * from student;
Empty set (0.00 sec)
mysql> select * from student;
Empty set (0.00 sec)
mysql> insert into student(name) values('ysb');
Query OK, 1 row affected (0.01 sec)
mysql> select * from student;
+----+------+------+
| id | name | sex |
+----+------+------+
| 9 | ysb | male |
+----+------+------+
row in set (0.00 sec)
#应该用truncate清空表,比起delete一条一条地删除记录,truncate是直接清空表,在删除大表时用它
mysql> truncate student;
Query OK, 0 rows affected (0.03 sec)
mysql> insert into student(name) values('xiaobai');
Query OK, 1 row affected (0.00 sec)
mysql> select * from student;
+----+---------+------+
| id | name  | sex |
+----+---------+------+
| 1 | xiaobai | male |
+----+---------+------+
row in set (0.00 sec)
mysql>
auto_increment_increment和 auto_increment_offset

查看可用的 开头auto_inc的词

mysql> show variables like 'auto_inc%';
+--------------------------+-------+
| Variable_name      | Value |
+--------------------------+-------+
| auto_increment_increment | 1   |
| auto_increment_offset  | 1   |
+--------------------------+-------+
rows in set (0.02 sec)
# 步长auto_increment_increment,默认为1
# 起始的偏移量auto_increment_offset, 默认是1
# 设置步长 为会话设置,只在本次连接中有效
set session auto_increment_increment=5;
#全局设置步长 都有效。
set global auto_increment_increment=5;
# 设置起始偏移量
set global auto_increment_offset=3;

强调:If the value of auto_increment_offset is greater than that of auto_increment_increment, the value of auto_increment_offset is ignored.
翻译:如果auto_increment_offset的值大于auto_increment_increment的值,则auto_increment_offset的值会被忽略

设置完起始偏移量和步长之后,再次执行show variables like'auto_inc%';

发现跟之前一样,必须先exit,再登录才有效。

mysql> show variables like'auto_inc%';
+--------------------------+-------+
| Variable_name      | Value |
+--------------------------+-------+
| auto_increment_increment | 5   |
| auto_increment_offset  | 3   |
+--------------------------+-------+
rows in set (0.00 sec)
#因为之前有一条记录id=1
mysql> select * from student;
+----+---------+------+
| id | name  | sex |
+----+---------+------+
| 1 | xiaobai | male |
+----+---------+------+
row in set (0.00 sec)
# 下次插入的时候,从起始位置3开始,每次插入记录id+5
mysql> insert into student(name) values('ma1'),('ma2'),('ma3');
Query OK, 3 rows affected (0.00 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> select * from student;
+----+---------+------+
| id | name  | sex |
+----+---------+------+
| 1 | xiaobai | male |
| 3 | ma1   | male |
| 8 | ma2   | male |
| 13 | ma3   | male |
+----+---------+------+

清空表区分delete和truncate的区别:

delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。

truncate table t1;数据量大,删除速度比上一条快,且直接从零开始。

foreign key

理解foreign key

 mysql中怎么实现一个完整性约束

如上图如果一个公司有很多员工,每个员工都对应一个部门,在填表的时候就会重复写这些部门,太冗余了

我们可以将它们分离

 mysql中怎么实现一个完整性约束

此时有两张表,一张是employee表,简称emp表(关联表,也就从表)。一张是department表,简称dep表(被关联表,也叫主表)。

#1.创建表时先创建被关联表,再创建关联表
# 先创建被关联表(dep表)
create table dep(
  id int primary key,
  name varchar(20) not null,
  descripe varchar(20) not null
);
#再创建关联表(emp表)
create table emp(
  id int primary key,
  name varchar(20) not null,
  age int not null,
  dep_id int,
  constraint fk_dep foreign key(dep_id) references dep(id) //创建约束
);
#2.插入记录时,先往被关联表中插入记录,再往关联表中插入记录
insert into dep values
(1,'IT','IT技术有限部门'),
(2,'销售部','销售部门'),
(3,'财务部','花钱太多部门');
insert into emp values
(1,'zhangsan',18,1),
(2,'lisi',19,1),
(3,'eGon',20,2),
(4,'yuanhao',40,3),
(5,'alex',18,2);

3.删除表

#按道理来说,删除了部门表中的某个部门,员工表的有关联的记录相继删除。
mysql> delete from dep where id=3;
ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`db5`.`emp`, CONSTRAINT `fk_name` FOREIGN KEY (`dep_id`) REFERENCES `dep` (`id`))
#但是先删除员工表的记录之后,再删除当前部门就没有任何问题
mysql> delete from emp where dep_id =3;
Query OK, 1 row affected (0.00 sec)
mysql> select * from emp;
+----+----------+-----+--------+
| id | name   | age | dep_id |
+----+----------+-----+--------+
| 1 | zhangsan | 18 |   1 |
| 2 | lisi   | 18 |   1 |
| 3 | egon   | 20 |   2 |
| 5 | alex   | 18 |   2 |
+----+----------+-----+--------+
4 rows in set (0.00 sec)
mysql> delete from dep where id=3;
Query OK, 1 row affected (0.00 sec)
mysql> select * from dep;
+----+-----------+----------------------+
| id | name   | descripe       |
+----+-----------+----------------------+
| 1 | IT    | IT技术有限部门    |
| 2 | 销售部  | 销售部门       |
+----+-----------+----------------------+
2 rows in set (0.00 sec)

上面的删除表记录的操作比较繁琐,按道理讲,裁掉一个部门,该部门的员工也会被裁掉。其实呢,在建表的时候还有个很重要的内容,叫同步删除,同步更新

on delete cascade #同步删除
on update cascade #同步更新

create table emp(
  id int primary key,
  name varchar(20) not null,
  age int not null,
  dep_id int,
  constraint fk_dep foreign key(dep_id) references dep(id) 
  on delete cascade #同步删除
  on update cascade #同步更新
);
#再去删被关联表(dep)的记录,关联表(emp)中的记录也跟着删除
mysql> delete from dep where id=3;
Query OK, 1 row affected (0.00 sec)
mysql> select * from dep;
+----+-----------+----------------------+
| id | name   | descripe       |
+----+-----------+----------------------+
| 1 | IT    | IT技术有限部门    |
| 2 | 销售部  | 销售部门       |
+----+-----------+----------------------+
2 rows in set (0.00 sec)
mysql> select * from emp;
+----+----------+-----+--------+
| id | name   | age | dep_id |
+----+----------+-----+--------+
| 1 | zhangsan | 18 |   1 |
| 2 | lisi   | 19 |   1 |
| 3 | egon   | 20 |   2 |
| 5 | alex   | 18 |   2 |
+----+----------+-----+--------+
4 rows in set (0.00 sec)
#再去更改被关联表(dep)的记录,关联表(emp)中的记录也跟着更改
mysql> update dep set id=222 where id=2;
Query OK, 1 row affected (0.02 sec)
Rows matched: 1 Changed: 1 Warnings: 0
# 赶紧去查看一下两张表是否都被删除了,是否都被更改了
mysql> select * from dep;
+-----+-----------+----------------------+
| id | name   | descripe       |
+-----+-----------+----------------------+
|  1 | IT    | IT技术有限部门    |
| 222 | 销售部  | 销售部门       |
+-----+-----------+----------------------+
2 rows in set (0.00 sec)
mysql> select * from emp;
+----+----------+-----+--------+
| id | name   | age | dep_id |
+----+----------+-----+--------+
| 1 | zhangsan | 18 |   1 |
| 2 | lisi   | 19 |   1 |
| 3 | egon   | 20 |  222 |
| 5 | alex   | 18 |  222 |
+----+----------+-----+--------+
4 rows in set (0.00 sec)

关于mysql中怎么实现一个完整性约束就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: mysql中怎么实现一个完整性约束

本文链接: https://www.lsjlt.com/news/56045.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql中怎么实现一个完整性约束
    这篇文章将为大家详细讲解有关mysql中怎么实现一个完整性约束,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。约束条件作用:用于保证数据的完整性和一致性主要分...
    99+
    2024-04-02
  • mysql-完整性约束
    约束条件与数据类型的宽度一样,都是可选参数作用:用于保证数据的完整性和一致性主要分为:PRIMARY KEY (PK)    #标识该字段为该表的主键,可以唯一的标识记录 FORE...
    99+
    2023-01-30
    完整性 mysql
  • MySQL完整性约束的定义与实例教程
    目录完整性约束完整性约束的定义完整性约束的分类主键约束(primary key)单个主键和联合主键的区别主键字段的挑选原则删除主键约束主键自增(auto_increment)主键自增...
    99+
    2024-04-02
  • 关系数据库的完整性约束:实体完整性、参照完整性、用户自定义完整性
    关系模型的三种完整性约束是实体完整性、参照完整性和用户定义完整性。 文章目录 关系模型的三种完整性约束是实体完整性、参照完整性和用户定义完整性。实体完整性参照完整性用户自定义完整性 ...
    99+
    2023-10-03
    mysql sql
  • MySQL约束之默认约束default与零填充约束zerofill怎么实现
    本篇内容主要讲解“MySQL约束之默认约束default与零填充约束zerofill怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL约束之默认约束default与零填充约束zer...
    99+
    2023-07-02
  • 数据库中sql完整性约束的示例分析
    小编给大家分享一下数据库中sql完整性约束的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!完整性约束  完整性约束是为了...
    99+
    2024-04-02
  • 如何使用MySQL的外键和约束提高数据完整性和一致性?
    如何使用MySQL的外键和约束提高数据完整性和一致性?在MySQL数据库中,外键和约束是两个重要的概念,它们可以帮助提高数据的完整性和一致性。在本文中,我们将详细讨论如何使用MySQL的外键和约束来实现这个目标,并提供一些代码示例。一、外键...
    99+
    2023-10-22
    MySQL 约束 外键
  • 数据库设计的完整性约束表现有哪些
    这篇文章主要介绍“数据库设计的完整性约束表现有哪些”,在日常操作中,相信很多人在数据库设计的完整性约束表现有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”数据库设计的完整...
    99+
    2024-04-02
  • 如何理解数据库设计的完整性约束表现
    这篇文章将为大家详细讲解有关如何理解数据库设计的完整性约束表现,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。数据完整性是指数据的正确性、完备性和一致性,是衡...
    99+
    2024-04-02
  • mysql中怎么使用check约束性别
    在MySQL中,可以使用ENUM数据类型来定义性别字段,并通过CHECK约束来限制字段的取值范围,从而实现性别的约束。以下是一个示例...
    99+
    2024-04-09
    mysql
  • SQL怎么添加唯一性约束
    在SQL中,可以使用UNIQUE关键字添加唯一性约束。在创建表时,可以在列的定义后面使用UNIQUE关键字来指定该列的唯一性约束。例...
    99+
    2023-08-18
    SQL
  • mongodb唯一性约束怎么创建
    在MongoDB中,可以通过在集合中创建索引来实现唯一性约束。以下是在MongoDB中创建唯一性约束的步骤: 连接到MongoDB...
    99+
    2023-10-26
    mongodb
  • mysql中check约束怎么用
    mysql 中的 check 约束用于限制表中数据值的范围,使用语法:alter table table_name add constraint constraint_name chec...
    99+
    2024-04-26
    mysql
  • 如何使用SQL语句在MySQL中进行数据校验和完整性约束?
    如何使用SQL语句在MySQL中进行数据校验和完整性约束?数据校验和完整性约束是数据库管理系统中常用的方法,用于确保数据的正确性和完整性。在MySQL中,我们可以通过使用SQL语句来实现这些约束。本文将介绍如何使用SQL语句在MySQL中进...
    99+
    2023-12-18
    MySQL SQL语句 数据校验
  • MySQL中唯一性约束与NULL的示例分析
    这篇文章给大家分享的是有关MySQL中唯一性约束与NULL的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言之前做的一个需求,简化描述下就是接受其他组的 MQ 的消息,...
    99+
    2024-04-02
  • SQL Server中怎么实现约束增强
    SQL Server中怎么实现约束增强,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。在许多情况下,对外键使用更复杂的逻辑表达式是非常有用的。 ...
    99+
    2024-04-02
  • mysql中检查约束怎么写
    在MySQL中,可以使用CREATE TABLE语句中的约束来检查约束。以下是一些常见的约束及其写法:1. NOT NULL约束:确...
    99+
    2023-10-20
    MySQL
  • mysql中主键约束怎么写
    mysql中的主键约束是一种唯一约束,用于明确定义表中每行的唯一标识符。可以通过使用primary key关键字或在创建表时指定来创建主键约束。主键可以是单列或复合列(由多个列组成),还...
    99+
    2024-04-26
    mysql
  • mysql中外键约束怎么创建
    在 mysql 中创建外键约束可强制子表记录关联主表记录,保障数据完整性。具体步骤包括:1. 指定子表的外键列;2. 引用主表的唯一索引列;3. 可设置级联删除或更新操作(可选)。 M...
    99+
    2024-05-01
    mysql
  • FlexBuilder2.0中怎么创建一个基于约束的布局
    FlexBuilder2.0中怎么创建一个基于约束的布局,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。FlexBuilder2.0中创建基于约束的布局这个速学教...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作