码迷,mamicode.com
首页 > 数据库 > 详细

SqlServer规则

时间:2019-05-11 21:15:50      阅读:223      评论:0      收藏:0      [点我收藏+]

标签:font   ssi   weight   alt   存储   需要   img   create   范围   

定义:规则时单独的SQLServer对象,可以关联到一个或几个表中的一列或几列。它可以使用多种方式来完成对数据值的校验,可以使用函数返回验证信息,也可以使用关键字BETWEEN,LIKE和IN完成对输入数据的检查。

规则的作用和CHECK约束的功能部分相同,在向表的某列 插入或更新数据时,用它来限制输入的新值的取值范围。

规则和CHECK约束的不同点:

  CHECK约束是用CREATE Table语句在创建表时指定的,而规则需要作为单独的数据库对象来实现。

  在一列上只能用一个规则,但可以使用多个CHECK约束。

  规则可以应用于多个列,还可以应用于用户自定义的数据类型,而CHECK约束只能应用于它定义的列。

语法:

  CREATE RULE rule_name

  AS

  condition_expression

例如:

create rule rule_score
as
@value between 0 and 100
--@value为变量  功能是位于0到100之间

sp_bindrule rule_score,NewSS.StuAge
--绑定到表的列上

创建规则后则立即在规则下面生成这一规则。

规则绑定到列上,需要用到系统存储过程sp_bindrule

打开列中NewSS.StuAge的属性且年龄输入超过100会报错技术图片

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

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

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

解除和删除规则

删除规则 drop rule rule_score

但是删除之前应该先解绑规则

规则绑定在一个列上 sp_unbindrule ‘NewSS.Age‘

但是如果规则绑定多个列上的话,也是依依解绑再删除

 

SqlServer规则

标签:font   ssi   weight   alt   存储   需要   img   create   范围   

原文地址:https://www.cnblogs.com/javier520/p/10849962.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!