一、SQL语法——4-数据库约束

4-数据库约束

1.概述

(1)约束是在表上强制执行的数据校验规则,约束主要用于保证数据库里数据的完整性;此外当表中的数据存在相互依赖性时,可以保护相关的数据不被删除;

(2)大部分数据库支持如下五种完整性约束:

  1)NOT NULL:非空约束,指定某列不允许为空;

  2)UNIQUE:唯一约束,指定某列或者几列组合不能重复;

  3)PRIMARY KEY:主键约束,指定该列的值可以唯一的标识该条记录;

  4)FOREIGN KEY:外键约束,指定该行记录从属于主表中的一条记录,主要用于保证参照完整性;

  5)CHECK:检查,指定一个布尔表达式,用于指定列的值必须满足该表达式;

(3)约束是数据库对象,也被保存在系统表中,也拥有自己的名字;

(4)根据约束对列的限制,约束可分为如下两类:

  1)单列约束:每个约束只约束一列;

  2)多列约束:每个约束可以约束多个数据列;

(5)为数据表指定约束的时机:

  1)建表时为相应的数据列指定约束;

  2)建表后,以修改表结构的方式增加约束。

2.NOT NULL约束

(1)NOT NULL约束主要用于确保指定列不可以为空,NOT NULL只能作为列级约束使用,只能使用列级约束语法定义;

(2)NULL在SQL中的解释:

  1)所有数据类型的值都可以是null;

  2)空字符串不是NULL,0也不是NULL;

  3)NULL不等于NULL;

(3)示例:

#建表时为指定列指定NOT NULL约束
create table hehe(#建立NOT NULL约束,指定hehe_id不能为NULL;hehe_id int not null,#MySQL的NOT NULL约束不能指定名字hehe_name varchar(255) default 'test' not null,#下面列可以为NULL,默认就是可以为NULLhehe_gender varchar(2) null
)#使用alter table在修改表时添加或者删除NOT NULL约束
#增加NOT NULL约束
alter table hehe
modify hehe_gender varchar(2) not null;
#取消NOT NULL约束
alter table hehe
modify hehe_name varchar(255) null;
#取消NOT NULL约束,并指定默认值
alter table hehe
modify hehe_name varchar(255) default 'test' not null;

 

3.UNIQUE约束

(1)UNIQUE约束用于保证指定列或指定列组合不允许出现重复值;

(2)同个表内可以建立多个UNIQUE,UNIQUE也可以由多个列组合而成。当为某个列添加UNIQUE时,MySQL会为该列相应的创建唯一索引。如果不给UNIQUE起名,该UNIQUE默认与列名相同;

(3)UNIQUE可以使用列级语法建立,也可以使用表级语法建立;如果需要为多列建立UNIQUE,或者为UNIQUE起名,只能使用表级约束语法;

(4)示例:

#建表时创建UNIQUE,使用列级约束语法
create table unique_test(#建立非空约束,表示此列不可为nulltest_id int not null,#使用列级约束语法建立UNIQUEtest_name varchar(255) unique
);#为多列组合建立UNIQUE,或者为UNIQUE自定义名称则需要使用表级约束语法建立UNIQUE#表级约束语法格式:[constraint 约束名] 约束定义
#建表时创建UNIQUE,使用表级约束语法
create table unique_test2(#建立NOT NULL约束test_id int not null,test_name varchar(255),test_pass varchar(255),#使用表级约束语法建立UNIQUEunique (test_name),#使用表级约束语法建立UNIQUE并指定约束名constraint test2_uk unique(test_pass)#分别为test_name和test_pass建立UNIQUE
);#使用表级约束语法,建表时为列组合建立UNIQUE
create table unique_test3(#NOT NULLtest_id int not null,test_name varchar(255),test_pass varchar(255),#使用表级约束语法为列组合建立UNIQUE:两列的组合不能出现重复值constraint test3_uk unique(test_name,test_pass)
);#在修改表结构时,使用add关键字添加UNIQUE
#为列组合添加UNIQUE
alter table unique_test3
add unique(test_name,test_pass);#在修改表时,使用modify关键字为单列添加UNIQUE
alter table unique_test3
modify test_name varchar(255) unique;#删除约束(MySQL)
alter table unique_test3
drop index test3_uk;

 

4.PRIMARY KEY约束

(1)PRIMARY KEY相当于NOT NULL+UNIQUE;即PRIMARY KEY约束的列既不可以存在null也不能够出现重复值;如果对多列组合建立PRIMARY KEY,则多列里包含的每一列都不能为null,但只要求这些列组合不重复,建立了PRIMARY KEY的列值(或列的组合值)可以用于唯一的标识一条记录;

(2)每个表中最多只有一个列(或者一个列组合建立PRIMARY KEY);

(3)建立PRIMARY KEY既可以使用表级约束语法,也可以使用列级约束语法,如果为列组合建立PRIMARY KEY只能使用表级约束语法。使用表级约束语法时,可以为约束起约束名(MySQL中无效,默认名称为PRIMARY);

(4)当创建PRIMARY KEY时,MySQL在所在列或列组合上建立对应的唯一索引;

(5)示例:

#使用列级约束语法,建表时建立PRIMARY KEY
create table primary_test(#建立了PRIMARY KEYtest_id int primary key,test_name varchar(255)
);#使用表级约束语法,建表时建立PRIMARY KEY
create table primary_test2(test_id int,test_name varchar(255),test_pass varchar(255),#指定约束名称为test2_pk,对大部分数据库有效,对MySQL无效#MySQL默认PRIMARY KEY的约束名为PRIMARYconstraint test2_pk primary key(test_id)
);#为多列组合建立PRIMARY KEY,只能使用表级约束语法
create table primary_test3(test_name varchar(255),test_pass varchar(255),#使用表级约束语法为多列组合建立PRIMARY KEYprimary key(test_name,test_pass)
);#删除指定表的PRIMARY KEY
alter table primary_test3
drop primary key;#使用表级约束语法添加PRIMARY KEY(列组合)
alter table primary_test3
add primary key(test_name,test_pass);#使用列级约束语法为单列添加PRIMARY KEY
alter table primary_test3
modify test_name varchar(255) primary key;#为主键添加自增长策略
create table primary_test4(#添加PRIMARY KEY,生成策略为自增长test_id int auto_increment primary key,test_name varchar(255),test_pass varchar(255)
);

 

5.FOREIGN KEY约束

(1)FORRIGN KEY主要用于保证一个或两个数据表之间的参照完整性,FOREGIN KEY是构建于一个表的两个字段或者两个表的两个字段之间的参照关系。FOREIGN KEY确保了两个字段的参照关系:子表外键列的值必须在主表被参照列的值范围内,或者为空(允许使用NOT NULL来约束FOREIGN KEY列不为空)。

(2)当主表的记录被从表的记录参照时,主表记录不允许被删除,必须先把从表参照该记录的所有记录全部删除后,才可删除主表的该记录。也可以在删除主表记录时级联删除从表中的所有参照该记录的从表记录。

(3)从表参照的必须是主表的PRIMARU KEY列或者UNIQUE列,这样才能保证从表记录可以准确定位到被参照的主表记录。同一个表中可以有多个FOREIGN KEY。

(4)FOREIGN KEY通常用于定义两个实体间的一对多、一对一的关联关系。对于一对多通常在多的一段添加FOREIGN KEY;对于一对一可以在任意一个表中添加FOREIGN KEY;对于多对多的关联关系,需要额外增加一个链接表记录他们的关联关系。

(5)建立FOREIGN KEY同样可以使用表级约束语法和列级约束语法。如果仅仅对单独的列建立FOREIGN KEY使用列级约束语法即可,如果要为多个列组合建立FOREIGN KEY或者为FOREIGN KEY起名,则必须使用表级约束语法。

(6)示例:

#采用列级约束语法建立FOREIGN KEY直接使用references关键字,references指定该列参照那个主表,以及参照主表的哪个列
#为保证从表参照的主表存在,通常应该先建立主表
#MySQL中使用列级语法建立FOREIGN KEY不会生效,只有使用表级约束语法建立的FOREIGN KEY才会生效
create table teacher_table(teacher_id int auto_increment,teacher_name varchar(255),primary key(teacher_id)
);
create table student_table(#为本表建立PRIMARY KEYstudent_id int auto_increment primary key,student_name varchar(255),#指定java_teacher参照到teacher_table的teacher_id列java_teacher int references teacher_table(teacher_id)
);#使用表级约束语法建立FOREIGN KEY
create table teacher_table1(teacher_id int auto_crement,teacher_name varchar(255),primary key(teacher_id)
);
create table student_table1(#建立PRIMARY KEYstudent_id int auto_increment primary key,student_name varchar(255),#指定java_teacher列参照到teacher_table1表中的teacher_id列java_teacher int,foreign key(java_teacher) references teacher_table1(teacher_id)
);#如果使用表级约束语法,则需要使用foreign key来指定本表的外键列,并使用references指定参照那个主表,以及餐超到
#主表的哪个数据列。使用表级约束语法可以为外键约束指定外键名,如果创建外键约束时没有指定约束名,则MySQL会为该
#外键约束命名为tableName_ibfk_n,其中tableName是从表的表名,而n是从1开始的整数;#如果显式指定外键约束的名字,需要使用constraint来指定
create table teacher_table2(teacher_id int auto_increment,teacher_name varchar(255),primary key(teacher_id)
);
create table student_table2(#为本表建立主键约束student_id int auto_increment primary key,student_name varchar(255),java_teacher int,#使用表级约束语法建立foreign key并为其指定名字constraint student_teacher_fk foreign key(java_teacher) references teacher_table2(teacher_id)
);#如果需要建立多列组合的foreign key则必须使用表级约束语法
create table teacher_table3(teacher_name varchar(255),teacher_pass varchar(255),#使用teacher_name和teacher_pass建立联合主键primary key(teacher_name,teacher_pass)
);
create table student_table3(#为本表建立主键约束student_id int auto_increment primary key,student_name varchar(255),java_teacher_name varchar(255),java_teacher_pass varchar(255),#使用表级约束语法为java_teacher_name和java_teacher_pass建立联合foreign keyconstraint student_table3_ibfk_1 foreign key(java_teacher_name,java_teacher_pass) references teacher_table3(teacher_name,teacher_pass)
);#删除foreign key
alter table student_table3
drop foreign key student_table3_ibfk_1;#修改表结构时增加foreign key
alter table student_table3
add foreign key(java_teacher_name,java_teacher_pass) references teacher_table3(teacher_name,teacher_pass);#foreign key不仅仅可以参照其他表,也可参照自身,这种参照自身的情况称为自关联
create table foreign_test(foreign_id int auto_increment primary key,foreign_name varchar(255),#使用该表的refer_id参照到本表的foreign_idrefer_id int,foreign key(refer_id) references foreign_test(foreign_id)
);#如果需要定义删除主表记录时,从表记录也会随之删除,需要在建立外键约束后添加on delete cascade或者
#添加on delete set null;
#on delete cascade:删除主表记录时,把参照该主表记录的从表记录全部级联删除
#on delete set null:删除主表记录时,把参照该主表记录的从表记录的外键设置为nullcreate table teacher_table4(teacher_id int auto_increment,teacher_name varchar(255),primary key(teacher_id)
);
create table student_table4(student_id auto_increment primary key,student_name varchar(255),java_teacher int,#使用表级约束语法建立foreign key并定义级联删除foreign key(java_teacher) references teacher_table4(teacher_id) on delete cascade#或者#foreign key(java_teacher) references teacher_table4(teacher_id) on delete set null
);

 

 

 

6.CHECK约束

用于指定一个列的值的取值范围

示例:

create table teacher_table(teacher_id int auto_increment primary key,teacher_age int,teacher_name varchar(255),teacher_pass varchar(255),check(teacher_age<1000)
);

 

 

 

转载于:https://www.cnblogs.com/ljiwej/p/7280147.html

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

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

相关文章

黑马程序员博学谷Java就业班课程

1、资料全无加密&#xff0c;可任意试看 2、内容包括课程资料 地址:https://www.boxuegu.com/class/outline-1112.html

设计模式一の设计模式详解

一、设计模式定义 设计模式&#xff08;Design Pattern&#xff09;是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。使用设计模式的目的&#xff1a;为了代码可重用性、让代码更容易被他人理解、保证代码可靠性。 设计模式使代码编写真正工程化&#xff1b;…

Spring模板对象

Spring模块对象: 把共性的方法抽取出来固定为一个模板&#xff0c;后续再操作只需要填充内容即可。 比如&#xff1a;淘宝每次买东西都要填写地址&#xff0c;只是每次买的东西不一样&#xff0c;所以可以做一个默认地址&#xff0c;每次买东西都要去选商品就行了&#xff0c;不…

SpringMVC入门案例

SpringMVC 概述&#xff1a; SpringMVC是一种基于Java实现MVC模型的轻量级Web框架 三层架构 表现层&#xff1a;负责数据展示业务层&#xff1a;负责业务处理数据层&#xff1a;负责数据操作 MVC&#xff08;Model View Controller&#xff09;&#xff1a;一种用于设计创建…

中文转换成字节数组

由中文转换成字节数组时由于编码格式的不同&#xff0c;一个汉字所占的字节会有所不同&#xff0c;在做转换时需特别注意。 例如&#xff0c; String.teststr "中国"; byte [] leng teststr.getBytestf-8"); 此时leng长度为6&#xff0c;即一个汉字占3个字节…

SpringMVC请求中的普通、POJO、数组集合类型传参与类转换器

SpringMVC将传递的参数封装到处理器方法的形参中&#xff0c;达到快速访问参数的目的。 普通类型参数传参 参数名与处理器方法形参名保持一致 访问URL&#xff1a; http://localhost/requestParam1?nameitzhuzhu&age14 RequestMapping("/requestParam1")publi…

【贪心算法】POJ-1017

一、题目 Description A factory produces products packed in square packets of the same height h and of the sizes 11, 22, 33, 44, 55, 66. These products are always delivered to customers in the square parcels of the same height h as the products have and of …

SpringMVC响应使用案例(带数据页面跳转,快捷访问路径,返回json数据)

页面跳转 转发&#xff08;默认&#xff09; RequestMapping("/showPage1") public String showPage1() {System.out.println("user mvc controller is running ...");// return "WEB_INF/pages/forward:page.jsp";这种方式不支持重定向&#…

HDU 2874 Connections between cities(LCA离线算法实现)

http://acm.hdu.edu.cn/showproblem.php?pid2874 题意&#xff1a; 求两个城市之间的距离。 思路&#xff1a; LCA题&#xff0c;注意原图可能不连通。 如果不了解离线算法的话&#xff0c;可以看我之前博客写的解释http://www.cnblogs.com/zyb993963526/p/7295894.html 1 #in…

SpringMVC中的异步请求-跨域访问

发送异步请求&#xff1a; <%page pageEncoding"UTF-8" language"java" contentType"text/html;UTF-8" %><a href"javascript:void(0);" id"testAjax">访问springmvc后台controller</a><br/> <…

P1080 国王游戏

题目描述 恰逢 H 国国庆&#xff0c;国王邀请 n 位大臣来玩一个有奖游戏。首先&#xff0c;他让每个大臣在左、右手上面分别写下一个整数&#xff0c;国王自己也在左、右手上各写一个整数。然后&#xff0c;让这 n 位大臣排成一排&#xff0c;国王站在队伍的最前面。排好队后&a…

SpringMVC配置静态资源加载, 中文乱码处理,注解驱动

常规配置&#xff08;Controller加载控制&#xff09; SpringMVC的处理器对应的bean必须按照规范格式开发&#xff0c;未避免加入无效的bean可通过bean加载过滤器进行包含设定或排除设定&#xff0c;表现层bean标注通常设定为Controller业务层与数据层bean加载由Spring控制&…

Android App性能測试

一、内存 1、查看单个应用App最大内存限制 Command&#xff1a;adb shell “getprop|grep heapgrowthlimit” C:\Users\hujiachun>adb shell "getprop|grep heapgrowthlimit" [dalvik.vm.heapgrowthlimit]: [128m] 128M是单个APP最大内存限制&#xff0c;假设Dalv…

SpringMVC-HandlerInterceptor拦截器的使用与参数详解

拦截器概念&#xff1a; 拦截器&#xff08; Interceptor&#xff09;是一种动态拦截方法调用的机制&#xff0c;请求处理过程解析核心原理&#xff1a; AOP思想拦截器链&#xff1a;多个拦截器按照一定的顺序&#xff0c;对原始被调用功能进行增强 作用&#xff1a; 在指定的…

使用FindBugs-IDEA插件找到代码中潜在的问题

另一篇使用文档&#xff0c;参照&#xff1a;https://www.cnblogs.com/huaxingtianxia/p/6703315.html 我们通常都会在APP上线之后,发现各种错误,尤其是空指针异常,这些错误对于用户体验来说是非常不好的,但其实大部分的问题,我们都能够提前发现. 在编写代码的过程中,可能不会时…

SpringMVC异常处理 自定义异常

异常处理器 实现HandlerExceptionResolver接口&#xff08;异常处理器&#xff09; Component // 配上注解Spring看到实现了这个接口就知道是异常处理器了 public class ExceptionResolver implements HandlerExceptionResolver {public ModelAndView resolveException(HttpSe…

霍炬:再谈百度:KPI、无人机,以及一个必须给父母看的案例

霍炬&#xff1a;再谈百度&#xff1a;KPI、无人机&#xff0c;以及一个必须给父母看的案例 作者&#xff1a;霍炬。 原文链接&#xff1a;http://www.donews.com/idonews/article/8147.shtm没想到我之前的一篇关于百度的文章引起了这么大的反馈。非常多朋友称赞我写的好&…

使用SpringMVC模拟文件上传与下载案例

文件上传下载 SpringMVC封装了Tomcat的上传文件功能 MultipartResolver接口 MultipartResolver接口定义了文件上传过程中的相关操作&#xff0c;并对通用性操作进行了封装MultipartResolver接口底层实现类CommonsMultipartResovlerCommonsMultipartResovler并未自主实现文件上…

JSR表单校验框架

表单校验的重要性&#xff1a; 表单校验保障了数据有效性、安全性 不适用表单检验数据可以随意输入&#xff0c;导致错误的结果。后端表单校验的重要性&#xff0c;比如输入框采集成绩&#xff0c;如果前端做了检验&#xff0c;但是用户比较牛逼&#xff0c;他在地址栏上直接加…

使用Phantom omni力反馈设备控制机器人

传统的工业机器人普遍采用电机 、齿轮减速器 、关节轴三者直接连接的传动机构&#xff0c;这种机构要求电机与减速器安装在机械臂关节附近&#xff0c;其缺点是对于多关节机械臂&#xff0c;下一级关节的电机与减速器等驱动装置成为上一级关节的额外负载 。这一额外负载带来的负…