第8章数据完整性_第1页
第8章数据完整性_第2页
第8章数据完整性_第3页
第8章数据完整性_第4页
第8章数据完整性_第5页
已阅读5页,还剩44页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第8章数据完整性

《数据库技术与应用-SQLServer2008》8.1使用规则实

施数据完整

性8.2使用默认值

实施数据完整性8.3使用约束实施数据完整性.8.1使用规则实施数据完整性 1.数据完整性数据完整性是防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作或错误信息而提出的。数据完整性主要有以下3种类型:实体完整性(EntityIntegrity)参照完整性(ReferentialIntegrity)用户自定义的完整性(User-definedIntegrity)在SQLServer2008中提供了完善的数据完整性机制,可以通过各种规则、默认、约束和触发器等数据库对象来保证数据的完整性。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.1使用规则实施数据完整性 2.规则规则(Rule)是数据库中对存储在表的列或用户定义数据类型中的值的规定和限制。规则是单独存储的独立的数据库对象。规则与其作用的表或用户定义数据类型是相互独立的,即表或用户定义对象的删除、修改不会对与之相连的规则产生影响。规则的管理主要包括创建、查看、绑定、松绑和删除等操作。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.1使用规则实施数据完整性 8.1.1创建规则

创建规则只能通过Transact-SQL的CREATERULE语句,而不能使用SQLServer管理平台工具创建。CREATERULE语法格式如下:CREATERULErule_nameAScondition_expression其中condition_expression子句是规则的定义。condition_expression子句可以是能用于WHERE条件子句的任何表达式,它可以包含算术运算符、关系运算符和谓词(如IN、LIKE、BETWEEN等)。注意:ondition_expression子句中的表达式的变量必须以字符“@”开头,通常情况下,该变量的名称应与规则所关联的列或用户定义的数据类型具有相同的名字。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.1使用规则实施数据完整性 8.1.1创建规则

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-1】创建雇佣日期规则hire_date_rule。

CREATERULEhire_date_rule

AS@hire_date>='1980-01-01'and@hire_date<=getdate()

【例8-2】创建性别规则sex_rule。CREATERULEsex_ruleAS@sexin('男','女')8.1使用规则实施数据完整性 8.1.1创建规则

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-3】创建评分规则grade_rule。

CREATERULEgrade_rule

AS@valuebetween1and100

【例8-4】创建字符规则my_character_rule。CREATErulemy_character_ruleAs@valuelike'[a-f]%[0-9]'8.1使用规则实施数据完整性 8.1.2查看规则

使用系统存储过程sp_helptext语句可查看某个规则的定义信息,或在SQLServer管理平台中,点击指定数据库下面的“可编程性”,选中“规则”后找到要查看的规则名称,单击鼠标右键,在弹出的菜单中选择“编写规则脚本为”→“CREATE到”→“新查询编辑器窗口”来查看规则。sp_helptext语法如下:sp_helptext[@objname=]'name'其中[@objname=]'name'子句指明对象的名称,用Sp_helptext存储过程查看的对象可以是当前数据库中的规则、默认值、触发器、视图或未加密的存储过程。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.1使用规则实施数据完整性 8.1.2查看规则

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-5】创建查看规则hire_date_rule的文本信息。EXECUTEsp_helptexthire_date_rule运行结果如图8-1所示:8.1使用规则实施数据完整性 8.1.3规则的绑定与松绑

创建规则后,规则只是一个存在于数据库中的对象,并未发生作用。需要将规则与数据库表或用户定义对象联系起来,才能达到创建规则的目的。联系的方法称为绑定。绑定就是指定规则作用于哪个表的哪一列或哪个用户定义数据类型。当向绑定了规则的列或绑定了规则的用户定义数据类型的所有列中插入或更新数据时,新的数据必须符合规则。表的一列或一个用户定义数据类型只能与一个规则相绑定,而一个规则可以绑定多个对象。解除规则与对象的绑定称为松绑。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.1使用规则实施数据完整性 1.用存储过程sp_bindrule绑定规则

系统存储过程sp_bindrule可以绑定一个规则到表的一个列或一个用户定义数据类型上。其语法格式如下:sp_bindrule[@rulename=]'rule',[@objname=]'object_name'[,[@futureonly=]'futureonly']8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.1使用规则实施数据完整性 8.1.3规则的绑定与松绑

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-6】将例8-1创建的规则hire_date_rule绑定到employee表的hire_date列上。EXECsp_bindrulehire_date_rule,'employee.hire_date'运行结果如下:已将规则绑定到表的列。【例8-8】创建绑定例8-2创建的规则sex_rule到employee表的字段sex。EXECsp_bindrulesex_rule,'employee.sex'运行结果如下:已将规则绑定到表的列。8.1使用规则实施数据完整性 2.用系统存储过程sp_unbindrule解除规则的绑定

如果不再使用规则,可以解除规则。使用系统存储过程sp_unbindrule语句可解除规则与列或用户定义数据类型的绑定,其语法格式如下:sp_unbindrule[@objname=]'object_name'[,[@futureonly=]'futureonly']参数的含义与sp_bindrule相同。其中,'futureonly'选项指定现有的由此用户定义数据类型定义的列仍然保持与此规则的绑定。如果不指定此项,所有由此用户定义数据类型定义的列也将随之解除与此规则的绑定。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.1使用规则实施数据完整性 8.1.3规则的绑定与松绑

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-9】解除例8-6和例8-7绑定在employee表的hire_date列和用户定义数据类型pat_char上的规则。EXECsp_unbindrule'employee.hire_date'运行结果如下:已解除了表列与规则之间的绑定。EXECsp_unbindrulepat_char,'futureonly'运行结果如下:已解除了数据类型与规则之间的绑定。8.1使用规则实施数据完整性 8.1.4删除规则当不再需要规则时,可以在SQLServer管理平台中选择规则对象,单击右键,从快捷菜单中选择“删除”选项删除规则,也可使用DROPRULE语句删除当前数据库中的一个或多个规则。其语法格式如下:DROPRULE{rule_name}[,…n]注意:在删除一个规则前,必须先将与其绑定的对象解除绑定,否则,在执行删除语句时会出错。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-10】删除例8-1和8-2中创建的规则。DROPRULEsex_rule,hire_date_rule8.2使用默认值实施数据完整性 1.默认值默认值(Default)是用户输入记录时向没有指定具体数据的列中自动插入的数据。默认值对象与CREATETABLE或ALTERTABLE语句操作表时用默认约束指定的默认值功能相似,两者的区别类似于规则与检查约束在使用上的区别。默认值对象可用于多个列或用户定义数据类型,它不会因数据列或用户定义数据类型的修改、删除等操作而受影响。表的一列或一个用户定义数据类型只能与一个默认值相绑定。默认值对象主要包括创建、查看、绑定、松绑和删除操作。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.2使用默认值实施数据完整性 8.2.1创建默认值

和规则一样,默认值对象的创建只能使用Transact-SQL语句CREATEDEFAULT来创建,其语法格式如下:CREATEDEFAULTdefault_nameASconstant_expression其中,constant_expression是默认值的定义,为一常量表达式,可以使用数学表达式或函数等,但不能包含表的列名或其他数据库对象。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.2使用默认值实施数据完整性 8.2.1创建默认值

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-11】创建生日默认值birthday_defa。CREATEDEFAULTbirthday_defaAS'1978-1-1'【例8-12】创建当前日期默认值today_defa。CREATEDEFAULTtoday_defaASgetdate()上述语句创建一个today_defa默认值,其常量表达式是一个内置函数,表示自动填入的默认值是当前系统日期。8.2使用默认值实施数据完整性 8.2.2查看默认值

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性使用sp_helptext系统存储过程可以查看默认值的细节。【例8-13】查看默认值today_defa。EXECsp_helptexttoday_defa运行结果如图8-2所示。8.2使用默认值实施数据完整性 8.2.3默认值的绑定与松绑

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性创建默认值后,默认值仅仅只是一个存在于数据库中的对象,并未发生作用。同规则一样,需要将默认值与数据库表的列或用户定义数据类型进行绑定,这样才能将创建的默认值应用到数据列或用户定义的数据类型中。8.2使用默认值实施数据完整性 1.用系统存储过程sp_bindefault绑定默认值

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性系统存储过程sp_bindefault可以绑定一个默认值到表的一个列或一个用户定义数据类型上。其语法格式如下:sp_bindefault[@defname=]'default',[@objname=]'object_name'[,[@futureonly=]'futureonly']8.2使用默认值实施数据完整性 1.用系统存储过程sp_bindefault绑定默认值

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-14】绑定默认值today_defa到employee表的hire_date列上。EXECsp_bindefaulttoday_defa,'employee.hire_date'运行结果如下:已将默认值绑定到列。8.2使用默认值实施数据完整性 2.用系统存储过程sp_unbindefault解除默认值的绑定

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性系统存储过程sp_unbindefault可以解除默认值与表的列或用户定义数据类型的绑定,其语法格式如下:sp_unbindefault[@objname=]'object_name'[,[@futureonly=]'futureonly']8.2使用默认值实施数据完整性 2.用系统存储过程sp_unbindefault解除默认值的绑定8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-15】解除默认值today_defa与表employee的hire_date列的绑定。EXECsp_unbindefault'employee.hire_date'运行结果如下:已解除了表列与其默认值之间的绑定。注意:如果列同时绑定了一个规则和一个默认值,那么默认值应该符合规则的规定。不能绑定默认值到一个用CREATETABLE或ALTERTABLE语句创建或修改表时用DEFAULT选项指定了默认值的列上。8.2使用默认值实施数据完整性 8.2.4删除默认值

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性当不再需要定义默认值时,可以在SQLServer管理平台中选择默认值对象,单击右键,从快捷菜单中选择“删除”选项删除默认值,也可以使用DROPDEFAULT语句删除当前数据库中的一个或多个默认值。其语法格式如下:DROPDEFAULT{default_name}[,…n]注意:在删除一个默认值前必须先将与其绑定的对象解除绑定,否则,在执行删除语句时会出错。【例8-16】删除生日默认值birthday_defa。DROPDEFAULTbirthday_defa8.3使用约束实施数据完整性 1.约束约束(Constraint)是SQLServer提供的自动保持数据库中数据完整性的一种机制,它定义了可输入表或表的单个列中的数据的限制条件。使用约束优先于使用触发器、规则和默认值。约束独立于表结构,作为数据库定义部分在CREATETABLE语句中声明,可以在不改变表结构的基础上,通过ALTERTABLE语句添加或删除。当表被删除时,表所带的所有约束定义也随之被删除。在SQLServer中有6种约束:主键约束、外键约束、唯一性约束、检查约束、默认约束和非空值约束。其中非空值约束已在第5章中做了详细介绍,本节只介绍其他5种约束。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.1主键约束

和规则一样,默认值对象的创建只能使用Transact-SQL语句CREATEDEFAULT来创建,其语法格式如下:CREATEDEFAULTdefault_nameASconstant_expression其中,constant_expression是默认值的定义,为一常量表达式,可以使用数学表达式或函数等,但不能包含表的列名或其他数据库对象。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.1主键约束

表的一列或几列组合的值在表中唯一地指定一行记录,这样的一列或多列称为表的主键(PrimaryKey,PK),通过它可强制表的实体完整性。主键不允许为空值,且不同两行的键值不能相同。表中可以有不止一个键唯一标识行,每个键都称为候选键,只可以选其中一个候选键作为表的主键,其他候选键称作备用键。表本身并不要求一定要有主键,但应该养成给表定义主键的良好习惯。在规范化的表中,每行中的所有数据值都完全依赖于主键。当创建或更改表时可通过定义主键约束来创建主键。如果一个表的主键由单列组成,则该主键约束可定义为该列的列约束。如果主键由两个以上的列组成,则该主键约束必须定义为表约束。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.1主键约束

定义列级主键约束的语法格式如下:[CONSTRAINTconstraint_name]PRIMARYKEY[CLUSTERED|NONCLUSTERED]定义表级主键约束的语法格式如下:[CONSTRAINTconstraint_name]PRIMARYKEY[CLUSTERED|NONCLUSTERED]{(column_name[,…n])}8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.1主键约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-17】在Sales数据库中创建customer表,并声明主键约束。CREATETABLESales.dbo.customer(customer_idbigintNOTNULLIDENTITY(0,1)PRIMARYKEY,customer_namevarchar(50)NOTNULL,linkman_namechar(8),addressvarchar(50),telephonechar(12)NOTNULL)8.3使用约束实施数据完整性 8.3.1主键约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-18】创建一个产品信息表goods1,将产品编号goods_id列声明为主键。CREATETABLEgoods1(goods_idchar(6)NOTNULL,goods_namevarchar(50)NOTNULL,classification_idchar(6)NOTNULL,unit_pricemoneyNOTNULL,stock_quantityfloatNOTNULL,order_quantityfloatNULLCONSTRAINTpk_p_idPRIMARYKEY(goods_id))ON[PRIMARY]8.3使用约束实施数据完整性 8.3.1主键约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-19】根据商品销售的时间和商品类别来确定销售的商品的数量。CREATETABLEg_order(good_typeint,order_timedatetime,order_numint,CONSTRAINTg_o_keyPRIMARYKEY(good_type,order_time))本例由两列组合成主键g_o_key,使用表约束来定义。8.3使用约束实施数据完整性 8.3.2外键约束

外键约束定义了表与表之间的关系。通过将一个表中一列或多列添加到另一个表中,创建两个表之间的连接,这个列就成为第二个表的外键(ForeignKey,FK),即外键是用于建立和加强两个表数据之间的连接的一列或多列,通过它可以强制参照完整性。当一个表中的一列或多列的组合和其他表中的主键定义相同时,就可以将这些列或列的组合定义为外键,并设定与它关联的表或列。这样,当向具有外键的表插入数据时,如果与之相关联的表的列中没有与插入的外键列值相同的值时,系统会拒绝插入数据。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.2外键约束

定义表级外键约束的语法格式如下:[CONSTRAINTconstraint_name]FOREIGNKEY(column_name[,…n])REFERENCESref_table[(ref_column[,…n])][ONDELETE{CASCADE|NOACTION}][ONUPDATE{CASCADE|NOACTION}]][NOTFORREPLICATION]定义列级外键约束的语法格式如下:[CONSTRAINTconstraint_name][FOREIGNKEY]REFERENCESref_table[NOTFORREPLICATION]8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.2外键约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-20】创建一个订货表sell_order1,与例8-18创建的产品表goods1相关联。CREATETABLEsell_order1(order_id1char(6)NOTNULL,goods_idchar(6)NOTNULL,employee_idchar(4)NOTNULL,customer_idchar(4)NOTNULL,transporter_idchar(4)NOTNULL,order_numfloatNULL,discountfloatNULL,order_datedatetimeNOTNULL,send_datedatetimeNULL,arrival_datedatetimeNULL,costmoneyNULL,CONSTRAINTpk_order_idPRIMARYKEY(order_id1),FOREIGNKEY(goods_id)REFERENCESgoods1(goods_id))8.3使用约束实施数据完整性 8.3.3唯一性约束

唯一性(unique)约束指定一个或多个列的组合的值具有唯一性,以防止在列中输入重复的值,为表中的一列或者多列提供实体完整性。唯一性约束指定的列可以有NULL属性。主键也强制执行唯一性,但主键不允许空值,故主键约束强度大于唯一约束。因此主键列不能再设定唯一性约束。定义列级唯一性约束的语法格式如下:[CONSTRAINTconstraint_name]UNIQUE[CLUSTERED|NONCLUSTERED]8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.3唯一性约束

唯一性约束应用于多列时的定义格式如下:[CONSTRAINTconstraint_name]UNIQUE[CLUSTERED|NONCLUSTERED](column_name[,…n])参数的含义与主键约束的参数含义相同。唯一性约束与主键约束的区别如下:(1)唯一性约束用于非主键的一列或列组合。(2)一个表可定义多个唯一性约束,只能定义一个主键约束。(3)唯一性约束可用于定义允许空值的列,而主键约束不能用于定义允许空值的列。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.3唯一性约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-22】创建goods2表,使goods_name具有唯一性约束。CREATETABLEgoods2(goods_idchar(6)NOTNULLPRIMARYKEY,goods_namevarchar(50)NOTNULLCONSTRAINTu_goods_nameUNIQUENONCLUSTERED,classification_idchar(6)NOTNULL,unit_pricemoneyNOTNULL,stock_quantityfloatNOTNULL,order_quantityfloat)8.3使用约束实施数据完整性 8.3.3唯一性约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-23】定义一个员工信息表employees,其中员工的身份证号emp_cardid列具有唯一性。CREATETABLEemployees(emp_idchar(8),emp_namechar(10),emp_cardidchar(18),CONSTRAINTpk_emp_idPRIMARYKEY(emp_id),CONSTRAINTuk_emp_cardidUNIQUE(emp_cardid))本例创建了表employees,同时显式地定义了表级主键约束pk_emp_id和唯一性约束uk_emp_cardid。8.3使用约束实施数据完整性 8.3.4检查约束

检查(Check)约束对输入列或整个表中的值设置检查条件,以限制输入值,保证数据库的数据完整性。当对具有检查约束列进行插入或修改时,SQLServer将用该检查约束的逻辑表达式对新值进行检查,只有满足条件(逻辑表达式返回TRUE)的值才能填入该列,否则报错。可为每列指定多个CHECK约束。例如,在employee表中,可以为sex(性别)列定义检查约束,其逻辑表达式为:sex='男'ORsex='女'或sexIN('男','女')从而限制该列只能输入“男”、“女”两值之一。检查约束的逻辑表达式可以使用当前表的多列。例如,可以检查约束的逻辑表达式为:DATEDIFF(year,Birth_Date,Hire_Date)>18该约束要求员工的雇用日期和出生日期这两个日期数据在年份上的差距大于18(即确保不雇用18岁以下员工)。此时,该检查约束必须定义为表级。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.4检查约束

定义检查约束的语法格式如下:[CONSTRAINTconstraint_name]CHECK[NOTFORREPLICATION](logical_expression)各选项的含义如下:(1)NOTFORREPLICATION:指定检查约束在把从其他表中复制的数据插入到表中时不发生作用。(2)logical_expression:指定检查约束的逻辑表达式。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实施数据完整性 8.3.4检查约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-24】更改表employee2以添加未验证检查约束。ALTERTABLEemployee2WITHNOCHECKADDCONSTRAINTCK_AgeCHECK(DATEDIFF(year,Birth_Date,Hire_Date)>18)本例向employee2表添加表级检查约束以限制员工的聘用年龄必须大于18岁。利用WITHNOCHECK来防止对现有行验证约束,从而允许在存在违反约束的值的情况下添加该约束。8.3使用约束实施数据完整性 8.3.4检查约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-25】创建一个订货表orders,保证各订单的订货量必须不小于10。CREATETABLEorders(order_idchar(8),p_idchar(8),p_namechar(10),quantitysmallintCONSTRAINTchk_quantityCHECK(quantity>=10),CONSTRAINTpk_orders_idPRIMARYKEY(order_id))本例为列quantity定义了列级检查约束,使其值必须大于等于10。8.3使用约束实施数据完整性 8.3.4检查约束

8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性【例8-26】创建transporters表并定义检查约束。CREATETABLEtransporters(transporter_idchar(4)NOTNULL,transport_namevarchar(50),linkman_namechar(8),addressvarchar(50),telephonechar(12)NOTNULLCHECK(telephoneLIKE'0[1-9][0-9][0-9]-[1-9][0-9][0-9][0-9][0-9][0-9][0-9]'ORtelephoneLIKE'0[1-9][0-9]-[1-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]'))注意:对计算列不能作为检查约束外的任何约束。8.3使用约束实施数据完整性 8.3.5默认约束

默认(Default)约束通过定义列的默认值或使用数据库的默认值对象绑定表的列,以确保在没有为某列指定数据时,来指定列的值。默认值可以是常量,也可以是表达式,还可以为NULL值。当给表列定义了Default约束后,在表中插入一条记录时,SQLServer会将该列的对应位置填入默认值。SQLServer推荐使用默认约束,而不使用默认值对象的方式来指定列的默认值。8.1使用规则实施数据完整性8.2使用默认值实施数据完整性8.3使用约束实施数据完整性8.3使用约束实

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论