WEB开发网
开发学院数据库Oracle Oracle数据库应遵循的PL/SQL编码规则 阅读

Oracle数据库应遵循的PL/SQL编码规则

 2007-05-11 12:22:25 来源:WEB开发网   
核心提示: 暴露商务规则和方案,这直接在SQL语句中包含了执行商务规则的逻辑,Oracle数据库应遵循的PL/SQL编码规则(3),这些规则总在变化,所以应用程序的维护成本会急剧增加,但另一方面,编写执行封装任务的代码却具有挑战性;甚至是不现实的,当然,你要编写的每一个PL/SQL应用程序几乎都是基于

暴露商务规则和方案。这直接在SQL语句中包含了执行商务规则的逻辑。这些规则总在变化,所以应用程序的维护成本会急剧增加。

当然,你要编写的每一个PL/SQL应用程序几乎都是基于基础表和视图的。你需要执行SQL语句。问题不在于是否执行,而是何时执行、如何执行。

如果你对数据结构进行封装,或者将它们隐藏于一个PL/SQL代码层(通常是一个代码包)之后,那么你的应用程序将会更健壮,而且你还会发现创建和维护变得更易多了。

我们来看一个简单的例子。 假定我需要编写一个处理某员工工作的程序。第一件事是获取该员工的全名,定义为"姓名逗号(,)姓";然后我可以进行详细分析。清单2给出了这种情况下我很可能要编写的这类代码的一个示例。

一切似乎都是这么简单和直接;这些代码可能会有什么错误呢?实际上真是非常糟糕。最主要的是我暴露了一个商务规则:全名的结构。我可能要花费数小时来对此代码及其所基于的应用程序进行测试。但就在它刚刚投入使用时,我才知道客户会不断地打电话告诉我,实际上,他们的全名应该表示为"名空格姓"。

现在怎么办?搜索所有位于引号内的单个逗号?

现实的解决方案是使用隐藏所有细节、只提供一组预定义、预测试及预优化并能完成所有任务的程序包。清单3为基于封装代码重新编写的process_employee过程。hr_employee_tp包提供了用于定义保存姓名的局部变量的类型;hr_employee_rp包含有基于一种商务规则而返回全名的函数。

将显示PL/SQL语句灌入SQL代码很容易,同样,谈论封装这些语句是如何重要也不费劲。但另一方面,编写执行封装任务的代码却具有挑战性;甚至是不现实的。生成这些包或许更有意义。

上一页  1 2 3 4 5  下一页

Tags:Oracle 数据库 遵循

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接