如何在现有表上增加主键
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;
alter table 表名 add constraint 约束名 check (约束条件)
alter table testkey add constraint ck_性别 check (sex='男' or sex='女')
如何删除CHECK约束:
alter table testkey drop constraint ck_sex
企业管理器:略
SQL命令:
如何在现有表上创建 UNIQUE 约束
alter table 表名 add constraint 约束名 unique (约束条件)
对yuangong表的姓名作一个UNIQUE 约束
alter table yuangong add constraint uk_name 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()
)
约束必须依赖于表的某一列才能创建.但是规则不用,规则作为一个对象单独存在.但是必须要绑定到列上
才能起作用.而且可以同时绑定到多个表的多个列上.
创建一个规则:
企业管理器:
SQL命令:
创建规则:
create rule 规则名
as
语句
create rule age
as
@age between 18 and 60
sp_bindrule '规则名','表名.列名'
sp_bindrule 'age','yuangong.年龄'
sp_unbindrule '表名.列名'
如:
sp_unbindrule 'yuangong.年龄'
删除规定:
drop rule 规则名
如: drop rule age
创建: create default 默认值名
as
值
as
'技术部'
sp_bindefault '默认值名','表名.列名'
如:
sp_bindefault 'bumen','yuangong.部门'
测试:...
sp_unbindefault '表名.列名'
如:
sp_unbindefault 'yuangong.部门'
drop default 默认值名
如:
drop default bumen