SQL数据库约束、默认和规则
数据的完整性
实体完整性 又称为行完整性,即数据库中的所有行都具有一个非空且没有重复的主键值
MSSQL中通过唯一索引、PRIMARY KEY约束、UNIQUE约束、INDENTITY属性等来强制主键的唯一性
域完整性 又叫列完整性,以保证列数据的输入具有正确的数据类型、格式和有效的数据范围
强制域有效性可以通过限制数据类型、CHECK约束和规则、FOREIGN KEY、DEFAULT、NOTNULL定义
参照完整性 又叫引用完整性,旨在保证主表和从表数据的一致性,通过FOREIGN KEY和CHECK约束实现
用户定义完整性 用户定义的不属于以上完整性的特点那个规则
SQL数据库约束、默认和规则
1)约束 CONSTRAINT
实现约束的五种方式:
(1) CHECK约束
[CONSTRAINT 约束名] CHECK (逻辑表达式)
CREATE TABLE 成绩
(
学号 char(8) NOT NULL,
CONSTRAINT ck_cj CHECK (成绩>=0 and 成绩<=100)
)
ALTER TABLE 成绩
ADD CONSTRAINT ck_cj (成绩>=60 and 成绩<=100)
ALTER TABLE 成绩
DROP CONSTRAINT ck_cj
(2)PRIMARY KEY约束
[CONSTRAINT 约束名] PRIMARY KEY [CLUSTERED] [NONLUSTERED]
CREATE TABLE 学生
(
学号 char(8) NOT NULL CONSTRAINT pl_xs PRIMARY KEY CLUSTERED
)
ALTER TABLE 学生
ADD CONSTRAINT pk_xs PRIMARY KEY CLUSTERED(学号)
(3)FOREIGN KEY约束 references
[CONSTRAINT 约束名] FOREIGH KEY (从表外键) PEFERENCES 主表 (主表外键)
CREATE TABLE 成绩
(
学号 char(8) NOT NULL FOREIGN KEY REFERENCES 学生 (学号)
)
(4)UNIQUE约束
[CONSTRAINT 约束名] UINQUE [CLUSTERED\NONCLUSTERED](列名...)
CREATE TABLE 职工
(
身份证号 char(18) NULL CONSTRAINT uni_sfz UNIQUE
)
(5)DEFAULT约束
[CONSTRAINT 约束名] DEFAULT 默认约束值 FOR 列名
CREATE TABLE 学生
(
性别 char(2) DEFAULT '男'
)
默认[DEFAULT]
默认是一种数据库对象,可以绑定在一列或者多列上,作用与DEFAULT约束相似,在插入数据行时,为没有指定数据的列提供实现定义的默认值
创建默认对象
CREATE DEFAULT 默认对象名 AS 默认值
USE 学生成绩
CREATE DEFAULT sex_mr AS '男'
绑定默认对象
sp_bindefault [@defname=] '默认对象名' [@objname] '绑定的列名'
use 学生成绩
go
exec sp_bindefault 'sex_mr','学生.性别'
删除绑定
sp_unbindefault [@objname=] '绑定的列名'
use 学生成绩
go
exec sp_unbindefault '学生.性别'
删除默认对象
DROP DEFAULT 默认对象名
use 学生成绩
go
drop default sex_mr
规则(RULE)
规则也是一种数据库对象,可以绑定在一列或多列上,作用与CHECK约束相似,在插入数据行时,指定接收的数据值的范围
创建规则
CREATE RULE 规则名 AS 规则条件
USE 学生成绩
go
create rule cj_rl as @cj>=0 and @cj<=100
绑定规则
sp_bindrule [@rulename=] '规则对象名' [@objname] '绑定的列名'
use 学生成绩
go
exec sp_bindrule 'cj_rl','成绩.成绩'
删除规则
sp_unbindrule [@objname=] '绑定的列名'
use 学生成绩
go
exec sp_unbindrule '成绩.成绩'
删除规则对象
DROP RULE 规则对象名
use 学生成绩
go
drop rule cj_rl
SQL数据库约束、默认和规则的更多相关文章
- SQL数据库修改默认备份和恢复路径
每次都做数据恢复和备份的时候,点Add文件,系统会自动指定到一个默认路径,是SQL的安装目录,但是我的数据库不是备份在这里,每次都要更改有点麻烦. 如上图,更改这个有三个方法. 方法一:找到注册表,手 ...
- SQL数据库约束
针对维护数据库的完整性,关系型数据库SQL提供了数据约束来管理数据,常用的约束有:外键.唯一.主键. 主键约束:标识数据的唯一,便于数据查询索引: 唯一约束:保证数据的唯一性:常用语法 alter t ...
- SQL数据库约束行为---防止数据乱填(即数据规范化)
防止乱填:一.Check约束.按照某种规则对数据进行检查.操作:在表的设计界面中,右击相应的列,选择“CHECK约束”在弹出的对话框中,设置约束的名称和表达式. 代码实现: create table ...
- SQL数据库约束行为---防止数据漏填
防止有些该填的没有填:一.非空约束不能为NULL.操作:在表的设计界面中“允许NULL值”中的复选框去掉. 二.默认值.如果不给列赋值的话,会使用默认值填上.操作:在表的设计界面,选择相应的列,在下面 ...
- sql数据库快照与恢复 规则绑定
存在数据库快照的话我发进行数据库分离 CREATE DATABASE <快照名称> ON (NAME=<数据库文件名>,FILENAME='<存放地址>') AS ...
- SQL数据库约束行为---防止数据完全重复
防止同一条数据完全重复: 一.主关键字约束:主键约束.1.能够唯一的区分每一行数据.——不许重2.表中的数据按照主键字排序的.——有序3.主键字不能为空——不为空4.一个表只能有一个主键,但可以设置组 ...
- Ms SQL Server 约束和规则
一.SQL约束 约束定义关于列中允许值的规则,是强制完整性的标准机制. 使用约束优先于使用触发器.规则和默认值.查询优化器也使用约束定义生成高性能的查询执行计划. 1:类型 约束的类型一共分三种 域约 ...
- Sql Server约束的学习二(检查约束、默认约束、禁用约束)
接上一篇的Sql Server约束学习一(主键约束.外键约束.唯一约束) 4.检查约束 1)检查约束的定义 检查约束可以和一个列关联,也可以和一个表关联,因为它们可以检查一个列的值相对于另一个列的值, ...
- MySQL-第三篇SQL语句基础(2)数据库约束
1.数据库约束. 约束是在表上强制执行的数据校验规则,约束主要用于保证数据库里数据的完整性. MySQL使用information_schema数据库里的TABLE_CONSTRAINTS表来保存该数 ...
随机推荐
- innodb 关键特性(两次写与自适应哈希索引)
两次写: 场景: 当发生数据库宕机时,可能innodb存储引擎正在写入某个页到表中,而这个页只写了一部分,这种情况被称为部分写失效,如果发生,可以通过重做日志进行恢复,重做日志中记录的是对页的物理操作 ...
- paloalto防火墙内存使用率高
上述内存使用率是正常的,实际使用的是buffers.
- 2018-2019-2 20165315 《网络对抗技术》Exp2+ 后门进阶
2018-2019-2 20165315 <网络对抗技术>Exp2+ 后门进阶 一.实验要求 以下三个课题三选一 1.其他专用后门工具研究(CROSSRAT ...) 2.恶意代码绑定技术 ...
- 51单片机学习笔记(清翔版)(13)——LED点阵、74HC595
如图3,点阵屏分单色和彩色,点阵屏是由许多点组成的,在一个点上,只有一颗一种颜色的灯珠,这就是单色点阵屏,彩色的在一个点上有三颗灯珠,分别是RGB三原色. 图4你可能没看出来,那么大块黄色的就是点阵屏 ...
- mysql关闭groupby模式
Mysql5.7 出现 SELECT list is not in GROUP BY clause and contains nonaggregated column ‘sss.month_id’ w ...
- python 下 判断操作系统
import platform OS = platform.system() # Windows, Linux, Darwin def get_sys(): if OS == 'Darwin': pr ...
- 爬坑记-tomcat 项目启动两次的的解决
项目就启动了两次,程序倒是正常运行,关键我里边写了个while 循环,不能让它启动两次啊 百度了一下,有人说是tomcat server.xml或者tomcat新建服务的时候设置出了问题 ....最终 ...
- 自定义扩展实现相对于addRoutes的removeRoutes方法——vue-router
使用vue-router的addRoutes方法做登录权限控制,当用户推出登录回到login页后,切换不同权限的账号,如果不reload页面,会导致router权限问题,故在vue-router代码中 ...
- [树上倍增+二分答案][NOIP2012]运输计划
题目背景 公元 2044 年,人类进入了宇宙纪元. 题目描述 公元 2044 年,人类进入了宇宙纪元 L 国有 nn 个星球,还有 n-1n−1 条双向航道,每条航道建立在两个星球之间,这 n-1n− ...
- IIS配置支持跨域请求
对于初次在IIS部署网站的同学,很容易忽略或不知道如何配置使其网站支持跨域请求,这里介绍一个最基础的方式,配置HTTP响应标头. 在IIS上选择HTTP响应标头,选择添加自定义响应标头,通常我们会添加 ...