MySQL表级完整性约束

MySQL表级完整性约束

为防止不符合规范的数据存入数据库,在用户对数据进行插入、修改、删除等操作时,MySQL提供
了一种机制来检查数据库是否满足规定的条件,以保证数据库中数据的准确性和一致性,这种机制
就是完整性约束。MySQL中主要支持六种完整性约束,如表所示。
完整性约束
约束条件约束描述
PRIMARY KEY主键约束,约束的值可唯一的标识对应的记录
NOT NULL非空字段的值不能为空
UNIQUE唯一约束,约束1字段的值是唯一的
CHECK检查约束,限制某个字段的取值范围
DEFAULT默认值约束,约束字段的默认值
AUTO_INCREMENT自动增加位数,约束字段的值自动递增
FOREIGN KEY外键约束,约束与表之间的关系

 

 

 

 

 

 

 

 

 

约束从作用上可以分为两类:(1) 表级约束:可以约束表中任意一个或多个字段。与列定义的相互独立,不包含
在列表定义中;与定义用‘,’分隔;必须指出要约束的列的名称;(2) 列级约束:包含在列定义中,直接跟在该列的其他定义之后,用空格分隔,不必指定列名;

 

1、主键约束
主键约束(PRIMARY KEY,缩写PK),是数据库中最重要的一种约束,其作用是约束表中的某个字段可以
唯一标识一条记录。因此,使用主键约束可以快速查找表中的记录,就像人的身份证、学生的学号等等,
设置主键的字段取值不能重复(唯一),也不能为空(非空),否则无法唯一标识一条记录。2、非空约束
非空约束(NOT NULL,缩写NK),规定一张表中指定的某个字段的值不能为空(NULL),设置了非空约束
的字段,在插入的数据为NULL时,数据库会提示错误,导致数据无法插入。
无论是单个字段还是多个字段非空约束的添加只能使用列级约束(非空约束无表级约束)

为已存在表中的字段添加非空约束

alter table student modify stu_sex varchar(1)not null;

使用ALTER TABLE语句删除非空约束

3、唯一约束:
唯一约束(UNIQUE,缩写QK):它规定了一张表中指定的某个字段的值不能重复,即这一字段的
每个值都是唯一的。如果想要某个字段的值不重复,那么就可以为该字段添加唯一约束。4、检查约束
检查约束(CHECK)用来限制某个字段的取值范围,可以定义为列级约束,也可以定义为表级约束。
MySQL8开始检查表级约束5、默认值约束
默认值约束(DEFAULT)用来规定字段的默认值。。如果某个被设置为DEFAULT约束的字段没插入具体指,
那么该字段的值将会被默认值填充。
默认值约束的设置与非空约束一样,也只能使用列级约束。6、字段值自动增加约束
自增约束(AUTO_INCREMENT)可以使表中某个字段的值自动增加。一张表中只能有一个自增长字段,
并且该字段必须定义了约束(该约束可以使主键约束、唯一约束以及自增长约束),如果自增长字段没有
定义约束,数据库会提示错误。
由于自增约束会自动生成唯一的ID,所以自增约束通常会配合主键使用,并且只适用于数据整型。一般情
况下,设置自增约束字段的值会从1开始,每增加一条记录,该字段的值就加1.

为已存在表中的字段添加自增约束

create table stu(stu_id int(10) primary key,stu_name varchar(3),stu_sex varchar(1));

使用ALTER TABLE语句删除自增约束

alter table stu modify stu_id int(10);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/562598.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php redis 投票_高性能Redis服务架构分析与搭建

基于内存的Redis应该是目前各种web开发业务中最为常用的key-value数据库了,我们经常在业务中用其存储用户登陆态(Session存储),加速一些热数据的查询(相比较mysql而言,速度有数量级的提升),做简单的消息队列(LPUSH和BRPOP)、订阅发…

MySQL表的非外键约束

MySQL表的非外键约束 /* 建立一张用来存储学生信息的表 字段包含学号、姓名、性别,年龄、入学日期、班级,email等信息 学号是主键 不能为空 ? 唯一 姓名不能为空 性别默认值是男 ,只能取值男、女 年龄:18---50 Email唯一 *…

go调用python3_在python3中使用google的protobuf以及gRPC-Go语言中文社区

下载源代码:地址安装proto#下载:protoc-3.9.1-linux-x86_64.zipunzip protoc-3.9.1-linux-x86_64.zip -d protoc-3.9.1-linux-x86_64 # 解压mv protoc-3.9.1-linux-x86_64 /usr/local/protoc # 移动ln -s /usr/local/protoc/bin/protoc /usr/bin/protoc …

static变量 java

static 变量java static 是java中的一个关键字,单词本身是静态的含义。一个类的成员包含变量、方法、构造方法 、代码块和内部类,static可以修饰除了构造方法以外的所有成员使用static修饰的成员称为静态成员,是属于某个类的;而不…

java static方法

static方法 1、static方法的作用访问static变量和static方法2、static方法的调用方式通过类名调用、通过对象名来访问3、不可以静态方法中不可以访问非静态变量 静态方法中不可以访问非静态方法 静态方法中不可以访问this原因:加载类的时候就加载静态变量和静态方法…

保存验证码的方法_selenium自动化测试:6.验证码处理

0.前言如果可以的话,请先关注(专栏和账号),然后点赞和收藏,最后学习和进步。你的支持是我继续写下去的最大动力,个人定当倾囊而送,不负众望。谢谢!!!1.前提基…

非root用户组启动sftp_如何在 Debian 10 中配置 Chroot 环境的 SFTP 服务 | Linux 中国

SFTP 是最常用的用于通过 ssh 将文件从本地系统安全地传输到远程服务器的方法https://linux.cn/article-12186-1.html作者:Pradeep Kumar译者:郑SFTP 意思是“安全文件传输协议(Secure File Transfer Protocol)” 或 “SSH 文件传输协议(SSH File Transf…

java权限修饰符

java权限修饰符 java一共有四种访问控制符1、private 表示私有,只有自己类能访问2、default 表示没有修饰符修饰,只有同一个报的类能访问3、protected 表示可以被同一个包的类以及其他包中的子类访问4、public 表示可以被该项目的所有包中的所有类访问类…

python增删改查csv文件_【练习】Python第四次:实现对文件的增删改查

import os #os包含改名和删除文件函数def file_handler(backend_data,res None,typefetch):if type fetch:with open(haproxy.conf, r) as read_f:tag False #找到标志ret []for read_line inread_f:if read_line.strip() backend_data: #匹配到数据tag Truecontinueif tag …

java封装练习

java封装练习 /*** 以面向对象的思想,编写自定义类描述图书信息。设定属性包括:书名、作者、出版社名、价格* 方法包括:信息介绍** 要求:* 1、设置属性的私有访问权限,通过公有的get、set方法实现对属性的访问* 2、限…

接口自动化测试_Python自动化测试学习路线之接口自动化测试「模块四」

01.接口自动化测试概念(接口测试的定义与意义;接口测试的实现方式和接口自动化的实现流程)02.HTTP协议(通信协议原理;HTTP与HTTP协议详解(请求,响应,请求方法,状态码)、session、cookie、token鉴权)03.JSON数据格式(JSON与XML的比较;JSON的语法规则;JSON的数据类型)…

java继承实现

java继承实现 /*** 继承*/ public class Animal { //默认animal集成objectprivate String color;private int age;public Animal(){super();}public Animal(String color,int age){this.color color;this.age age;}public void eat(){System.out.println("吃饭"…

spss多元非线性曲线拟合_快速掌握SPSS数据分析

在和SPSSAU的用户交流中,我们发现本是非常简单的数据分析原理以及软件工具,结果非常多的同学完全不会SPSS数据分析,不知道如何学习,即使学过相关原理,但对具体数据进行分析时也有非常多问题。这不禁让我们思考&#xf…

继承情况下构造方法的调用过程-java

继承情况下构造方法的调用过程-java super关键字:可以看做是直接父类对象的引用。每个子类对象都会有一个super引用 指向其直接父类对象。super可以:1、调用成员变量 super.color 2、调用成员方法 super.show 3、调用构造方法 super&#xff0…

重写equals方法---java

重写equals方法---java /*** 重写equals方法*/ public class Animal {String color;private int age;public boolean equals(Object obj){Animal other (Animal)obj;//如果参数是null,直接返回falseif (objnull){return false;}//如果两个变量指向同一个空间&…

python循环函数怎么改变变量_python:循环定义多个变量

我们可能会时长碰到这样一个场景,计算得到一个非固定值,需要根据这个值定义相同数量个变量。实现方式的核心是exec函数,exec函数可以执行我们输入的代码字符串。exec函数的简单例子:>>>exec (print "hello world")hello w…

多态--Java

多态--Java 多态指的是同一个方法调用,由于对象不同可能会有不同的行为。编译器类型指的是‘’左边的类型,运行时类型指的是‘’右边的类型。当有继承关系时,可能发生编译器 和运行期类型不同的情况,即编译期类型是父类类型&…

tex文件用什么软件打开_pdf怎么打开?用什么软件打开pdf?

时光荏苒,转眼2020年还有几个月就结束了,我们公司最近举办了"2020年工作季度总结"大会,领导要求每个部门的不同职员要写一份总结,讲述自己这段时间的经验和教训。而我作为办公室文秘,负责收集他们的个人总结…

Java一个小练习----String类型转换int类型

Java一个小练习 把字符串str分割程String数组,然后转换成int数组,排序 String str "123 345 89 93 2 6573 223" 然后在拼接成一个字符串如下: "2 89 93 123 223 345 6573" /*** String str "123 345 89 93 2…

高级语言的编译过程和解释过程_进来了解一下C语言真正的编译过程看你掌握了吗?...

C语言 前言说实话,很多人做了很久的C/C,也用了很多IDE,但是对于可执行程序的底层生成一片茫然,这无疑是一种悲哀,可以想象到大公司面试正好被问到这样的问题,有多悲催不言而喻,这里正由于换工作的缘故&…