数据库程序设计中的约束、触发器和存储过程-1
上一篇 / 下一篇 2012-08-20 09:54:46 / 个人分类:数据库
o:U[I{1kk `m!Yf0 上篇博客中所说的对于表操作的几种限制少分析了触发器。这次从对表设计的角度来着重分析约束和触发器的关系,并进一步扩展比较触发器和存储过程。但在看该篇博客前强烈建议大家好好读下我的上一篇博客《约束与数据库对象规则、默认值的探究》
n5\9^Y;gFm}051Testing软件测试网6hQ| R.`0z}首先,从图上来比较三者的关系:51Testing软件测试网(~B(L0T/iQ"l
|Ykp QSlzQ2p0触发器不仅能够保证数据的完整性,而且还可以封装复杂的T-SQL逻辑处理语句,在功能上类似于存储过程,所以触发器又是一种特殊的存储过程。但是存储过程的执行是我们使用Exec主观调用的,而触发器是经过一种事件操作后自动被调用的。51Testing软件测试网4Xz*r0M%U,W
在拆开分析约束和触发器、触发器和存储过程之前我们穿插点外话。在数据库程序设计中包含有多种数据模型:51Testing软件测试网qP[.K Kv
20世纪60年代后期,在文件系统基础上发展起来的层次模型、网状模型和关系模型等传统数据模型;20世纪70年代后期产生的E-R数据模型;20世纪 80年代以来又相继推出面向对象数据模型、基于逻辑的数据模型等新的模型。下图关系数据库中的关键术语和语义对象模型及ER图中使用的术语之间的映射关 系:51Testing软件测试网KxVU&vVc
pLFoJ?:\$S3{Ex,p0上面的内容只存在了解而已,不用深究。
-c2L R&^ Zr[0数据完整性和业务规则
7Y"ugS `#O0在上篇博客我已经简单介绍了数据完整性,接下来我们详细说下数据完整性和业务规则。
$G{$a1~U)S-@0一、数据完整性51Testing软件测试网9S.o@_(Sge.l-jP7|l
数据完整性=可靠性+准确性,这里我们要清楚一下两点:51Testing软件测试网9Rj6I&J M7O
● 数据存放在表中51Testing软件测试网b&Onl/HN*c
● 创建表的时候,就应当保证以后数据输入是正确的(错误的数据、不符合要求的数据不允许输入)51Testing软件测试网 { G$h-}`/K;yW
为了保证数据的完整性我们经常使用完整性约束来确保数据的完整性。数据完整性,主要包括下面四部分:51Testing软件测试网:Z(b:]L+@
M;{/je H0]7h(Bm sP PaXT5q \0 二、业务规则
?q(lX1iX051Testing软件测试网*sgPBL%uT业务规则听起来很难理解,当然它也是值得我们深究东西,通俗的讲它其实是符合实际条件。如:某商店规定一个售货员在一个月内售出10个以上的热 浴盆,那么奖励2000元;某公司的订单上必须含有客户的姓名和联系方式等等,这些都是简单的业务规则。从数据库的角度看,业务规则就是约束。
d O5MKh Q/\ _051Testing软件测试网c}5j6Tm6TtB约束和触发器51Testing软件测试网.H)b]P1q[
51Testing软件测试网7`D^Mv zjEMS SQL Server提供了两种主要的机制进行强制业务规则和数据的完整性:约束和触发器。在作用上约束支持的触发器都可以实现,它们两者是相容的关系,如下图。 虽然两者在作用关系上有重合的地方,但是相较两者的执行效率和维护难易来说,触发器是远远不如约束的。所以约束能实现的情况下编程人员是不会选择触发器 的。
&tCe B8]2om'I051Testing软件测试网j0m by%YX Rq;^K%u
一、约束,上篇博客我已经着重讲解了约束的概念,这里不再深究。51Testing软件测试网k9vt#Xun
SQL Server中存在五种约束:
b8Q5A5^3G}1d8pI0● 约束的目的:确保表中数据的完整型
(WaTLk0● 常用的约束类型:
&T6jq6Ay j&E c0– 主键约束(Primary Key Constraint):要求主键列数据唯一,并且不允许为空