(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

相关文章

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

Mac电脑如何通过 IntelliJ IDEA 远程连接 MySQL

《Mac电脑如何通过IntelliJIDEA远程连接MySQL》本文详解Mac通过IntelliJIDEA远程连接MySQL的步骤,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟... 目录MAC电脑通过 IntelliJ IDEA 远程连接 mysql 的详细教程一、前缀条件确认二、打开 ID

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十