完整性(二)

数据完整性理论(二)

● 规则

● 默认

1. 规则

规则(RULE)是一种数据库对象,作用是向表中的列插入数据时,指定该列接受数据值的范围。

特点:

1)规则要在insert和update语句之前给出。

2)规则与其作用的表是相互独立的,即表的删除、修改不会对与之相连的规则产生影响。

3)规则和约束可以同时使用,表的列可以有一个规则及多个CHECK 约束。

4)规则与CHECK 约束很相似。但CHECK 约束不能直接作用于用户自定义数据类型

一、创建规则

1.用CREATE RULE 命令创建规则

CREATE RULE 命令用于在当前数据库中创建规则,其语法如下:

CREATE RULE rule_name AS condition_expression

其中:

rule_name 是规则的名称

condition_expression 子句是规则的定义,它可以是能用于WHERE 条件子句中的任何表达式,可包含算术运算符、关系运算符和谓词(如IN、LIKE、BETWEEN 等)。 condition_expression 子句中的表达式必须以字符@ 开头

例1:创建年龄规则。

create rule age_rule as @age >= 10 and @age

create rule age_rule as @age between 10 and 50

例2:

create rule Sex_rule as @性别 in ('男','女') ----创建性别规则。

create rule Enter_date_rule

as @入学年份>='1953-01-01' and @入学年份

2.用Enterprise Manager 创建规则

在Enterprise Manager 的左侧窗格中,展开要创建规则的数据库(如:JXGL)目录。 在数据库的对象“规则”上面单击右键,此时出现一快捷菜单,从快捷菜单中单击“新建规则”菜单项,则会弹出“规则属性”对话框。

在此对话框中的“名称”对应的文本框中输入要创建的规则的名称(如:age_rule),在“文本”对应的文本框中输入规则的内容(即约束的条件)。

在输入完规则名称和规则的内容之后,单击“确定”按钮即完成规则的创建。

二、查看和修改规则

1.用Enterprise Manager 查看规则

选择要查看的规则,单击右键,从快捷菜单中选择“属性”选项,即会出现“规则属性”对话框,可以从中编辑规则的表达式。

2.用存储过程Sp_helptext 查看规则

其语法如下:sp_helptext [@objname =] 'name'其中,[@objname =] „name‟子句指明对象的名称

用Sp_helptext 存储过程查看的对象可以是当前数据库中的规则、默认、触发器、视图或未加密的存储过程。

如:查看名称为“age_rule”的规则内容。

EXEC sp_helptext 'age_rule'

3.修改规则的名称

可以通过Sp_rename 系统存储过程进行,也可以直接用右键单击要修改的规则,从快捷菜单中选择“重命名”菜单项,进行名称修改。

格式为: sp_rename ’ age_rule’,’nianling_rule’

三、规则的绑定与松绑

创建规则后,规则仅仅只是一个存在于数据库中的对象,并未发生作用。

需要将规则与数据库表或用户自定义对象联系起来,才能达到创建规则的目的。联系的方法称为“绑定”。

所谓绑定就是指定规则作用于哪个表的哪一列。

表的一列只能与一个规则相绑定,而一个规则可以绑定多个对象,这正是规则的魅力所在。

解除规则与对象的绑定称为“松绑”。

1. 用存储过程Sp_bindrule 绑定规则

存储过程Sp_bindrule 可以绑定一个规则到表的一个列或一个用户自定义数据类型上。 其语法如下:sp_bindrule [@rulename =] 'rule',[@objname =] 'object_name'[, 'futureonly']

各参数说明如下:(1)[@rulename =] 'rule' 指定规则名称。

(2)[@objname =] 'object_name' 指定规则绑定的对象。

(3)'futureonly„ 此选项仅在绑定规则到用户自定义数据类型上时才可以使用。

如:绑定规则age_rule 到学生表的字段年龄。

EXEC sp_bindrule 'age_rule', '学生表.年龄'

注:规则对已经输入表中的数据不起作用。

规则所指定的数据类型必须与所绑定的对象的数据类型一致,且规则不能绑定一个数

据类型为TEXT、IMAGE或TIMESTAMP 的列。

如果表的列与规则A 绑定,同时列又与规则B 绑定,则以规则B 为列的规则。 可以直接用一个新的规则来绑定列,而不需要先将其原来绑定的的规则解除,系统会

将旧规则覆盖。

2.用存储过程Sp_unbindrule 解除规则

存储过程Sp_unbindrule 可解除规则与列或用户自定义数据类型的绑定,其语法如下:sp_unbindrule [@objname =] 'object_name' [,'futureonly']

其中:„futureonly‟选项同绑定时一样,仅用于用户自定义数据类型,

如:要解除已绑定到学生表的字段年龄的规则age_rule。

EXEC sp_unbindrule '学生表.年龄'

3.用Enterprise Manager 管理规则的绑定

在相应的规则名称上面单击右键,从快捷菜单中选择“属性”选项

该对话框中的“绑定UDTs”按钮用于将规则绑定到用户自定义数据类型,“绑定列”按钮

用于将规则绑定到表的列。

4. 删除规则

操作1:用Enterprise Manager 删除规则

操作2:使用DROP RULE命令删除规则使用DROP RULE 命令删除当前数据库中的一个或多个规则。

其语法如下:DROP RULE {rule_name} [,...n]

注:在删除一个规则前必须先将与其绑定的对象解除绑定

如:删除age_rule规则,可执行以下命令:DROP RULE age_rule

2 。默认

默认(Default)也是一种数据库对象,与缺省约束的功能一样。用户插入记录时,在没有给出具体数据的字段中,系统会自动插入一个数据。

默认的管理与应用同规则有许多相似之处。

一、创建默认

用CREATE DEFAULT 命令创建默认其语法如下:CREATE DEFAULT default_name AS constant_expression

其中:

default_name是要创建的默认的名称

constant_expression 子句是默认的定义,该子句可以是数学表达式或函数,也可以包含表的列名或其它数据库对象。

如:创建性别默认sex_defa。

CREATE DEFAULT sex_defa as '男'

这样,当用户在输入记录数据时,未提供性别字段的值时,系统将自动默认其值为“男”。

二、查看和修改默认

1.用Enterprise Manager 查看默认

在Enterprise Manager 的左侧窗格中,展开相应的数据库(如:JXGL)目录

在数据库的对象“默认”上面单击,这时在右侧窗格中的任务板中即可看到已建立的各个默认的信息

在某个默认的名称上面单击右键,从快捷菜单中选择“属性”菜单项,即会出现“默认属性”对话框,可以从中编辑默认的值。

2.用存储过程SP_HELPTEXT 查看默认

使用SP_HELPTEXT存储过程可以查看默认的细节。

如:查看默认sex_defa。

EXEC SP_HELPTEXT sex_defa

3. 修改默认的名称

与修改规则名称的方法相同,可以用SP_RENAME存储过程,也可以在企业管理器的任务板窗口中直接改名。

格式为: sp_rename ’ sex _defa’,’ xingbie_defa’

三、默认的绑定与松绑

创建默认后,默认仅仅只是一个存在于数据库中的对象,并未发生作用。

同规则一样,需要将默认与数据库表或用户自定义对象绑定。

表的一列只能与一个默认相绑定,而一个默认可以绑定多个对象。

1.绑定默认xingbie_defa到数据表学生表的性别列上。

EXEC SP_BINDEFAULT xingbie_defa, '学生表.性别'

2.解除默认xingbie_defa与学生表的性别列的绑定。

EXEC SP_UNBINDEFAULT '学生表.性别'

注:

如果列同时绑定了一个规则和一个默认,那么默认应该符合规则的规定。

不能绑定默认到一个用CREATE TABLE 创建或ALTER TABLE 命令修改表时用

DEFAULT 选项(默认约束)指定了的默认的列上。

四、删除教师职称默认xingbie_defa。

DROP DEFAULT xingbie_defa

注意:在删除一个默认前必须先将与其绑定的对象解除绑定

数据完整性理论(二)

● 规则

● 默认

1. 规则

规则(RULE)是一种数据库对象,作用是向表中的列插入数据时,指定该列接受数据值的范围。

特点:

1)规则要在insert和update语句之前给出。

2)规则与其作用的表是相互独立的,即表的删除、修改不会对与之相连的规则产生影响。

3)规则和约束可以同时使用,表的列可以有一个规则及多个CHECK 约束。

4)规则与CHECK 约束很相似。但CHECK 约束不能直接作用于用户自定义数据类型

一、创建规则

1.用CREATE RULE 命令创建规则

CREATE RULE 命令用于在当前数据库中创建规则,其语法如下:

CREATE RULE rule_name AS condition_expression

其中:

rule_name 是规则的名称

condition_expression 子句是规则的定义,它可以是能用于WHERE 条件子句中的任何表达式,可包含算术运算符、关系运算符和谓词(如IN、LIKE、BETWEEN 等)。 condition_expression 子句中的表达式必须以字符@ 开头

例1:创建年龄规则。

create rule age_rule as @age >= 10 and @age

create rule age_rule as @age between 10 and 50

例2:

create rule Sex_rule as @性别 in ('男','女') ----创建性别规则。

create rule Enter_date_rule

as @入学年份>='1953-01-01' and @入学年份

2.用Enterprise Manager 创建规则

在Enterprise Manager 的左侧窗格中,展开要创建规则的数据库(如:JXGL)目录。 在数据库的对象“规则”上面单击右键,此时出现一快捷菜单,从快捷菜单中单击“新建规则”菜单项,则会弹出“规则属性”对话框。

在此对话框中的“名称”对应的文本框中输入要创建的规则的名称(如:age_rule),在“文本”对应的文本框中输入规则的内容(即约束的条件)。

在输入完规则名称和规则的内容之后,单击“确定”按钮即完成规则的创建。

二、查看和修改规则

1.用Enterprise Manager 查看规则

选择要查看的规则,单击右键,从快捷菜单中选择“属性”选项,即会出现“规则属性”对话框,可以从中编辑规则的表达式。

2.用存储过程Sp_helptext 查看规则

其语法如下:sp_helptext [@objname =] 'name'其中,[@objname =] „name‟子句指明对象的名称

用Sp_helptext 存储过程查看的对象可以是当前数据库中的规则、默认、触发器、视图或未加密的存储过程。

如:查看名称为“age_rule”的规则内容。

EXEC sp_helptext 'age_rule'

3.修改规则的名称

可以通过Sp_rename 系统存储过程进行,也可以直接用右键单击要修改的规则,从快捷菜单中选择“重命名”菜单项,进行名称修改。

格式为: sp_rename ’ age_rule’,’nianling_rule’

三、规则的绑定与松绑

创建规则后,规则仅仅只是一个存在于数据库中的对象,并未发生作用。

需要将规则与数据库表或用户自定义对象联系起来,才能达到创建规则的目的。联系的方法称为“绑定”。

所谓绑定就是指定规则作用于哪个表的哪一列。

表的一列只能与一个规则相绑定,而一个规则可以绑定多个对象,这正是规则的魅力所在。

解除规则与对象的绑定称为“松绑”。

1. 用存储过程Sp_bindrule 绑定规则

存储过程Sp_bindrule 可以绑定一个规则到表的一个列或一个用户自定义数据类型上。 其语法如下:sp_bindrule [@rulename =] 'rule',[@objname =] 'object_name'[, 'futureonly']

各参数说明如下:(1)[@rulename =] 'rule' 指定规则名称。

(2)[@objname =] 'object_name' 指定规则绑定的对象。

(3)'futureonly„ 此选项仅在绑定规则到用户自定义数据类型上时才可以使用。

如:绑定规则age_rule 到学生表的字段年龄。

EXEC sp_bindrule 'age_rule', '学生表.年龄'

注:规则对已经输入表中的数据不起作用。

规则所指定的数据类型必须与所绑定的对象的数据类型一致,且规则不能绑定一个数

据类型为TEXT、IMAGE或TIMESTAMP 的列。

如果表的列与规则A 绑定,同时列又与规则B 绑定,则以规则B 为列的规则。 可以直接用一个新的规则来绑定列,而不需要先将其原来绑定的的规则解除,系统会

将旧规则覆盖。

2.用存储过程Sp_unbindrule 解除规则

存储过程Sp_unbindrule 可解除规则与列或用户自定义数据类型的绑定,其语法如下:sp_unbindrule [@objname =] 'object_name' [,'futureonly']

其中:„futureonly‟选项同绑定时一样,仅用于用户自定义数据类型,

如:要解除已绑定到学生表的字段年龄的规则age_rule。

EXEC sp_unbindrule '学生表.年龄'

3.用Enterprise Manager 管理规则的绑定

在相应的规则名称上面单击右键,从快捷菜单中选择“属性”选项

该对话框中的“绑定UDTs”按钮用于将规则绑定到用户自定义数据类型,“绑定列”按钮

用于将规则绑定到表的列。

4. 删除规则

操作1:用Enterprise Manager 删除规则

操作2:使用DROP RULE命令删除规则使用DROP RULE 命令删除当前数据库中的一个或多个规则。

其语法如下:DROP RULE {rule_name} [,...n]

注:在删除一个规则前必须先将与其绑定的对象解除绑定

如:删除age_rule规则,可执行以下命令:DROP RULE age_rule

2 。默认

默认(Default)也是一种数据库对象,与缺省约束的功能一样。用户插入记录时,在没有给出具体数据的字段中,系统会自动插入一个数据。

默认的管理与应用同规则有许多相似之处。

一、创建默认

用CREATE DEFAULT 命令创建默认其语法如下:CREATE DEFAULT default_name AS constant_expression

其中:

default_name是要创建的默认的名称

constant_expression 子句是默认的定义,该子句可以是数学表达式或函数,也可以包含表的列名或其它数据库对象。

如:创建性别默认sex_defa。

CREATE DEFAULT sex_defa as '男'

这样,当用户在输入记录数据时,未提供性别字段的值时,系统将自动默认其值为“男”。

二、查看和修改默认

1.用Enterprise Manager 查看默认

在Enterprise Manager 的左侧窗格中,展开相应的数据库(如:JXGL)目录

在数据库的对象“默认”上面单击,这时在右侧窗格中的任务板中即可看到已建立的各个默认的信息

在某个默认的名称上面单击右键,从快捷菜单中选择“属性”菜单项,即会出现“默认属性”对话框,可以从中编辑默认的值。

2.用存储过程SP_HELPTEXT 查看默认

使用SP_HELPTEXT存储过程可以查看默认的细节。

如:查看默认sex_defa。

EXEC SP_HELPTEXT sex_defa

3. 修改默认的名称

与修改规则名称的方法相同,可以用SP_RENAME存储过程,也可以在企业管理器的任务板窗口中直接改名。

格式为: sp_rename ’ sex _defa’,’ xingbie_defa’

三、默认的绑定与松绑

创建默认后,默认仅仅只是一个存在于数据库中的对象,并未发生作用。

同规则一样,需要将默认与数据库表或用户自定义对象绑定。

表的一列只能与一个默认相绑定,而一个默认可以绑定多个对象。

1.绑定默认xingbie_defa到数据表学生表的性别列上。

EXEC SP_BINDEFAULT xingbie_defa, '学生表.性别'

2.解除默认xingbie_defa与学生表的性别列的绑定。

EXEC SP_UNBINDEFAULT '学生表.性别'

注:

如果列同时绑定了一个规则和一个默认,那么默认应该符合规则的规定。

不能绑定默认到一个用CREATE TABLE 创建或ALTER TABLE 命令修改表时用

DEFAULT 选项(默认约束)指定了的默认的列上。

四、删除教师职称默认xingbie_defa。

DROP DEFAULT xingbie_defa

注意:在删除一个默认前必须先将与其绑定的对象解除绑定


相关文章

  • 管道完整性管理实施方案
  • 湛管道完整性管理实施方案 编制: 审核: 审定: 中国?!% 二00七年一月 目 录 一.完整性管理概述 1.管道完整性管理的概念 2.开展管道完整性管理的重要性及原则 3.管道完整性管理的主要内容 4.国内外管道完整性管理进展 二.?原油 ...查看


  • 小学作业检查记录表_小学教案检查记录表
  • 小学教案检查记录表 科目: 检查时间: 有教学内容, 教学 目的,教学重难 点,教具准备,教 学过程, 作业布置 □完整 □差 □完整 □差 □完整 □差 □完整 □差 □完整 □差 □完整 □差 □完整 □差 □完整 □差 □较完整 □较 ...查看


  • 数据库第四版答案(王珊 萨师煊)第5章 数据库完整性
  • 数据库第四版答案(王珊萨师煊) 第5章数据库完整性数据库第四版答案(萨师煊) 1什么是数据库的完整性? 答: 数据库的完整性是指数据的正确性和相容性. 2.数据库的完整性概念与数据库的安全性概念有什么区别和联系? 答: ,但是有一定的联数据 ...查看


  • 图书管理系统中数据完整性的实现
  • 第18卷第3期江西电力职业技术学院学报v01.18,No.32005年9月JoumalofJiangxiVocationalandTechnicalCo¨egeofElectricitysep.2005 图书管理系统中数据完整性的实现 江霞 ...查看


  • 高应变法检测桩身完整性的分析
  • 龙源期刊网 http://www.qikan.com.cn 高应变法检测桩身完整性的分析 作者:张高其 来源:<科技创新与应用>2015年第16期 摘 要:高应变检测桩身完整性分析中,除按照桩身完整性系数判定类别外,如何结合实际 ...查看


  • 设备完整性管理系统研究 1
  • 摘 要:伴随着海上油田产能不断增大,生产设施设备不断增多,设施老化问题凸显,如何保证海上石油生产设施的安全经济运行已经成为迫切需要解决的问题,文章开发建立了海上石油生产设施数据库和海上石油生产设施完整性管理软件系统.对保障海上安全生产.保护 ...查看


  • 基桩完整性验证检测方法与实例
  • 基桩完整性验证检测方法与实例 摘要:本文对同一根钻孔灌注桩,采用多种检测方法对基桩身完整性进行检测,通过这一典型的工程实践,有效验证了各种基桩完整性检测理论的有效性和可靠性,同时也根据目前诸多基桩完整性检测方法的适用范围和特点,提出选择一种 ...查看


  • 信号完整性分析详解
  • 高速数字系统设计成功的关键在于保持信号的完整,而影响信号完整性的因素主要有传输线的长度.电阻匹配及电磁干扰.串扰等.设计过程中要保持信号的完整性必须借助一些仿真工具进行仿真,通过结果对PCB布线产生指导性意见,布线完成后再提取网络,对信号进 ...查看


  • 企业实地审计的程序内容和方法
  • 作者:程士忠何志仁 现代审计与会计 2000年03期 一.要搞好企业实地审计,必须严格履行审计程序 (一)实施企业审计时,应当提高工作效率,尽量缩短现场工作时间,减轻企业负担.审前需做以下几项工作:①确定审计组长及其成员.②开展审前调查.③ ...查看


  • 数字签名过程的一个形式描述和验证_最终稿)
  • 数字签名过程的一个形式描述和验证 刘益和 内江师范学院 计算机与信息科学系 四川内江 641112 摘 要:本文通过引入一些新概念,利用Biba 模型思想,对一般的数字签名方案形式化描述和验证,该模型具有完整性. 关键词:Biba 模型,数 ...查看


热门内容