当前位置: 首页 > news >正文

MySQL数据库(数据库约束)

目录

数据库约束

数据库约束的类型: 

null约束 : 

unique约束(唯一约束): 

default约束(默认值约束):  

primary key约束(主键约束): 

foreign key约束(外键约束): 


数据库约束

数据库约束的类型: 

not null- 指示某列不能存储 null值。
unique- 保证某列的每行必须有唯一的值。
default - 规定没有给列赋值时的默认值。
primary key - not null 和 unique 的结合。确保某列(或两个列多个列的结合)有唯一标
识,有助于更容易更快速地找到表中的一个特定的记录。
foreign key - 保证一个表中的数据匹配另一个表中的值的参照完整性

null约束 : 

创建表时,可以指定某列不为空

 drop table if exists student;create table student (id int not null,sn int,name varchar(20),qq_mail varchar(20));

unique约束(唯一约束): 

指定sn列为唯一的、不重复的:

 drop table if exists student;create table student (id int,sn int unique,name varchar(20),qq_mail varchar(20));

 default约束(默认值约束):  

指定插入数据时,name列为空,默认值无名氏:

 drop table if exists student;create table student (id int,sn int ,name varchar(20) default '无名氏',qq_mail varchar(20));

primary key约束(主键约束): 

指定id列为主键:

drop table if exists student;
create table student (id int primary key,sn int ,name varchar(20),qq_mail varchar(20));


对于整数类型的主键,常配搭自增长auto_increment来使用。插入数据对应字段不给值时,使用最大值+1。

drop table if exists student;
create table student (id int primary key auto_increment,sn int ,name varchar(20),qq_mail varchar(20));
desc student;
insert into student values(1,1,'张三','********@qq.com');
insert into student (sn,name,qq_mail)values(2,'李四','********@qq.com');
select *from student;

foreign key约束(外键约束): 

外键用于关联其他表的主键或唯一键,语法:
语法形式:

foreign key(字段名) references 主表(列)
create table class (id int primary key,name varchar(20));create table student(id int primary key,name varchar(20),class_id int,foreign key(class_id)references class(id));

这样就使得student和class产生了联系。而且在插入数据的时候,只能插入符合外键约束的数据:

insert into class values(1,'java1班');
insert into class values(2,'java2班');
select *from class;

class中的数据: 

 insert into student values(1,'张三',2);insert into student values(2,'李四',1);select *from student;

student中的数据:

也就是说张三class_id为2,也就是java1班,李四就是java2班的。这是我们插入一条在class中不存在的id:

 insert into student values (3,'王五',100);

就会出现报错了,无法插入,这就体现了外键的约束。

还要注意的一点就是,外键约束约束的其实是双方,(我们可以把class看成主(父)表,student看成子表) ,除了上述关系外,如果我们想删除父表,也必须删除子表,否则无法删除:

drop table class;

 因为约束的存在所以无法删除。要想删除就要先把子表删除。

http://www.lryc.cn/news/9998.html

相关文章:

  • Hive的安装与配置
  • 关于医院医用医疗隔离电源系统应用案例的分析探讨
  • 【LeetCode】剑指 Offer 07. 重建二叉树 p62 -- Java Version
  • ERROR 1114 (HY000): The table ‘tt2‘ is full
  • 考了PMP证后工资大概是多少 ?(含pmp资料)
  • 基于国产龙芯 CPU 的气井工业网关研究与设计(一)
  • 40/365 javascript 数据类型
  • 后勤管理系统—服务台管理功能
  • Spring Boot 是什么,应该如何学习,有哪些优缺点
  • 使用yolov5和强化学习训练一个AI智能欢乐斗地主(一)
  • C++ 浅谈之 AVL 树和红黑树
  • 【Kotlin】Kotlin函数那么多,你会几个?
  • 饲养员喂养动物-课后程序(JAVA基础案例教程-黑马程序员编著-第四章-课后作业)
  • 数据分析:消费者数据分析
  • Transformer论文阅读:ViT算法笔记
  • Android基础练习解答【2】
  • k8s 搭建
  • 安全运维之mysql基线检查
  • 跨境电商卖家敦煌、雅虎、乐天、亚马逊测评自养号的重要性!
  • Python 之 Matplotlib xticks 的再次说明、图形样式和子图
  • 3.InfluxDB WEB使用
  • git冲突合并
  • 项目自动化构建工具make/Makefile
  • 双目客流统计方案的应用原理
  • python魔术方法(二)
  • cmd for命令笔记
  • 4.1 Filter-policy
  • day15_常用类
  • 【网络原理5】IP协议篇
  • Unity导出WebGL工程,并部署本地web服务器