约束:此部分内容在此做一简短介绍,详细内容会放入到数据库实践课中介绍
如何在现有表上增加主键
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

SQL Server 2005系列教学(11) 约束相关推荐

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

    约束:此部分内容在此做一简短介绍,详细内容会放入到数据库实践课中介绍 如何在现有表上增加主键 alter table 表名 add constraint 主键名 primary key(字段) alt ...

  2. SQL Server 2005系列教学(2) SQL 服务及创建数据库

    SQL SERVER 2005的服务介绍: 核心服务 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office ...

  3. SQL Server 2005系列教学(14) 用户管理

    用户管理: 哪些用户可以使用: 一种是WINDWOS 一种是SQL SERVER用户 身份验证方式:     windows验证:  安全,但不灵活     混合验证(WINDOWS SQL SERV ...

  4. SQL Server 2005系列教学_用户管理

    用户管理: 哪些用户可以使用: 一种是WINDWOS 一种是SQL SERVER用户 身份验证方式:     windows验证:  安全,但不灵活     混合验证(WINDOWS SQL SERV ...

  5. SQL Server 2005系列教学(1) SQL SERVER2005介绍及安装

    重点在于SQL Server 2005各个版本的安装及测试! 大纲如下: 信息与数据的区别 信息:是现实世界事物的存在方式或运动状态的反映. 数据:数据是信息的载体和具体表现形式,是信息的表现形式. ...

  6. SQL Server 2005系列教学(9) SQL 存储过程

    声明变量,SQL规定变量在使用之前先声明,以便以后的程序中用到 格式:   declare 变量名 变量类型[,变量名 变量类型--] 一次可声明多个变量,它们之间用,分隔.用户变量以一个@开头,全局 ...

  7. SQL Server 2005系列教学(6) 多表操作及子查询

    多表查询:<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> 人事 ...

  8. SQL Server 2005系列教学(13) 游标

    定义一个标准游标: declare mycursor cursor for select * from yuangong  定义一个只读游标: declare mycursor cursor for ...

  9. [学习SQL SERVER 2005系列]图解SQL SERVER2005的安装

    [学习SQL SERVER 2005系列]图解SQL SERVER2005的安装 前言: [学习SQL SERVER 2005系列]准备把学习2005的一些心得整理出来,和大家分享,共同学习一起提高. ...

最新文章

  1. linux ls文件颜色和底色设置
  2. Windows:系统环境变量配置提示系统环境变量太大的问题三种解决方案亲测可用
  3. 新兴短距离无线通信技术ZigBee入门到进阶
  4. 服务器启动时的leader选举
  5. 1034. 有理数四则运算(20)
  6. 【转】SOAR平台初探(一)
  7. js实现删除确认提示框
  8. 诗歌,一路走来...
  9. HDFS文件权限不足导致Sqoop执行失败
  10. Git - 推送当前分支快捷方式
  11. FreeSwitch Lua编程接口(1)dialplan里的配置
  12. LOJ2360「NOIP2016」换教室
  13. Linux 多线程编程 (典藏、含代码)
  14. Part I. S2. 直觉模糊集理论
  15. 8、javascript数组
  16. Mediapipe+OpenCV图像识别技术与Unity引擎的结合-Part2
  17. 【Linux修炼】开篇
  18. 【PC自动化测试-11】窗口控件的类型分类
  19. 如何禁止Windows Defender自动扫描
  20. GIT面试题——分支

热门文章

  1. 【Python】用sympy判断函数的单调性和极值
  2. 浅析如何衡量程序员的生产效率
  3. Windows系统kratos生成proto代码是报exec: “protoc“: executable file not found in %PATH%错误解决办法
  4. 评价最高影片JAVAlibrary_视频 | 手游大神,动画导演,机圈新贵,极客怎么评价愤怒的小鸟2?...
  5. C#语法小知识(二十一)ref与out
  6. Realsense D435i使用笔记
  7. 攻防世界 favorite_number mfw、[BJDCTF2020]ZJCTF,不过如此
  8. 2015春季实习生招聘 多益网络科技有限公司笔试+面试 游戏开发工程师
  9. [JAVA实战篇] AES加密的JAVA实现及AES算法讲解
  10. 最近,帮一个学生做了一个毕业设计