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

为什么阿里不用存储过程(阿里禁用存储过程)

来源:原点资讯(www.yd166.com)时间:2023-04-22 07:53:56作者:YD166手机阅读>>

作者:杨洋的围脖啊

之所以有这个题目,我既不是故意吸引眼球,也不想在本文对存储过程进行教科书般论述。《阿里巴巴Java开发手册》是这样规定的:

为什么阿里不用存储过程,阿里禁用存储过程(1)

再结合我最近项目中遇到的存储过程问题,所以今天我打算来聊一聊这个问题。

这事儿要从去年在武汉出差时一位同事的发问说起,问题是这样的:

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

当时我好似胸有万言,但终究没用一个实在的例子回答同事,只是从结论上大侃一通,代码相对于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去预处理的数据。从接口语义表达就可知调用的目的,这样代码可读性也会有大大提高。

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

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

CREATEPROCEDURE[dbo].[GetJobs] ( @PersonIdint, @OrganizaitionIdint ) AS BEGIN SELECTJobId,JobName,JobTypeFROMJobWHEREPersonId=@PersonIdANDOrganizaitionId=@OrganizaitionId END

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

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

CREATEPROCEDURE[dbo].[MyProc] ( @PersonIdint, @OrganizaitionIdint, ) AS BEGIN CREATETABLE#Temp( PersonIdint, OrganizaitionIdint ) INSERTINTO#TempEXECdbo.GetJobs @PersonId=@PersonId, @ParentOrgId=@ParentOrgId SELECTCOUNT(*)FROM#Temp END

这种办法简单有效,但它存在严重的维护问题。未来如果被调用的存储过程的返回结果集字段有变动,那么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的语句写一了次。

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

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

segmentfault.com/a/1190000011138993

栏目热文

三轮驾照新规定(电瓶三轮车60岁以上需要驾照吗)

三轮驾照新规定(电瓶三轮车60岁以上需要驾照吗)

随着人们对电动小型交通工具的需求量增多,致使电动车类型的各种交通工具很盛行,例如,人们常见的电动三轮车和四轮车就比较多。...

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

摩托车走非机动车道会被扣分吗(摩托车可以借道非机动车道行驶吗)

摩托车走非机动车道会被扣分吗(摩托车可以借道非机动车道行驶吗)

一哥们跑外卖,前几天遇到,我发现他的摩托车居然故意遮挡号牌,有可能是怕路上闯红灯或者其他原因,当我提到被抓到就是12分,...

2023-04-22 07:58:05查看全文 >>

摩托车闯红灯扣几分(输车号查违章)

摩托车闯红灯扣几分(输车号查违章)

开起来飞快时不时还来个“风骚”走位现如今想要出门畅通无阻摩托车和电动车是个不错的选择毕竟遇到高峰期堵车也是伤不起不过开惯...

2023-04-22 08:15:36查看全文 >>

摩托车在公路上走哪个车道(摩托车市内行驶走哪个车道)

摩托车在公路上走哪个车道(摩托车市内行驶走哪个车道)

摩托车在八、九十年代是非常实用的交通工具,后来因为噪音大、安全性低、事故多发被限制,至今很多地方还有“禁摩令”。但随着交...

2023-04-22 08:11:07查看全文 >>

摩托车掉头走哪条道(18种左转掉头图解)

摩托车掉头走哪条道(18种左转掉头图解)

“安康大道部分调头区设置不合理,摩托车、电动车掉头存在极大安全隐患。”——2019年,安康市公安局高新分局交通管理大队共...

2023-04-22 08:30:30查看全文 >>

阿里云为啥不写存储过程

阿里云为啥不写存储过程

之所以有这个题目,我既不是故意吸引眼球,也不想在本文对存储过程进行教科书般论述。最近项目中遇到的存储过程问题,让我想起了...

2023-04-22 08:10:47查看全文 >>

阿里的数据存放在哪里(阿里巴巴的数据储存在哪)

阿里的数据存放在哪里(阿里巴巴的数据储存在哪)

来源:中国新闻网大数据发展看贵州|大数据时代数据存在哪?华为腾讯苹果都在这里建“粮仓”中新网贵阳5月26日电 (左宇坤)...

2023-04-22 07:53:48查看全文 >>

阿里云存储空间当前不可用(阿里云盘占用本地空间问题)

阿里云存储空间当前不可用(阿里云盘占用本地空间问题)

 本月10日,阿里云盘突发故障,不少用户称云盘空间全部变回了100GB。阿里云盘官方也很快作出回应称技术故障导致容量异常...

2023-04-22 08:22:26查看全文 >>

阿里巴巴存储服务器放在哪里(阿里巴巴存储服务器有多大)

阿里巴巴存储服务器放在哪里(阿里巴巴存储服务器有多大)

刚刚刷头条看到一则消息,有网友说阿里巴巴把服务器放到湖底,这下是高科技啊!有的网友甚至说,手机掉到水中也会坏,即使是IP...

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

文档排行