SQLServer之DEFAULT约束

发布时间:2018-12-29  栏目:SQL  评论:0 Comments

DEFAULT约束优缺点

优点:

1、使用默认值可以削减代码量,新增多少时得以不用写新增默认值列,执行新增操作时时默认填充。

2、较便宜开展总结和剖析,以及便于程序逻辑操作。

缺点:

1、使用不为NULL的默认值,占用了更多的仓储空间。

 

一、约束的分类

  在SQLServer中,有3种不同类另外束缚。

  1、实体约束

    实体约束是关于行的,比如某一行出现的值就不同意出现在任何行,例如主键。

  2、域约束

    域约束是有关列的,对于持有行,某一列有那个约束,例如CHECK约束。

  3、参照完整性约束

    要是某列的值必须与此外列的值十分,这就代表需要一个参阅完整性约束,例如外键。

创制表时丰裕默认约束

先是判断表是否选在,如果存在则先删除表再添加,假使不存在则直接助长。

语法:

–创制新表时添加默认约束
–数据库注脚
use 数据库名
go
–尽管表已存在则先删除表再创立,要是表不设有则一向开立
if exists(select * from sysobjects where
name=表名 and type =’U’)
drop table 表名;
go
–建表语法讲明
create table 表名
(
–字段阐明
列名 列类型 identity(1,1) not
null,
列名 列类型) null,
列名 列类型 null,
列名 列类型 null,
列名 列类型,
列名 列类型 constraint 约束名 default
默认值,
primary key clustered(列名 asc)
with(ignore_dup_key=off) on [primary] –主键索引讲明
)on [primary]

–字段注释注明
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’列说明’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’表名’,
@level2type=N’COLUMN’,@level2name=N’列名’;

go

示例:

–创立新表时添加默认约束
–数据库讲明
use testss
go
–如果表已存在则先删除表再成立,假若表不存在则直接成立
if exists(select * from sysobjects where
name=’test1′ and type =’U’)
drop table test1;
go
–建表语法阐明
create table test1
(
–字段表明
id int identity(1,1) not null,
name nvarchar(50) null,
sex nvarchar(50) null,
age nvarchar(50) null,
classid int,
height int constraint default_he default
166,
primary key clustered(id asc)
with(ignore_dup_key=off) on [primary] –主键索引讲明
)on [primary]

–字段注释申明
exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’id主键’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’id’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’姓名’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’name’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’性别’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’sex’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’年龄’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’age’;

exec sys.sp_addextendedproperty
@name=N’MS_Description’, @value=N’班级id’ ,
@level0type=N’SCHEMA’,
@level0name=N’dbo’,
@level1type=N’TABLE’,@level1name=N’test1′,
@level2type=N’COLUMN’,@level2name=N’classid’;

go

图片 1

图片 2

3、唯一约束

  唯一约束与主键相比相似,共同点在于它们都要求表中指定的列(或者列的结缘)上有一个唯一值,区别是唯一约束尚未被看作表中著录的绝无仅有标识符(尽管你可以按这样的主意利用也实惠),而且可以有几个唯一约束(而在各种表中只好有一个主键)。

  一旦创建了唯一约束,那么指定列中的每个值必须是唯一的。假如更新或者插入一条记下在带唯一约束的列上有曾经存在的值的记录,SQLServer将抛出荒谬,拒绝这么些记录。

  和主键不同,唯一约束不会活动制止设置一个NULL值,是否允许为NULL由表中相应列的NULL选项的安装决定,但哪怕真的允许NULL值,一张表中也只好插入一个NULL值(如果同意四个,这就不叫唯一了)。

  在已存在的表上创制唯一约束:

alter table Account
    add constraint AK_AccountName    --约束名
    unique (Account_Name)    -- 列名

  AK代表替换键(Alternate Key),唯一约束也叫替换键。

  主键和唯一约束的界别:

  •    
    主键约束不容许出现NULL值。任何索引的索引键都不同意包含null值。但唯一约束允许包含NULL值,但唯一约束把两个NULL值当作重复值,所以施加了唯一约束的每一列只允许包含一个NULL值。
  •    
    创立主键时会自动创造聚集索引,除非当前表中一度包含了聚集索引或是创造主键时指定了NONCLUSTERED关键字。
  •    
    成立唯一约束时会自动创制非聚集索引,除非你指定了CLUSTERED关键字并且当前表中还未曾聚集索引。
  •     每个表中只可以有一个主键,但可以由三个唯一约束。

动用T-SQL脚本添加DEFAULT约束

6、禁用约束

   有时我们想临时或永久地排除约束。可是SQL
Server并从未提供删除约束的法门。SQL
Server只允许禁用外键约束或CHECK约束,而与此同时保障约束的完整性。

   禁用一个数据完整性规则经常是因为早已有不行数据了。这样的数码一般分为以下两类:

  1、在开立约束时已经在数据库中的数据

  2、在约束创设未来希望增长的数目

  SQL
Server允许禁用完整性检查一段时间来对两样的不算数据作处理,然后再另行启用完整性(不是情理删除数据完整性约束)。

    瞩目:不能够禁用主键约束仍旧唯一约束

  6.1、在开创约束时,忽略检查往日的不满足数据

  要添加一个封锁,不过有不使用到已存在的数目中,可以再执行Alter
Table语句添加约束时行使WITH NOCHECK选项。

  遵照地点创制Check约束的点子,已经Alter
Table时,表中本人已经存在不切合的数码,那么Alter Table操作将被SQL
Server拒绝执行。除非已经存在的装有数据都满足CHECK约束的基准,否则SQL
Server不会执行创设约束的授命。要解决这么些题材,大家可以添加WITH NOCHECK。

  我们先新建一个表只有3个字段的表,Id、姓名、年龄,并在里头插入一条不知足要求的多少:

insert into Account values (23,'洪',17)

   然后执行添加封锁命令:

alter table Account
    add constraint CN_AccountAge18
    check 
    (Account_Age > 18);    -- 插入年龄必须大于18

   SQL Server报一下谬误:

消息 547,级别 16,状态 0,第 1 行
ALTER TABLE 语句与 CHECK 约束"CN_AccountAge18"冲突。该冲突发生于数据库"Nx",表"dbo.Account", column 'Account_Age'。

   那时候我们换一种模式去实践:

alter table Account
    WITH NOCHECK
    add constraint CN_AccountAge18
    check 
    (Account_Age > 18);    -- 插入年龄必须大于18

   以上代码就可以成功执行,并且只有将来添加的数据具有约束,在此之前增长的不符合条件的数量记录仍然存在。

   6.2临时禁用已存在的束缚

   当咱们需要从另一数据库中导入数据到表中,而表中已创制了束缚的时候,可能会存在一些数码和规则不兼容。当然有一个解决模式是先删除约束,添加需要的多寡,然后WITH
NOCHECK在添加归来。然而如此做太难为了。我们不需要这样做。大家可以拔取名为NOCHECK的选项来运行ALTER语句,这样就可知撤除需要的羁绊。

  先来看看上节中创建的那多少个约束:

alter table Account
    add constraint CN_AccountAge18
    check 
    (Account_Age > 18);    -- 插入年龄必须大于18

   要撤消上述约束可以如此来:

Alter Table Account
    NOCHECK
    constraint CN_AccountAge18

  执行命令:

  insert into Account values (25,'取消了约束',17)

  执行成功,成功添加了一条龙数据。

  留意到又可以向表中插入格式不兼容的数据了。

  这里要证实下,如下知道一个羁绊是否是启用如故禁用呢?sp_helpconstraint命令,当我们举办sp_helpconstraint的时候,会有一列status_enabled显示该约束的启用意况:

  sp_helpconstraint Account

  图片 3

   留意到status_enabled名列Disabled表明是禁用的情致。

  当要启用约束时,只需要用将语句中的NO CHECK替换为CHECK就足以了:

Alter Table Account
    CHECK
    constraint CN_AccountAge18

   执行之后,约束又启用了:再来sp_helpconstraint看下:

  图片 4

   留意到status_enabled列变成了Enabled。

  status_enabled的二种情景如下:

  Enabled:启用;

  Disabled:禁用;

DEFAULT约束添加规则

1、若在表中定义了默认值约束,用户在插入新的数码行时,假若该行没有点名数量,那么系统将默认值赋给该列,借使大家不设置默认值,系统默认为NULL。

2、倘若“默认值”字段中的项替换绑定的默认值(以不带圆括号的形式显得),则将唤起您拨冗对默认值的绑定,并将其替换为新的默认值。

3、若要输入文本字符串,请用单引号 (‘)
将值括起来;不要拔取双引号
(“),因为双引号已保存用于带引号的标识符。

4、若要输入数值默认值,请输入数值并且不要用引号将值括起来。

5、若要输入对象/函数,请输入对象/函数的称号并且毫不用引号将名称括起来。

1、主键约束

   主键是每行的唯一标识符,仅仅经过它就能规范定位到一行,其中主键列在方方面面表中无法有再一次,必须带有唯一的值(不可能为NULL)。由于主键在关周密据库中的重要性,由此它是所有键和束缚中最要紧的。

   下边的话说主键的创制格局

  1、在创立表的时候成立主键约束。

create table customer
(
    customerId        int identity    not null
        primary key,  --创建主键约束
    CustomerName    nvarchar(30)    not null
);

  如何,非凡简单吧!

  2、在已存在的表上创造主键约束

  现在一经已经存在了一张表,不过还从未主键约束:

alter table person
    add constraint PK_Employee_Id  --外键名称
    primary key(personId)  --personId 字段名

  alter名称告诉SQLServer如下信息:

  1、添加了一部分情节到表中(也可以去除表中的少数内容)

  2、添加了咋样内容(一个羁绊)

  3、对约束的命名(允许将来直接访问约束)

  4、约束的品类(主键约束)

  5、约束应用于哪个列。

  3、复合主键的创造

  要是实际Management
Studio中,创造复合主键,只需要按住Ctrl键,选中多个列,然后设置为主键就OK了,分外简单。上边首要讲述使用T-SQL创立复合主键的主意:

ALTER TABLE 表名 WITH NOCHECK ADD 
CONSTRAINT [PK_表名] PRIMARY KEY NONCLUSTERED 
( 
[字段名1], 
[字段名2] 
) 

  在多对多交换中,平日会有一张表来描述其他两张表的涉及,就以此读者和书为例子:

图片 5

ALTER TABLE ReaderAndBook 
ADD 
CONSTRAINT [PK_ReaderAndBook] PRIMARY KEY NONCLUSTERED 
( 
ReaderId, 
BookId 
) 

图片 6

动用SSMS数据库管理工具添加DEFAULT约束

1、连接数据库,采纳数据表-》右键点击-》拔取设计。

图片 7

2、在表设计窗口中-》采纳数据列-》在列属性窗口中找到默认值或绑定-》输入默认值(注意默认值的数据类型和输入格式)。

图片 8

3、点击保存按钮(或者ctrl+s)-》刷新表-》再度打开表查看结果。

图片 9

2、外键约束

  外键既能确保数据完整性,也能显示表之间的涉及。添加了外键之后,插入引用表的笔录要么必须被引用表中被引用列的某条记下匹配,要么外键列的值必须设置为NULL。

  外键和主键不同等,每个表中的外键数目不限定唯一性。在各种表中,每一有-~253个外键。唯一的范围是一个列只好引用一个外键。一个列可以被五个外键引用。

  1、创造表的时候创造外键

图片 10

create table orders
(
    orderId        int identity    not null
        primary key,
    customerId    int                not null
        foreign key references customer(customerId)  --约束类型-外键-引用表(列名)
);

图片 11

  2、在已存在的表中添加一个外键

  假若上边的代码去掉了充裕外键行,那么可以挥洒代码如下:

alter table orders
    add constraint FK_Orders_CustomerId        --添加约束 名称
        foreign key (customerId)    references customer(customerId)    --外键约束,外键列名,被引用列名

  刚添加的羁绊和以前增长的牢笼一样生效,假使某行引用customerId不设有,那么就不允许把该行添加到Orders表中。

  3、级联动作

  外键和另外类型键的一个关键区别是:外键是双向的,即不仅是限制子表的值必须存在于父表中,还在每一遍对父表操作后检查子行(这样制止了孤行)。SQLServer的默认行为是在子行存在时“限制”父行被去除。不过,有时会活动删除任何借助的记录,而不是预防删除被引用的记录。同样在革新记录时,可能希望借助的笔录自动引用刚刚更新的记录。相比少见的场所是,你恐怕希望将引用行改变为某个已知的动静。为此,可以采纳将凭借行的值设置为NULL或者相当列的默认值。

  这种进行活动删除和自动更新的历程称为级联。这种过程,特别是剔除过程,能够经过几层的来说关系(一条记下依赖于另一条记下,而这另一条记下又凭借其他记录)。在SQLServer中实现级联动作需要做的就是修改外键语法-只需要在加上前边加上ON子句。例如:

alter table orders
    add constraint FK_Orders_CustomerId        --添加约束 名称
        foreign key (customerId)    references customer(customerId)    --外键约束,外键列名,被引用列名
        on update     no action    --默认  修改时不级联更新子表
        on delete     cascade      --删除时级联删除依赖行

  当在进展级联删除时,假设一个表级联了另一个表,而另一个表又级联了其它表,这种级联会从来下去,不受限制,这实质上是级联的一个饮鸩止渴之处,很容易一个不小心删掉大量多少。

  级联动作除了no action,cascade之外,还有set null和set
default。后六个是在SQLServer2005中引入的,假若要配合到SQLServer2000的话,要避免采取这五个级联动作。可是他们的才做是非凡简单的:假使进行更新而改变了一个父行的值,那么子行的值将被设置为NULL,或者安装为该列的默认值(不管SET
NULL依旧SET DEFAULT)。

  4、外键其他地方的考虑

    外键中的之唯有入选可能的挑选:

    1、在列中填充与被引用表中的照应列相匹配的值。

      通过定义引用列为NOT
NULL,可以使外键完全是必须的(即用户增长数据时务必引用表中务必有相匹配的一行数据)。

    2、不填充任何值,而使该值为NULL。

      允许引用列有NULL值时,用户能够选取不提供值-即便在被引用表没有与NULL值匹配的行,依旧允许插入。

当表结构已存在时

第一判断表中是否存在默认约束,假设存在则先删除默认约束再添加,倘若不存在则直接助长。

语法:

use 数据库
go
–判断默认约束是否留存,假诺存在则先删除,如果不存在则直接抬高
if exists(select * from sysobjects where
name=约束名)
alter table 表名 drop constraint
约束名;
go
–给指定列添加默认约束
alter table 表名 add constraint 约束名
default(约束值) for 列名;
go

示例:

use [testss]
go
–判断默认约束是否留存,如果存在则先删除,假设不设有则直接助长
if exists(select * from sysobjects where
name=’defalut_height’)
alter table [testss].[dbo].[test1]
drop constraint defalut_height;
go
–给指定列添加默认约束
alter table [testss].[dbo].[test1]
add constraint defalut_height default(160) for height;
go

图片 12

图片 13

9、如何拔取

  经过上述的就学,对于数据完整性,你会发现有很多种可以采纳,那么咋样抉择合适的自律呢?

限制 优点 缺点
约束

快速

可以引用其他列

在命令执行前发生

遵循ANSI标准

必须对每个表重新定义

不能引用其他表

不能绑定到数据类型

规则

独立的对象

可重用

可以绑定到数据类型

命令执行前发生

稍慢

不能跨列使用

不能引用其他表

实际上只用于向后兼容

默认值

非常灵活

可以引用其他列或其他表

可以通过.NET引用SQL Server之外的其他信息

在命令执行之后发生

系统开销很大

  假设要促成更结实的逻辑模型以及常见运用用户自定义数据类型,则相似采用规则和默认值。在那种状态下规则和默认值可以提供许多功效,容易管理,而不用太多的编程开销。

  唯有在不可能选取约束时拔取触发器。和约束一样,他们被增大到表中,而且必须对创设的每个表重新定义。好的下边是触发器几乎可以做数据完整性方面的任何操作。实际上再没有出现外键时,他们常被当作外键的替代品。

  而在任何情状下,应将约束作为数据完整性解决方案的选用。它们执行进度快,而且容易创设。他们的败笔是效益有限(除了外键约束,都不可以引用其他表),而且对于通用约束逻辑来说,需要五遍次地重复定义。

8、触发器

  触发器也可以用于落实数据完整性,这些情节相比较多,新建一篇著作叙述。

4、CHECK约束  

  CHECK约束约束可以和一个列关联,也足以和一个表关联,因为它们得以检查一个列的值相对于此外一个列的值,只要这多少个列都在同一个表中以及值是在更新或者插入的相同行中。CHECK约束还足以用来检查列值组合是否满意某一个正规。

  可以像使用where子句一样的条条框框来定义CHECK约束。CHECK约束规范的言传身教如下:

目标 SQL
限制Month列为合适的数字 BETWEEN 1 AND 12
正确的SSN格式 LIKE'[0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9][0-9][0-9]’
限制为一个快递公司的特定列表 IN(‘UPS’,’Fed Ex’,EMS’)
价格必须为正数 UnitPrice >= 0
引用同一行中的另外一列 ShipDate >= OrderDate

  下面给出的列表只是一小部分,而标准实际上市无限多的。几乎所有可以放置where子句的尺度都可以停放该约束中。而且和另外选项(规则和触发器)比较,CHECK约束执行进度更快。

  在已存在的表中添加一个CHECK约束:

alter table Account
    add constraint CN_AccountAge
    check 
    (Account_Age > 18);    -- 插入年龄必须大于18

  假如这时视图添加一条不知足的笔录,将报如下错误:

  insert into Account values (22,'洪',17)

消息 547,级别 16,状态 0,第 1 行
INSERT 语句与 CHECK 约束"CN_AccountAge"冲突。该冲突发生于数据库"Nx",表"dbo.Account", column 'Account_Age'。
语句已终止。

二、约束命名

  在读书约束在此以前,首先来了然下为约束命名需要专注哪些地点。

  SQLServer在我们不提供名称时,会自动创制名称,可是由系统活动创设的名目并不是专程有用。

  例如,系统生成的主键名称或者是如此的:PK_Employees_145C0A3F。 

  PK代表主键(primary
key),Employees代表在Employees表中,而剩下的“145C0A3F”部分是为了保险唯一性而自由变化的值。唯有经过脚本创制才会得到这种值,假如是经过Managerment
Studio创制表,那么就直接是PK_Employees。

  对于系统自动生成的Check约束名称如:CK_Customers_22AA2996。CK代表这是一个Check约束,Customers代表是在Customers表中,前边的22AA2996依然一个随机数。假若一个表中有多少个Check约束,则命名可能如下:

  CK_Customers_22AA2996

  CK_Customers_25869641

  CK_Customers_267ABA7A

  假设您需要修改这多少个约束其中的一个,那么你很难识别那几个约束到底是哪一个。

  由此,为了可以一眼看上去就驾驭这多少个约束是用来干什么的,我们理应选拔一种简单明了的短语来展开命名。

  例如要确保某一列电话号码格式正确的封锁,我们可以使用命名CK_Customers_PhoneNo这样的短语来定名。

  总而言之命名要到位以下几点:

  1、一致性

  2、通俗易懂

  3、满足以上两个标准的情形下简化名称。

5、DEFAULT约束

  和享有约束一样,DEFAULT约束也是表定义的一个组成部分,它定义了当插入的新行对于定义了默认约束的列未提供对应数额时该怎么做。可以定义它为一个字面值(例如,设置默认薪水为0,或者安装字符串列为”UNKNOWN”),或者某个系统值(getdate())。

  对于DEFAULT约束,要询问以下多少个性状:

  1、默认值只在insert语句中应用-在update语句和delete语句中被忽略。

  2、倘若在insert语句中提供了任意值,这就不利用默认值。

  3、尽管没有提供值,那么总是采纳默认值。

  值得注意的是,update命令的条条框框由一个见仁见智,假如呈现表达使用默认值就是不同。可以因而选用首要字DEFAULT表示更新的值设置为默认值。

  5.1在创造表时概念DEFAULT约束:

图片 14

create table person
(
    person_id int identity not null
        primary key,
    person_name nvarchar(30) not null
        default '无名氏',
    person_age int not null
)

图片 15

  在履行语句后:

insert into person (person_age) values(24)

  表中被插入一条记下如下:

  图片 16

   5.2在已存在的表上添加DEFAULT约束:

alter table person
    add constraint CN_DefaultName
    default    '无名氏' for person_name

三、键约束

7、规则和默认值

  规则和默认值的利用要早于CHECK和DEFAULT约束。他们是较老的SQL
Server备用约束的一局部,当然也不是从未有过亮点。自7.0版本之后,MicroSoft列出规则和默认值只是为了向后非凡,而不准备在随后继续协助这多少个特性。因而对此生成新代码时,应该使用约束。

  规则、默认值与约束的本质区别是:约束是一个表的表征,本身没有存在模式,而平整和默认值是表和我的实在目的,本身存在。约束是在表定义中定义的,而平整和默认值是单独定义,然后”绑定到”表上。

  规则和默认值的单独对象特性使得它们可以在选择时毫无再行定义。实际上,规则和默认值不制止被绑定到表上,它们也得以绑定到数据类型上。

  7.1规则

   规则和CHECK约束十分相像。它们之间的唯一区别是规则每回只好效能于一个列。可以将一如既往规则分别绑定到一个表中的多少个列,可是规则分别功能于每个列,根本不会发现到此外列的存在。像QtyShipped

<=
QtyOrdered这样的自律不适用于规则(它引用两个列),而LIKE([0-9][0-9][0-9])这样的定义适用于规则。

  概念规则:

  下边定义一个规则,这样就可以率先看到有别于所在:

CREATE RULE Age18Rule
    AS @Age > 18  

  这里相比的是一个变量,不管被检查的列是何等值,这些值将用于替换@Age。由此在这一个示例中,规则所绑定的另外列的值都不可以不超出18。

  到目前停止,只是创制了一个平整,但以此规则还没对任何表的另外列起效能,要激活这多少个规则需要运用一个存储过程:sp_bindrule。

  将规则Age18绑定到表person的person_age列:

  EXEC sp_bindrule 'Age18Rule','person.person_age';

  此时,假若我们实践不满足规则的插入操作:

insert into person values ('绑定规则',17)

   将赶回如下报错音信:

消息 513,级别 16,状态 0,第 1 行
列的插入或更新与先前的 CREATE RULE 语句所指定的规则发生冲突。该语句已终止。冲突发生于数据库 'Nx',表 'dbo.person',列 'person_age'。
语句已终止。

  很强烈,规则已经生效。

  要特别注意的是,在绑定往日,规则与此外表,任何列都不曾关系,由此在绑定的时候,第二个参数要加.指定表名与列名(tablename.column)。

  铲除绑定规则:

  当我们需要在一个列上解除绑定规则的时候,只要举行sp_unbindrule

  删除刚才绑定的条条框框:

EXEC sp_unbindrule 'person.person_age';

  这时候,执行方才的插入操作,就不会报错了。

  除去规则:

  假使希望将规则从数据库中干净删除,那么可以在表中采取特别领悟的DROP语法。

DROP RULE <rule name>

  如删减刚才制造的这条规则:

DROP RULE Age18Rule

  7.2默认值

  默认值类似于DEFAULT。实际上默认值-DEFAULT约束的关联与规则-CHECK约束的关联大多。区别在于它们被追加到表中的法子和对用户自定义数据类型的默认值(是目的,而不是封锁)支持。

  定义默认值的语法和概念规则类似:

  CREATE DEFAULT <default_name>
  AS <default value>

  创立默认值:

  因而,要是要为Age定义一个值为0的默认值:

CREATE DEFAULT AgeDefault
AS 0

  绑定默认值:

  同样,即使不绑定到一个对象上,则默认值是不起功用的。要绑定的话,使用存储过程sp_bindefault。

  EXEC sp_bindefault 'AgeDefault','person.person_age';

  要从表中解决默认值的绑定,使用sp_unbindefault:

  sp_unbindefault 'person.person_age';

  删除默认值:

  倘诺要从数据库中到底删除一个默认值,则足以应用DROP语法,与删除规则一样:

  DROP DEFAULT AgeDefault

  7.3规定哪些表和数据类型使用给定的规则或默认值

  假若愿意删除或者修改规则或默认值。那么你能够先看看哪些表和数据类型在应用它们。SQL
Server依然采纳系统存储过程解决这么些题目。这些蕴藏过程是sp_depends。其语法如下所示:

  EXEC sp_depends <object name>

  sp_depends提供了借助于您所查询对象的兼具目标列表。

留下评论

网站地图xml地图