SQL Server 2005系列教学(11) 约束

  1. 云栖社区>
  2. 博客>
  3. 正文

SQL Server 2005系列教学(11) 约束

技术小胖子 2017-11-09 19:29:00 浏览885
展开阅读全文
约束:此部分内容在此做一简短介绍,详细内容会放入到数据库实践课中介绍
如何在现有表上增加主键
alter table 表名 add constraint 主键名 primary key(字段)
alter table testkey add constraint pk_id primary key(id)
如何删除主键:
alter table 表名 drop constraint 主键名
alter table testkey drop constraint pk_id

check 约束: 限定数据必须在指定的范围内,此范围以外不能存放到表中。
通过企业管理器和SQL两种方式来管理
企业管理器:略。。。
SQL 命令:
如何在新建表时创建一个CHECK约束:
create table testkey
(id int  not null,
name varchar(10),
sex char(2),
age int
constraint ck_sex check (age>=18 and age<=60)
)
drop table testkey;
如何在现有表上创建CHECK约束:
alter table 表名 add constraint 约束名 check (约束条件)
对testkey的性别作一个约束,只能是男或女
alter table testkey add constraint ck_性别 check (sex='男' or sex='女')
select * from testkey
insert into testkey values (2,'狗剩','中',30)
如何删除CHECK约束:
alter table 表名 drop constraint 约束名
alter table testkey drop constraint ck_sex
UNIQUE 约束: 限制某些字段值不允许出现重复,但为主键不同,一个表只能有一个主键,但可以有多个UNIQUE约束
企业管理器:略
SQL命令: 
如何在现有表上创建 UNIQUE 约束
alter table  表名 add constraint 约束名 unique (约束条件)
对yuangong表的姓名作一个UNIQUE  约束
alter table yuangong add constraint uk_name unique (姓名)
insert into yuangong (编号,姓名,性别) values ('0020','刘满','男')
如何在新建表时创建UNIQUE约束,参考CHECK约束.
如何删除UNIQUE约束
alter table 表名 drop constraint 约束名
alter table yuangong drop constraint uk_name

create table 员工表
(
员工编号 int not null identity constraint PK_编号 primary key,
姓名 nvarchar(10) not null,
性别 bit constraint DF_性别 default 1,
年龄 tinyint constraint CK_性别 check(年龄 between 15 and 40),
籍贯 nvarchar(15) constraint CK_籍贯 check(籍贯 in('北京','南京','东京','西京')),
联系电话 varchar(20) constraint CK__联系电话 check(联系电话 like '[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]' or 联系电话 like '[0-9][0-9][0-9][0-9][0-9][0-9][0-9]' or 联系电话 like '0[0-9][0-9]-[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]' or 联系电话 like '0[0-9][0-9][0-9]-[0-9][0-9][0-9][0-9][0-9][0-9][0-9]' or 联系电话 like '0[0-9][0-9][0-9]-[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]'),
省份 nvarchar(2),
通讯地址 nvarchar(20),
工作日期 datetime  constraint df_工作日期 default getdate()
)
 
规则:作用和CHECK约束相同:用于限制数据的合法性.
约束必须依赖于表的某一列才能创建.但是规则不用,规则作为一个对象单独存在.但是必须要绑定到列上
才能起作用.而且可以同时绑定到多个表的多个列上.

创建一个规则:
企业管理器:

SQL命令:
创建规则:
create rule 规则名
as 
  语句
如:限制年龄只能在18--60
create rule age
as
  @age between  18 and 60  
实现绑定:
sp_bindrule '规则名','表名.列名'
如:
sp_bindrule 'age','yuangong.年龄'
测试:插入一条记录年龄为70,则不成功
解除绑定:
sp_unbindrule '表名.列名'
如:
sp_unbindrule 'yuangong.年龄'
删除规定:
drop rule 规则名
如:  drop rule age
默认值: 某字段最有可能出现的情况,如果没有手动指定值,则系统自动填入默认值.
企业管理器创建,绑定,解除绑定,删除默认值
利用SQL命令来管理默认值:
创建:  create default 默认值名
       as
         值
 create default bumen
as
'技术部'
绑定:
sp_bindefault '默认值名','表名.列名'
如:
sp_bindefault 'bumen','yuangong.部门'
测试:...
解除绑定:
sp_unbindefault '表名.列名'
如:
sp_unbindefault 'yuangong.部门'
删除默认值:
drop default 默认值名
如:
drop default bumen



 本文转自 dufei 51CTO博客,原文链接:http://blog.51cto.com/dufei/80761,如需转载请自行联系原作者

网友评论

登录后评论
0/500
评论
技术小胖子
+ 关注