当前位置: 首页 > news >正文

温州阀门外贸网站建设山西省建筑工程网

温州阀门外贸网站建设,山西省建筑工程网,广州做外贸网站多少钱,成都网站优化软件之所以有这个题目#xff0c;我既不是故意吸引眼球#xff0c;也不想在本文对存储过程进行教科书般论述。最近项目中遇到的存储过程问题#xff0c;让我想起了去年在武汉出差时一位同事的发问#xff1a;我觉得存储过程挺好用的#xff0c;为什么你不建议用#xff1f;当…之所以有这个题目我既不是故意吸引眼球也不想在本文对存储过程进行教科书般论述。最近项目中遇到的存储过程问题让我想起了去年在武汉出差时一位同事的发问我觉得存储过程挺好用的为什么你不建议用当时我好似胸有万言但终究没用一个实在的例子回答同事只是从结论上大侃一通代码相对于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去预处理的数据。从接口语义表达就可知调用的目的这样代码可读性也会有大大提高。那就动手改。但没想到的是问题来了。为了讲述问题我简化代码假设系统现有的存储过程如下CREATE PROCEDURE [dbo].[GetJobs] (PersonId int,OrganizaitionId int) AS BEGINSELECT JobId,JobName,JobType FROM Job WHERE PersonId PersonId AND OrganizaitionId OrganizaitionId END 我在新的存储过程中调用它我需要获得该person的jobs的数量即GetJobs返回结果集的count。为了实现这一目的首先想到的是使用临时表将返回结果集存入临时表再对其进行count(*)的计数操作CREATE PROCEDURE [dbo].[MyProc] (PersonId int,OrganizaitionId int,) AS BEGINCREATE TABLE #Temp(PersonId int,OrganizaitionId int)INSERT INTO #Temp EXEC dbo.GetJobsPersonId PersonId,ParentOrgId ParentOrgIdSELECT COUNT(*) 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的语句写一了次。存储过程在很多场景时有其优势比如性能。但对于业务逻辑的通用方法非常不推荐将其写在存储过程中代码复用、扩展与客户端语言比相差甚远。也许终究能实现但代价与风险比客户端语言要高得不偿失。天知道还有没有机会和那位前同事再讨论这一话题呢。来源杨洋的围脖啊 sf.gg/a/1190000011138993:-D 搜索微信号ID芋道源码可以获得各种 Java 源码解析、原理讲解、面试题、学习指南。:-D 并且回复【书籍】后可以领取笔者推荐的各种 Java 从入门到架构的 100 本书籍。:-D 并且回复【技术群】后可以加入专门讨论 Java、后端、架构的技术群。来吧骚年~《Java 2019 超神之路》《Dubbo 实现原理与源码解析 —— 精品合集》《Spring 实现原理与源码解析 —— 精品合集》《MyBatis 实现原理与源码解析 —— 精品合集》《Spring MVC 实现原理与源码解析 —— 精品合集》《Spring Boot 实现原理与源码解析 —— 精品合集》《数据库实体设计合集》《Java 面试题 —— 精品合集》《Java 学习指南 —— 精品合集》
http://www.yutouwan.com/news/228963/

相关文章:

  • 镇江建工建设集团网站12306网站建设费用
  • 搭建个人网站定制开发app软件
  • 现在用什么软件做网站公司logo在线设计生成器
  • 萧山做网站的公司做网站准备内容
  • 专业的制作网站开发公司优化大师会员兑换码
  • 扬州市做网站做dm素材网站
  • 帝国cms7.0网站地图工信部域名备案管理系统
  • 网站首页开发wordpress教程阿里云
  • 十大计算机培训学校合肥网站优化费用
  • 太原公司网站建立c2c网站建站的标准
  • 微网站免费建设平台seo实战密码第三版
  • 网站建设费用能否计入广告费网站的后台在哪儿
  • 西安网站建设联系电话上海门户网站制作公司
  • 信阳公司做网站襄阳网站建设楚翼网络
  • 合肥专业手机网站哪家好注册公司注册资金可以随便写吗
  • 东莞网站设计公司排名网站建设范本
  • 成都房地产网站建设c在线编程网站
  • 阿里巴巴吧网站建设网站建设锚点链接
  • 浙江建设厅继续教育网站江西天亿建设有限公司网站
  • 学网站建设需要几年站内关键词排名优化软件
  • 制作一个网站的成本代理登录网站
  • 仙游网站建设公司地方门户网站系统
  • 有没有小学生做兼职的网站湖南城乡建设网站
  • 北京市建设监理协会官方网站北京网站建设公司完美湖南岚鸿首 选
  • 上海松江网站制作律师网站建设公司
  • 网站后台页面进不去网站开发岗位职责及任职要求
  • 凌源网站优化上市网络公司排名
  • 全自动建站系统源码网站被恶意关键字访问
  • 网站建设与管理自考试题及答案wordpress主题安全
  • 网站建设所需的硬件设备滨州医学院做计算机作业的网站