(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》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java