(P112)mysql数据库(四):完整性约束:主键 (constraint) ,完整性约束:外键 (constraint) ,完整性约束:用户自定义完整性约束 (check)

本文主要是介绍(P112)mysql数据库(四):完整性约束:主键 (constraint) ,完整性约束:外键 (constraint) ,完整性约束:用户自定义完整性约束 (check),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1.完整性约束:主键 (constraint)
    • 2.完整性约束:外键 (constraint)
    • 3.完整性约束:用户自定义完整性约束 (check)

1.完整性约束:主键 (constraint)

  • 主键能够标识唯一一条记录,主键不能为空,也不能重复
mysql> create table t_emp(empno int primary key,ename varchar(20),esex char(2));
Query OK, 0 rows affected (0.20 sec)mysql> show tables;
+-----------------+
| Tables_in_study |
+-----------------+
| t_emp           |
+-----------------+
1 row in set (0.00 sec)
mysql> desc t_emp;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| empno | int         | NO   | PRI | NULL    |       |
| ename | varchar(20) | YES  |     | NULL    |       |
| esex  | char(2)     | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)mysql> show create table t_emp;
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                                                                      |
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t_emp | CREATE TABLE `t_emp` (`empno` int NOT NULL,`ename` varchar(20) DEFAULT NULL,`esex` char(2) DEFAULT NULL,PRIMARY KEY (`empno`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 |
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)mysql> insert into t_emp(empno,ename,esex) values(10,'wangji','f');
Query OK, 1 row affected (0.03 sec)
mysql> insert into t_emp(empno,ename,esex) values(10,'wangji','m');
ERROR 1062 (23000): Duplicate entry '10' for key 't_emp.PRIMARY'
mysql> insert into t_emp values(11,'shenlulu','m');
Query OK, 1 row affected (0.04 sec)
mysql> insert into t_emp values(null,'lili','m');
ERROR 1048 (23000): Column 'empno' cannot be null

2.完整性约束:外键 (constraint)

  • t_emp表(员工表)的deptno字段的名称不一定与t_dept表(部门表)中的deptno字段的名称一样,通常都是一样的,引用的类型要一样的
mysql> show create table t_emp;
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                                                                                                                                                                                                                 |
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t_emp | CREATE TABLE `t_emp` (`empno` int NOT NULL,`deptno` int DEFAULT NULL,`ename` varchar(20) DEFAULT NULL,`esex` char(2) DEFAULT NULL,PRIMARY KEY (`empno`),KEY `FK_DEPTNO` (`deptno`),CONSTRAINT `FK_DEPTNO` FOREIGN KEY (`deptno`) REFERENCES `t_dept` (`deptno`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 |
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)mysql> insert into t_dept values(2001,'hr');
Query OK, 1 row affected (0.06 sec)mysql> insert into t_dept values(2002,'software');
Query OK, 1 row affected (0.05 sec)mysql> select * from t_dept;
+--------+----------+
| deptno | dname    |
+--------+----------+
|   2001 | hr       |
|   2002 | software |
+--------+----------+
2 rows in set (0.00 sec)自动增长字段
mysql> create table t_test1(id int auto_increment primary key, name varchar(20), age int default 20);
Query OK, 0 rows affected (0.20 sec)mysql> desc t_test1;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int         | NO   | PRI | NULL    | auto_increment |
| name  | varchar(20) | YES  |     | NULL    |                |
| age   | int         | YES  |     | 20      |                |
+-------+-------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)mysql> insert into t_test1(name)  values('bbb');
Query OK, 1 row affected (0.05 sec)
mysql> insert into t_test1(name,age)  values('bbb',null);
Query OK, 1 row affected (0.03 sec)mysql> select * from t_test1;
+----+------+------+
| id | name | age  |
+----+------+------+
|  1 | bbb  |   20 |
| 20 | bbb  |   20 |
| 21 | bbb  | NULL |
+----+------+------+
3 rows in set (0.00 sec)

3.完整性约束:用户自定义完整性约束 (check)

  • 主键,外键,用户自定义的约束保存的位置如下
    在mysql中,所有主键的约束名称都叫做:PRIMARY(在oracle数据库中是生效的,主键名称设置啥,这里就叫啥);
    所有外键的约束名称设置什么就是什么;
    在这里插入图片描述

  • sql语句如下:test.sql

====主键约束====
create table t_emp(empno int not null primary key, ename varchar(20), esex char(2));普通字段也可以设置为not null
/* 等价于 */
create table t_emp(empno int primary key, ename varchar(20), esex char(2));
/* 等价于 */
create table t_emp(empno int, ename varchar(20), esex char(2), primary key (empno));
/* 等价于 */
PK_EMPNO大小写都行,给primary key加上约束
create table t_emp(empno int, ename varchar(20), esex char(2), constraint PK_EMPNO primary key(empno));
/* 等价于 */
create table t_emp(empno int, ename varchar(20), esex char(2));
alter table t_emp add constraint PK_EMPNO primary key(empno);/* 2个字段联合作为一个主键 */
alter table t_emp add constraint PK_EMPNO primary key(XX1,XX2);show create table t_emp;
/* 查看它的查询语句 */insert into t_emp values(1000, 'john', 'm');
insert into t_emp values(1000, 'lily', 'f');
insert into t_emp values(null, 'lily', 'f');====外键约束====
/* deptno是外键:参照完整性,员工表t_emp的部门号deptno要么是空的,要么是部门表t_dept中存在的记录 */
/* t_dept是父表, t_emp是子表,因为t_emp子表的deptno来自t_dept*/
create table t_emp(empno int, deptno int, ename varchar(20), esex char(2));
alter table t_emp add constraint PK_EMPNO primary key(empno);create table t_dept(deptno int, dname varchar(20));
alter table t_dept add constraint PK_DEPTNO primary key(deptno);/* deptno外键引用到了部门表t_dept中的deptno */
alter table t_emp add constraint FK_DEPTNO foreign key(deptno) references t_dept(deptno);set names gbk;
insert into t_dept values(2001, '人事部');
insert into t_dept values(2002, '技术部');/* 查看插入的记录 */
select * from t_emp;insert into t_emp values(1001, 2001, 'john', 'm');
insert into t_emp values(1003, 2003, 'john', 'm');/* 显示表结构 */
describe table t_dept;
/* 等价于 */
desc table t_dept;
简化版
desc t_dept;显示所有数据库:show databases;
选定数据库:use dbname;
显示当前数据库中所有表:show tables;
要先选定数据库
显式指定数据库中的所有表:show tables from dbname;删除表的所有记录
delete from t_emp;删除t_emp整张表
drop table t_emp;/* 自动增长的字段 */
/* 自动增长的属性必定是主键 */
/*auto_increment是mysql自己的语法,oracle没有的*/
create table t_test1(id int auto_increment primary key, name varchar(30), age int default 20);
show create table t_test1;/* 查看它的查询语句 */
desc table t_test1;/*查看表结构*//* 用户自定义的约束 */
/* 主键不设置会自动增长 */
insert into t_test1 values(null, 'aaa');/*这样的写法是错误的*/
insert into t_test1 values(null, 'aaa', null);/*这样写,age=null*/
insert into t_test1(name) values( 'bbb');/*这样写,age = 20*/
/* 查看插入的记录 */
select * from t_emp;/* 用户自定义完整性约束	(check) mysql不支持,oracle支持*/
create table t_test2(id int, name varchar(30), age int);
alter table t_test2 add constraint CC_AGE check (age >=18 and age<=60);
alter table t_test2 add constraint CC_NAME check (length(name)>2);

这篇关于(P112)mysql数据库(四):完整性约束:主键 (constraint) ,完整性约束:外键 (constraint) ,完整性约束:用户自定义完整性约束 (check)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1041357

相关文章

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串