一、我先来来说一说调用存储过程的优点与缺点:
1、SQL语句已经预编绎过了,因此执行效率、性能大大增加。
2、可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。
3、减少网络流量。如:执行插入记录这个功能时只要传输存储过程名、参数和这些参数的数值即可。免去写一大串操纵的SQL语句。
我们将会发现要是网络速度慢时这个是多么的有用,即减少对客户机的压力,又可以简化一系列复杂语句。
4、减少注入式攻击。存储过程可以包含程序流、逻辑以及对数据库的查询。同时可以实体封装和隐藏了数据逻辑。
5、存储过程可以在单个存储过程中执行一系列SQL语句,存储过程内还可以嵌套其它存储过程。
6、有利于SQL语句的重用。
7、更强的适应性:由于存储过程对数据库的访问是通过存储过程来进行的,因此数据库开发人员可以在不改动存储过程接口的情况下对数据库进行任何改动,
而这些改动不会对应用程序造成影响。
8、 布式工作:应用程序和数据库的编码工作可以分别独立进行,而不会相互压制。
当一个业务同时对多个表进行处理的时候采用存储过程比较合适。
- 使用存储过程在一般情况下会提高性能,因为数据库优化了存储过程的数据访问计划并应用缓存方便以后的查询;
- 存储过程单独保护存在于数据库中。客户端可以获取权限执行存储过程,而不需要对底层的具体表设置其他的访问权限; <