数据库用SQL语言建表,什么是完整性约束?请问如何写出各种完整性约束?

数据库用SQL语言建表,什么是完整性约束?请问如何写出各种完整性约束?,第1张

一、数据的完整性

实体完整性

实体完整性简单的说,就是将表中的每一行看作一个实体。实体完整性要求表的标示符列或主键的完整性。可以通过建立唯一索引、PRIMARY KEY约束、UNIQUE约束,以及列的IDENTITY属性来实施实体完整性。

域完整性

域完整性是指给定列的输入有效性。要求表中指定列的数据具有正确的数据类型、格式和有效的数据范围。强制域有效性的方法有:限制类型(通过数据类型)、格式(通过 CHECK 约束和规则)或可能值的范围。域完整性通过 FOREIGN KEY 约束、CHECK 约束、DEFAULT 定义、NOT NULL 定义和规则来实现。

引用完整性

引用完整性又称参照完整性。引用完整性维持被参照表和参照表之间的数据一致性,他通过主键(PRIMARY KEY)约束和外键(FOREIGN KEY)约束来实现。

用户定义完整性

二、约束 *** 作

与表相关的约束

在SQL 2008中,常用有6种约束,分别是NOT NULL,UNIQUE,PRIMARY KEY,FOREIGN KEY,DEFAULT和CHECK.

--添加主键约束(即primary key约束)

alter table goods add constraint pk_gid primary key(gid)

--1.删除主键约束

alter table goods drop pk_gid

--添加唯一约束(即unique约束)

alter table goods add constraint uq_gname unique(gname)

--删除唯一约束:仿1.

--添加缺省约束(即default约束)

alter table goods add constraint def_gtel default 0000-00000000 for gtel

--删除缺省约束:仿1.

--添加检查约束(即check约束)

alter table goods add constraint ck_gprice check(gprice>500)

--删除check约束:仿1.

--创建表2

create table g_p

(

wno int identity(1,1) primary key,

gno int

)

--添加外键约束(即foreign key约束)

alter table g_p

add constraint fk_gno

foreign key(gno) references goods(gid)

--删除外键约束:仿1.

--使用newid()

select newid()--生成全球唯一的ID号

create table customer

(

custID uniqueidentifier not null default newid(),

customer char(30) not null

)

insert customer values(newid(),\''\''accp\''\'')--向customer中插入信息

-----------------------------------慢慢研究----

约束,主要为了维护数据库的完整性而定义的一些规则,列约束作为列定义的一部分只作用于此列本身。表约束作为表定义的一部分,可以作用于多个列。在这里举几个例子。

1.主键约束

主关键字约束指定表的一列或几列的组合的值在表中具有惟一性,即能惟一地指定一行记录。每个表中只能有一列被指定为主关键字,且IMAGE 和TEXT 类型的列不能被指定为主关键字,也不允许指定主关键字列有NULL 属性。

多列组成的主键叫联合主键,联合主键就是表级约束,单列主键就是列级约束。

2.唯一性约束

某一列的值,在这个表中,只能出现一个,比如身份z号码等

3.外键约束

外关键字约束定义了表之间的关系。当一个表中的一个列或多个列的组合和其它表中的主关键字定义相同时,就可以将这些列或列的组合定义为外关键字,并设定它适合哪个表中哪些列相关联

等等,不一一列举了。

在SQL中,表达完整性约束的规则有主键约束、外键约束、属性值约束和全局约束等多种形式。

(1)主键约束:可用主键子句或主键短语来定义。  

 如 PRIMARY KEY (S#) (主键子句)  

S# CHAR (4) PRIMARY KEY (其中,PRIMARY KEY 为主键短语)

(2)外键约束:可用外键子句来定义

 如 FOREIGN KEY (S#) REFERNCE S(S#)

(3)属性值约束:包括非空值约束(NOT NULL);基于属性的检查子句(CHECK) ;

 域约束子句(在“CREAT DOMAIN”语句中出现CHECK子句)

如CREAT DOMAIN AGE SMALLINT CHECK (VALUE>10)

(4)全局约束:包括基于元组的检查子句(CHECK)和断言

断言的句法为:CREATE ASSERTION 断言名 CHECK 条件


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/6719659.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-27
下一篇 2023-03-27

发表评论

登录后才能评论

评论列表(0条)

保存