SQL Server 中的约束Word文档下载推荐.docx
《SQL Server 中的约束Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《SQL Server 中的约束Word文档下载推荐.docx(12页珍藏版)》请在冰豆网上搜索。
空值(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字段