点击上方“方志朋”,选择“设为星标”

回复”666“获取新整理的面试文章

作者 | 杨洋的围脖啊

来源 | segmentfault.com/a/1190000011138993

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

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

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

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

当时我好似胸有万言,但终究没用一个实在的例子回答同事,只是从结论上大侃一通,代码相对于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]
(
@PersonId int,
@OrganizaitionId int
)
AS
BEGIN
SELECT JobId,JobName,JobType FROM Job WHERE PersonId = @PersonId AND OrganizaitionId = @OrganizaitionId
END

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

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

CREATEPROCEDURE [dbo].[MyProc]
(
@PersonId int,
@OrganizaitionId int,
)
AS
BEGIN
CREATETABLE#Temp(
PersonId int,
OrganizaitionId int
)

INSERTINTO#Temp EXEC dbo.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的语句写一了次。

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

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

热门内容:问一下,线程池里面到底该设置多少个线程?
点赞功能,用 MySQL 还是 Redis ?知乎千万级高性能长连接网关是如何搭建的
读写分离很难吗?SpringBoot结合aop简单就实现了设计一个成功的微服务,堪称必备的9个基础知识最近面试BAT,整理一份面试资料《Java面试BAT通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。
获取方式:点“在看”,关注公众号并回复 666 领取,更多内容陆续奉上。

明天见(。・ω・。)ノ♡

为什么阿里巴巴禁止使用存储过程?相关推荐

  1. 数据库:为什么阿里巴巴禁止使用存储过程?

    之所以有这个题目,我既不是故意吸引眼球,也不想在本文对存储过程进行教科书般论述.<阿里巴巴Java开发手册>是这样规定的: 再结合我最近项目中遇到的存储过程问题,所以今天我打算来聊一聊这个 ...

  2. mysql 禁止存储过程_为什么阿里巴巴禁止使用存储过程?

    点击关注上方"SQL数据库开发", 设为"置顶或星标",第一时间送达干货 本文作者:杨洋的围脖啊 链接:segmentfault.com/a/119000001 ...

  3. 为什么阿里巴巴禁止使用 Executors 创建线程池,而是通过 ThreadPoolExecutor 方式?...

    >>号外:关注"Java精选"公众号,菜单栏->聚合->干货分享,回复关键词领取视频资料.开源项目. 1. 通过Executors创建线程池的弊端 在创建线 ...

  4. 阿里巴巴为什么要禁止使用存储过程?

    之所以有这个题目,我既不是故意吸引眼球,也不想在本文对存储过程进行教科书般论述.<阿里巴巴Java开发手册>是这样规定的: 再结合我最近项目中遇到的存储过程问题,所以今天我打算来聊一聊这个 ...

  5. error 系统错误 错误码10007_为什么阿里巴巴禁止工程师直接使用日志系统( Log4j 、Logback )中的 API...

    (给ImportNew加星标,提高Java技能) 转自:Hollis 作为Java程序员,我想很多人都知道日志对于一个程序的重要性,尤其是Web应用.很多时候,日志可能是我们了解应用程序如何执行的唯一 ...

  6. 为什么阿里巴巴禁止使用Apache Beanutils进行属性的copy?

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! 在日常开发中,我们经常需要给对象进行赋值,通常会调用其se ...

  7. 为什么阿里巴巴禁止在 foreach 循环里进行元素的 remove/add 操作

    在阿里巴巴Java开发手册中,有这样一条规定: 但是手册中并没有给出具体原因,本文就来深入分析一下该规定背后的思考. 1 foreach循环 foreach循环(Foreach loop)是计算机编程 ...

  8. 为什么阿里巴巴禁止使用BigDecimal的equals方法做等值比较?

    点击上方蓝色"方志朋",选择"设为星标" 回复"666"获取独家整理的学习资料! BigDecimal,相信对于很多人来说都不陌生,很多人都 ...

  9. 为什么阿里巴巴禁止开发人员使用isSuccess作为变量名(修订版)

    在日常开发中,我们会经常要在类中定义布尔类型的变量,比如在给外部系统提供一个RPC接口的时候,我们一般会定义一个字段表示本次请求是否成功的. 关于这个"本次请求是否成功"的字段的定 ...

最新文章

  1. 分布式架构探索 - 2. WebService RPC框架之Apache CXF
  2. Altium Designer隐藏或显示元件名字
  3. pip安装库包遇到错误:TypeError: expected str, bytes or os.PathLike object, not int 的解决方法
  4. ffmpeg rtp时间戳
  5. vscode 常用插件
  6. Boost:boost::bimaps::set_of的测试程序
  7. enum to IEnumerableT
  8. Linux关于文件的权限笔记
  9. py哪个函数可以返回输入的变量类型_[Python基础]二、pycharm,python变量
  10. 10分钟教会你Apache Shiro
  11. Redis3集群搭建
  12. 语音识别技术的研究难点以及未来发展方向
  13. python力导向图论文_力导向图(关系图) echarts的运用
  14. studio2.3app签名打包安装失败,找不到签名证书。
  15. HNUCM-1322:调酒壶里的酸奶
  16. 青蛙跳台阶(剑指 Offer 10- II)
  17. navicat中看sql执行计划
  18. ARM开发软件ADS教程
  19. 136 137 260只出现一次的数字【我亦无他唯手熟尔】
  20. Google中国招聘三大标准 实干、内功与人品

热门文章

  1. lemp-------3多站点访问,,访问控制,,虚拟目录
  2. 网页制作之html基础学习3-css样式表
  3. 【WA】九度OJ题目1435:迷瘴
  4. 基于Matlab的BP神经网络在语音特征信号识别中的应用
  5. 【数据结构】单链表的逆序输出(两种方法)
  6. Imagination 推新款GPU IP,首次实现桌面级光线追踪效果
  7. 女程序员也有35岁危机焦虑吗?
  8. AI时代的幕后英雄:谁在生产高质量的AI训练数据?
  9. 干货!仅有 100k 参数的高效显著性检测方法
  10. 给Python代码加上酷炫进度条的几种姿势