为什么使用存储过程可以提高性能
来源:互联网 发布:解析还珠格格知画心机 编辑:程序博客网 时间:2024/06/10 12:31
存储过程优点:
* 存储过程的能力大大增强了SQL语言的功能和灵活性。存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的 运算。
* 可保证数据的安全性和完整性。
# 通过存储过程可以使没有权限的用户在控制之下间接地存取数据库,从而保证数据的安全。
# 通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性。
* 在运行存储过程前,数据库已对其进行了语法和句法分析,并给出了优化执行方案。这种已经编译好的过程可极大地改善SQL语句的性能。由于执行SQL语句的大部分工作已经完成,所以存储过程能以极快的速度执行。
* 可以降低网络的通信量。
* 使体现企业规则的运算程序放入数据库服务器中,以便:
# 集中控制。
# 当企业规则发生变化时在服务器中改变存储过程即可,无须修改任何应用程序。企业规则的特点是要经常变化,如果把体现企业规则的运算程序放入应用程序中,则当企业规则发生变化时,就需要修改应用程序工作量非常之大(修改、发行和安装应用程序)。如果把体现企业规则的运算放入存储过程中,则当企业规则发生变化时,只要修改存储过程就可以了,应用程序无须任何变化。
缺点:
1:调试麻烦,但是用 PL/SQL Developer 调试很方便!弥补这个缺点。
2:移植问题,数据库端代码当然是与数据库相关的。但是如果是做工程型项目,基本不存在移植问题。
3:重新编译问题,因为后端代码是运行前编译的,如果带有引用关系的对象发生改变时,受影响的存储过程、包将需要重新编译(不过也可以设置成运行时刻自动编译)。
4: 如果在一个程序系统中大量的使用存储过程,到程序交付使用的时候随着用户需求的增加会导致数据结构的变化,接着就是系统的相关问题了,最后如果用户想维护该系统可以说是很难很难、而且代价是空前的,维护起来更麻烦。
参见http://baike.baidu.com/view/68525.htm#7
- 为什么使用存储过程可以提高性能
- 为什么使用plsql编写存储过程会提高程序的性能?
- 为什么数据库读写分离可以提高性能
- 为什么数据库读写分离可以提高性能
- 为什么数据库读写分离可以提高性能
- 为什么数据库读写分离可以提高性能
- 为什么使用存储过程
- 为什么使用存储过程
- 提高DB2存储过程性能和健壮性
- 存储过程一定会提高性能么?
- 为什么要使用存储过程?
- 为什么要使用存储过程以及存储过程的优缺点
- 提高DB2数据库SQL存储过程性能学习笔记
- 转载:提高DB2数据库SQL存储过程性能学习笔记
- 提高性能——存储过程最佳实践
- 使用dbms_profiler包测试存储过程性能
- 使用dbms_profiler包测试存储过程性能
- 使用dbms_profiler包测试存储过程性能
- 分享Mac和Win系统下iTunes备份文件、更新固件存放位置
- java学习中应该理解的6个问题
- java中的全局变量---->类中pulic static 变量名 来取代--->类名.变量名, 直接用
- VS2010与.NET4系列 21.VS2010调试器改进(断点、数据提示、导入/导出)
- 计算机经典书籍
- 为什么使用存储过程可以提高性能
- Linux环境 C++ Boost 安装
- 装软件总结
- C语言有关文件操作的函数
- 触发器的概念及作用
- Windows Server 2012网络新特性
- 导入自己的命令
- 2012,当我们谈论移动互联网创业时,我们在谈论些什么?
- 面试中常被问到的问题