SQL Server 中的约束Word文档下载推荐.docx

上传人:b****6 文档编号:19078629 上传时间:2023-01-03 格式:DOCX 页数:12 大小:21.95KB
下载 相关 举报
SQL Server 中的约束Word文档下载推荐.docx_第1页
第1页 / 共12页
SQL Server 中的约束Word文档下载推荐.docx_第2页
第2页 / 共12页
SQL Server 中的约束Word文档下载推荐.docx_第3页
第3页 / 共12页
SQL Server 中的约束Word文档下载推荐.docx_第4页
第4页 / 共12页
SQL Server 中的约束Word文档下载推荐.docx_第5页
第5页 / 共12页
点击查看更多>>
下载资源
资源描述

SQL Server 中的约束Word文档下载推荐.docx

《SQL Server 中的约束Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《SQL Server 中的约束Word文档下载推荐.docx(12页珍藏版)》请在冰豆网上搜索。

SQL Server 中的约束Word文档下载推荐.docx

空值(NULL)约束。

创建检查约束常用的操作方法有如下两种:

使用SQLServer管理平台创建检查约束(即右键,选择,点击的过程);

用Transact-SQL语句创建检查约束。

2)检查约束CHECK

检查约束对输入列或者整个表中的值设置检查条件,以限制输入值,保证数据库数据的完整性。

这里全选sql语句写的约束做例子。

其语法形式如下:

CONSTRAINTconstraint_name

CHECK[NOTFORREPLICATION]

(logical_expression)

例(注:

下面为列约束)

CREATETABLE我的会员

会员编号smallintNOTNULLCONSTRAINTMemberNoChk

CHECK(会员编号BETWEEN1AND10000),

姓名nvarchar(20)NOTNULL,

地址nvarchar(60)NOTNULL

);

GO

(注:

下面为表约束)

看清楚了没有:

列约束和表约束的区别就是列约束是直接跟在后面,而表约束则不是。

会员编号smallintNOTNULL,

姓名nvarchar(20)NOTNULL,

地址nvarchar(60)NOTNULL,

CONSTRAINTChkMemberNo

CHECK(会员编号BETWEEN1AND10000)

2)主键约束PRIMARYKEY

PRIMARYKEY约束用于定义基本表的主键,它是惟一确定表中每一条记录的标识符,

其值不能为NULL,也不能重复,以此来保证实体的完整性。

PRIMARYKEY与UNIQUE约束类似,通过建立唯一索引来保证基本表在主键列取值的唯一性,

但它们之间存在着很大的区别:

①在一个基本表中只能定义一个PRIMARYKEY约束,但可定义多个UNIQUE约束;

②对于指定为PRIMARYKEY的一个列或多个列的组合,其中任何一个列都不能出现空值,

而对于UNIQUE所约束的唯一键,则允许为空。

注意:

不能为同一个列或一组列既定义UNIQUE约束,又定义PRIMARYKEY约束。

PRIMARYKEY既可用于列约束,也可用于表约束。

使用Transact-SQL语句操作法设置主键约束,其语法形式如下:

PRIMARYKEY[CLUSTERED|NONCLUSTERED]

(column_name)

PRIMARYKEY用于定义表约束时,即将某些列的组合定义为主键,其语法格式如下:

(column_name[,…n])

3)惟一性约束UNIQUE

使用Transact-SQL语句完成惟一性约束的操作,其语法形式如下:

CONSTRAINTconstraint_name

UNIQUE[CLUSTERED|NONCLUSTERED]

CREATETABLE我的员工

员工编号intIDENTITY(10,10)NOTNULLCONSTRAINTPK_员工编号_我的员工PRIMARYKEY,

身份证号码char(10)NOTNULLCONSTRAINTUQ_身份证号码_我的员工UNIQUE,

技能检定编号char(6)NOTNULLCONSTRAINTUQ_技能检定编号_我的员工UNIQUE,

姓名nvarchar(16)NULL,

电话号码char(11)NULL,

行动电话intNULL,

CONSTRAINTUQ_姓名_电话号码_我的员工UNIQUE(姓名,电话号码),

CONSTRAINTUQ_姓名_行动电话_我的员工UNIQUE(姓名,行动电话)

4)外部键约束FOREIGNKEY

外键(FOREIGNKEY)是用于建立和加强两个表数据之间的链接的一列或多列。

外部键约束用于强制参照完整性。

当使用外部键约束时,应该考虑以下几个因素:

外部键约束提供了字段参照完整性;

外部键从句中的字段数目和每个字段指定的数据类型都必须和REFERENCES从句中的字段相匹配;

外部键约束不能自动创建索引,需要用户手动创建;

用户想要修改外部键约束的数据,必须有对外部键约束所参考表的SELECT权限或者REFERENCES权限;

参考同一表中的字段时,必须只使用REFERENCES子句,不能使用外部键子句;

一个表中最多可以有253个外部键约束;

在临时表中,不能使用外部键约束;

主键和外部键的数据类型必须严格匹配

5)默认约束DEFAULT

默认约束指定在插入操作中如果没有提供输入值时,则系统自动指定值。

默认约束可以包括常量、函数、不带变元的内建函数或者空值。

创建默认约束的Transact-SQL语句操作法。

DEFAULTconstraint_expression[FORcolumn_name]

地址varchar(60)NOTNULLDEFAULT'

北京市'

年收入moneyNULLDEFAULT10000)

6)空值约束NULL|NOTNULL

空值(NULL)约束用来控制是否允许该字段的值为NULL。

NULL值不是0也不是空白,

更不是填入字符串的“NULL”字符串,而是表示“不知道”、“不确定”或“没有数据”的意思。

当某一字段的值一定要输入才有意义的时候,则可以设置为NOTNULL。

如主键列就不允许出现空值,否则就失去了唯一标识一条记录的作用。

空值(NULL)约束只能用于定义列约束。

使用Transact-SQL语句设置空值(NULL)约束,其语法形式如下:

[CONSTRAINT<

约束名>

][NULL|NOTNULL]

建立一个S表,对SNO字段进行NOTNULL约束。

程序清单如下:

CREATETABLES

(SNOCHAR(10)CONSTRAINTS_CONSNOTNULL,

SNVARCHAR(20),

AGEINT,

SEXCHAR

(2)DEFAULT'

男'

..................

----------------------------

约束主要包括:

1、notnull:

用于控制字段的内容一定不能为空(NULL)。

用法:

CreatetableMyTable

idvarchar(32)notnull,

namevarchar(32)

2、Unique:

控件字段内容不能重复,一个表允许有多个Unique约束。

在SqlServer、Orcale、MSAccess支持的添加Unique语法:

CreatetableMyTable

idvarchar(32)notnullunique,

在SqlServer、MySql支持的添加Unique语法:

namevarchar(32),

unique(id,.....)

在SqlServer、Orcale、MSAccess、MySql都支持的添加Unique语法:

ConstraintuniqueNameunique(UniqueColumn,.....)

注:

第一种写法(也就是在字段后面直接添加约束),保证每个字段数据唯一性。

第二种写法(也就是同时添加几个字段为约束),这个是保证几个字段数据同时是唯一的,比如Unique(id,name)两个字段为约束,那么当id有重复值,而name没有重复值的情况下是允许的,只有当两个字段数据都与原数据重复的情况下才是不允许的。

在SqlServer、Oracle、MSAccess删除Unique约束语法:

dropconstraintUniqueName;

在MySql删除Unique约束语法:

dropindexUniqueName;

3、PrimaryKey:

也是用于控件字段内容不能重复,但它在一个表只允许出现一个。

在SqlServer、Orcale、MSAccess支持的添加PrimaryKey语法:

CreatetablemyTB1

idnvarchar(32)notnullprimarykey,

namenvarchar(32)

在SqlServer、MySql支持的添加PrimaryKey语法:

idnvarchar(32)notnull,

namenvarchar(32),

primarykey(id)

在SqlServer、Orcale、MSAccess、MySql支持的添加PrimaryKey语法:

constraintPrimaryNameprimarykey(id)

在SqlServer、Orcale、MSAccess、MySql表已存在的情况下,添加表的PrimaryKey约束语法:

AltertablemyTB1

ADDPrimaryKey(id,......)--这样的写法,系统会自定义约束名称

AddConstaintPrimaryNameprimarykey(id)--这样的写法,自己可以自定义约束名称

在SqlServer、Orcale、MSAccess删除表已存在的PrimaryKey约束的语法:

DropConstraintPrimaryName

在MySql删除表已存在的PrimaryKey约束的语法:

DropPrimaryKey

Unique与Primary的相同之处:

UNIQUE和PRIMARYKEY约束均为列或列集合提供了唯一性的保证。

Unique与Primary的不同之处:

每个表可以有多个UNIQUE约束,但是每个表只能有一个PRIMARYKEY约束,Unique允许有NULL值,而Primarykey不允许有NULL值。

注:

在同一个数据库中,就算在不同的表中,约束名称是不允许相同的。

4、ForeignKey:

FOREIGNKEY约束用于预防破坏表之间连接的动作,FOREIGNKEY约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。

在SqlServer、MySql支持的添加ForeignKey语法:

foreignkey(id)referencesmyTB(id)

在SqlServer、Orcale、MSAccess支持的添加ForeignKey语法:

idnvarchar(32)notnullforeignkeyreferencesmyTB(id),

在SqlServer、Orcale、MSAccess、MySql都支持的添加ForeignKey语法:

ConstraintforeignNameforeignkey(id)referencesmyTB(id)

在SqlServer、Orcale、MSAccess、MySql的表已存在情况下,向表添加外键约束的语法:

Addforeignkey(id)referencesmyTB(id)--这样写系统会自定义约束名称

AddConstraintforeignNameforeignkey(id)referencesmyTB(id)--这样写自己可以自定义约束名称

在SqlServer、Orcale、MSAccess中删除外键约束的语法:

DropConstraintforeignName;

在MySql中删除外键约束的语法:

DropforeignkeyforeignName;

5、Check:

用于控制字段的值范围。

在SqlServer、MySql支持的添加check语法:

CreatetablemyCheck

ageintnotnull,

check(age>

15andage<

30)

在SqlServer、Orcale、MSAccess支持的添加check语法:

ageintnotnullcheck(age>

15andage<

在SqlServer、Orcale、MSAccess、MySql都支持的添加check语法:

ageintnotnull,

constraintcheckNamecheck(age<

15andage>

在SqlServer、Orcale、MSAccess、MySql的表已存在情况下,向表添加check约束的语法:

AltertablemyCheck

addcheck(id='

celly'

--这样定义是系统自定义check约束名称。

addconstraintcheckNamecheck(id='

--这样定义是自己自定义check约束名称。

在SqlServer、Orcale、MSAccess删除表已存在的check约束的语法:

dropconstraintcheckName

6、Default:

用于设置新记录的默认值。

在SqlServer、Orcale、MSAccess、MySql添加default约束的语法:

CreatetablemyDefault

idint,

namenvarchar(32)default'

在MySql的已存在表中添加字段默认值:

AltertablemyDefault

Alter[id]setdefault0

在SqlServer、Orcale、MSAccess的已存在表中添加字段默认值:

Altercolumn[id]setdefault0

在MySql中删除字段默认值语法:

AlterColumnNamedropdefault

本文来自CSDN博客,转载请标明出处:

-------------------------------------------

sqlserver中增加约束的语句是:

---添加主键约束

altertable表名addconstraint约束名primarykey(主键)

---添加唯一约束

altertable表名addconstraint约束名unique(字段)

---添加默认约束

altertable表名addconstraint约束名default('

默认内容'

)for字段

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 党团工作 > 思想汇报心得体会

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1