当前位置:首页 > 网络科技 >

为什么禁止写存储过程(为什么不建议写存储过程)

来源:原点资讯(m.360kss.com)时间:2023-04-22 07:57:40作者:YD166手机阅读>>

来源:杨洋的围脖啊

链接:https://segmentfault.com/a/1190000011138993

之所以有这个题目,我既不是故意吸引眼球,也不想在本文对存储过程进行教科书般论述。最近项目中遇到的存储过程问题,让我想起了去年在武汉出差时一位同事的发问:

我觉得存储过程挺好用的,为什么你不建议用?

当时我好似胸有万言,但终究没用一个实在的例子回答同事,只是从结论上大侃一通,代码相对于SQL,复用、扩展、通用性都要更强。想必同事并不信服。

现在想来,我最近正碰到的问题,算是一个可以回答同事的例子吧。

最近项目中有个新需求,需要校验一个用户是否有Job,Certification,Disclosure这三个业务数据。

翻看了代码发现,系统的用户个人页面的C#代码调用了三个存储过程,去抓取用户的Job,Certification,Disclosure数据。
我的新需求,自然需要复用这三个存储过程,否则:

若每一处都写一次抓取数据的业务逻辑代码,若业务逻辑发生变化,难以追查和维护所有读取Job,Certification,Disclosure的SQL。

如果我在C#代码中调用这已有的三个存储过程,事情本该非常快就能结束。我也是这么做的。

但code reviewer认为,我的需求中,并不需要Job,Certification,Disclosure这三个业务对象的数据。我只是需要给定用户是否有Job,Certification,Disclosure而已。所以我应将是否有无Job,Certification,Disclosure的判断逻辑写在数据库,最终通过网络从数据库传到web服务器的仅是true或false,节省网络流量,这样最好不过了。
也对。除开网络性能,从接口设计的角度讲,接口的传入和返回值,都应是你本身需要的数据,不应带有大量不需要或者需要caller去预处理的数据。从接口语义表达就可知调用的目的,这样代码可读性也会有大大提高。

那就动手改。但没想到的是问题来了。

为了讲述问题,我简化代码,假设系统现有的存储过程如下:


为什么禁止写存储过程,为什么不建议写存储过程(1)

我在新的存储过程中调用它,我需要获得该person的jobs的数量,即GetJobs返回结果集的count。

为了实现这一目的,首先想到的是使用临时表,将返回结果集存入临时表,再对其进行count(*)的计数操作:


为什么禁止写存储过程,为什么不建议写存储过程(2)

这种办法简单有效,但它存在严重的维护问题。未来如果被调用的存储过程的返回结果集字段有变动,那么MyProc中的临时表结构也需要随之变化。这是令人难以接受的。

那么将MyProc中的INSERT INTO换为SELECT INTO呢?很遗憾,答案是不行。SQL本身并不支持这种用法。

给现有存储过程GetJobs加output参数?本例中因为GetJobs已被其他多处代码或SQL scripts调用,所以对现有现有存储过程进行改动会有不小风险。

我搜遍网络,一位MS MVP的大神的文章几乎总结了所有存储过程之间传递数据的方法: How to Share Data between Stored Procedures。他在文章中也无可奈何地说道

Keep in mind that compared to languages such as C# and Java, Transact-SQL is poorly equipped for code reuse, why solutions in T‑SQL to reuse code are clumsier.

最终我没能找到一种满意的办法,无奈之下我在新写的存储过程中将查询Jobs的语句写一了次。

存储过程在很多场景时有其优势,比如性能。但对于业务逻辑的通用方法,非常不推荐将其写在存储过程中,代码复用、扩展与客户端语言比,相差甚远。也许终究能实现,但代价与风险比客户端语言要高,得不偿失。

天知道还有没有机会和那位前同事再讨论这一话题呢。

栏目热文

阿里小号停止服务了吗(阿里小号领新号方法)

阿里小号停止服务了吗(阿里小号领新号方法)

从大的分类来说,风险分为三类,看得见的风险,看不见的风险,系统性的风险。 //壹//看得见的风险看得见的风险很容易理解,...

2023-04-22 08:00:18查看全文 >>

阿里云存储和普通存储有什么区别(阿里云常见云存储服务)

阿里云存储和普通存储有什么区别(阿里云常见云存储服务)

我们的电脑和手机平时经常会出现内存不够用的情况,这时你会怎么解决呢?相信很多人的答案都是云盘。网上的云盘软件有很多:百度...

2023-04-22 07:56:16查看全文 >>

为什么不建议使用阿里代码规范(阿里开发代码规范)

为什么不建议使用阿里代码规范(阿里开发代码规范)

一个优秀的开发工程师,他的技术不仅要达到相对靠前的标准,而且平常的编程格式也应该要规范,比如代码对齐、嵌套等等,这些都是...

2023-04-22 07:57:25查看全文 >>

怎么设置阿里存储权限(为什么阿里禁用存储过程)

怎么设置阿里存储权限(为什么阿里禁用存储过程)

[啤酒]满怀忧思,不如先干再说!做干净纯粹的技术分享!欢迎评论区或私信交流!​ [微风]所有源码收录于 gitee,因无...

2023-04-22 07:59:59查看全文 >>

为什么不推荐存储过程(为什么不建议写存储过程)

为什么不推荐存储过程(为什么不建议写存储过程)

作者:菜v菜 来源公众号:架构师修行之路(ID:jiagoushixiuxing) 一、存储过程是什么?存储过程(Sto...

2023-04-22 08:38:50查看全文 >>

阿里数据存在哪里(阿里数据分析在哪里)

阿里数据存在哪里(阿里数据分析在哪里)

最近两年,华为、苹果、腾讯、阿里等全球知名互联网科技企业都把数据放在贵州。腾讯则是在贵州的大山里面挖了个山洞,用来放置...

2023-04-22 08:02:28查看全文 >>

阿里云开放存储(阿里云现有存储空间)

阿里云开放存储(阿里云现有存储空间)

两个核心信息:其一、阿里巴巴旗下所有产品都将用大模型全面改造;其二,阿里云将进行史上最大力度降价,降价并非简单粗暴价格战...

2023-04-22 08:18:31查看全文 >>

阿里巴巴做的分布式存储(阿里巴巴数据存储方式有哪几种)

阿里巴巴做的分布式存储(阿里巴巴数据存储方式有哪几种)

5月26日晚,阿里巴巴集团公布2022年第四季度及2022财年业绩,中国市场消费者突破10亿里程碑,海外市场消费者达3....

2023-04-22 07:54:25查看全文 >>

阿里地址异常(阿里处理地址异常很慢)

阿里地址异常(阿里处理地址异常很慢)

老板:王总你来了,最近生意怎么样啊?王总:哎呀,别提了,我的企业列入严重违法失信名单了,现在不知道怎么才好,你给出出主意...

2023-04-22 08:05:54查看全文 >>

阿里镜像和快照区别(阿里云快照怎么样)

阿里镜像和快照区别(阿里云快照怎么样)

本文以云原生为时代背景,介绍了阿里云块存储快照服务如何基于高性能 ESSD 云盘提升快照服务性能,提供轻量、实时的用户体...

2023-04-22 08:33:59查看全文 >>

文档排行