谈谈一直被开发者们过于在乎的性能问题

来自:十三燕

链接:https://www.cnblogs.com/13yan/p/3539938.html

软件开发者最初为了做出某种功能而努力着。

当有一天,开发者们掌握了开发的门道,实现功能已经家常便饭了。

于是人们开始考虑更多问题,性能就是一个问题。

通常2-4年工作经验的开发者会很纠结这个问题,但由于基础参差不齐,对性能的理解也大不相同。

那些年也许我们过于在乎性能问题了。

误区一:O/RM工具影响性能

发现很多人喜欢拿O/RM工具讨论性能,害怕引入ORM工具以后带来损失性能的问题,不过据我所知目前一些主流的ORM工具性能都半斤八两,ORM工具之间的比较不是性能问题,而是使用习惯的问题。

ORM与原生ADO.NET比较,肯定会损失一定的性能,但是带来了提高开发效率的优势。

据我所知,很多同行做着的OA、ERP什么的系统用户数量都不多,过于计较性能问题,那就是拿5%不到的特殊情况,拒绝大多数情况提高开发效率。

没有人说用了ORM就一定要每个地方都用ORM到底。

误区二:存储过程可提高性能

采用存储过程本身没有什么问题,过于频繁地用存储过程,调试就会比较烦。

1、程序里加断点,然后变量复制到存储过程里加断点调试。

2、过于依赖存储过程,数据库里包含业务逻辑,业务逻辑就分散在程序与数据库,代码可读性损失。

3、调用存储过程的确让很多SQL语句变成了一个存储过程名和参数,减少了网络传输,但很多情况下不需要这点性能。

4、业务逻辑都写在存储过程里了,用面向对象语言的话就当做面向过程语言用了,对开发功能复杂的项目比较不利。

误区三:大数据性能问题

只要接触到几百万或者几千万就认为是大数据,有些人甚至以为MSSQLSERVER数据库碰到千万级的就得挂了。

其实不然,如果每个月以百万级的数据增长,那么对查询而言这些都是小数据,利用分区与查询约束还是比较容易解决的。

而用同样的方法,MSSQLSERVER也能处理超越千万级的数据。

数据库真正的性能问题在哪里?

真正的性能问题从宏观上讲我认为是数据库设计问题,微观上则是SQL调优。

总结

不该以性能为理由拒绝ORM工具,也不该滥用存储过程。

关注性能从设计阶段开始,不可过于纠结性能问题而损失开发效率。

●编号551,输入编号直达本文

●输入m获取文章目录

推荐↓↓↓

数据库开发

更多推荐《18个技术类公众微信》

涵盖:程序人生、算法与数据结构、黑客技术与网络安全、大数据技术、前端开发、Java、Python、Web开发、安卓开发、iOS开发、C/C++、.NET、Linux、数据库、运维等。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180611B1AEK100?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券