什么情况下才应该使用存储过程而不是用程序来对数据做操作?

对于什么情况下才应该使用存储过程而不是用程序来对数据做操作的问题,我有下面的看法。


个人经验总结

正巧看到了这个问题,那就把之前不成熟的想法梳理一下(可能有很多错误),因为没有写存储过程,所以不涉及实现细节,从宏观的角度来看,有错误多多谅解。

存储过程是数据操作,它向数据库层提供数据操作。程序在数据库层之上的应用程序层上执行数据操作。

数据处理数据库层的优点是数据的计算和大量数据的处理。应用程序层的优点是业务逻辑的实现。

局限性

很久以前,由于硬件的局限性和功能的限制,被认为更节省数据,数据存储的一致性和安全性是数据库的主要功能,数据计算和操作的应用层实现了更多的功能。

后来随着DB的发展,越来越少的硬件限制,计算和数据操作的功能越来越强大,所以越来越多的业务应用程序层、数据层和数据库对数据操作是最擅长DB,数据库数据处理结果后应用程序层不仅可以使软件更轻,而且可以减少IO。

与应用程序类型相关的是,大量的数据操作和计算在OLAP类应用程序、数据计算和分析软件的数据库层中被更快地放置。

其他内容

OLTP类的应用可能需要更多的业务逻辑,而数据操作的复杂性和容量相对较小,甚至在应用程序层实现中,数据操作也不会产生太大的影响。

应用程序软件可移植性(DB独立性),软件可能需要支持多个数据库,如Oracle或IBM数据库,应该支持上述应用程序。向应用程序层添加更多的数据操作逻辑可以减少对数据库存储过程的更改的需求,从而支持不同的数据库。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏前端迷

Node.js初探

首先,我想说:“很荣幸在经历了2个月的努力,第一个Node.js项目落地了”。整个项目做下来,还是算比较顺畅的。

71920
来自专栏Web项目聚集地

设计一个秒杀系统

最近在部门内部分享了原来在电商业务做秒杀活动的整体思路,大家对这次分享反馈还不错,所以我就简单整理了一下,分享给大家参考参考

18820
来自专栏Java职业技术分享

不懂高性能的负载均衡设计?没关系,架构师带你飞

在软件系统的架构设计中,对集群的负载均衡设计是作为高性能系统优化环节中必不可少的方案。负载均衡本质上是用于将用户流量进行均衡减压的,因此在互联网的大流量项目中,...

10720
来自专栏腾讯移动品质中心TMQ的专栏

抽丝剥茧定位Windows客户端CPU占用问题

摘要 本文主要展示了从电脑管家CPU占用过高问题发现到解决的全过程。包括分析问题的思路、解决问题的方法、压力测试的设计、优化前后数据对比等。同时,在末尾分享了自...

32750
来自专栏搜云库

分布式和集群区别?什么是云计算平台?分布式的应用场景?

分布式是指将一个业务拆分不同的子业务,分布在不同的机器上执行,集群是指多台服务器集中在一起,实现同一业务,可以视为一台计算机,一个云计算平台,就是通过一套软件系...

30250
来自专栏wblearn

Web网站通知系统设计

写在前面: 通知系统是网站信息传播机制的重要的一部分,足够写一大章来说明。本文只梳理设计原则,后续相关内容会持续更新。 这里的通知包括但不限于公告、提醒或消息(...

1.5K20
来自专栏Linyb极客之路

秒杀架构设计

最近在部门内部分享了原来在电商业务做秒杀活动的整体思路,大家对这次分享反馈还不错,所以我就简单整理了一下,分享给大家参考参考

22710
来自专栏Java架构沉思录

如何设计一个秒杀系统

最近在部门内部分享了原来在电商业务做秒杀活动的整体思路,大家对这次分享反馈还不错,所以我就简单整理了一下,分享给大家参考参考。

13820
来自专栏阮一峰的网络日志

谷歌的代码管理

谷歌和 Facebook 都只有一个代码仓库,全公司的代码都放在这个库里。 我一直很困惑,为什么要这样做,不同语言的项目放在一个库有什么好处? 最新一期的《AC...

40980
来自专栏纯洁的微笑

不懂高性能的负载均衡设计?没关系,架构师带你飞

在软件系统的架构设计中,对集群的负载均衡设计是作为高性能系统优化环节中必不可少的方案。负载均衡本质上是用于将用户流量进行均衡减压的,因此在互联网的大流量项目中,...

10520

扫码关注云+社区

领取腾讯云代金券