逻辑写在SQL中还是写在后台程序代码中

最近转去了做互联网开发,看到了最大的不同就是后台代码算法比较多,模块服务化,很多逻辑都写在了后台代码中,比如各种计算甚至连诸如分组排序这种SQL最擅长的功能。

   到底逻辑是应该写在后台程序中还是SQL中?这个话题其实没少讨论过,我这里仅想把一些看法总结下。如果这个问题交给数据库专家去回答,那么十有八九的答案是写在SQL中,理由如下。

性能尽在掌控中,集群,共享存储,表分区,索引,in memory table, 安全,成熟,稳定,让我更有自信。
能适应业务的快速变化,不需要打包编译,大部分时候改下视图或者存储过程就ok.
往往用后台代码写的复杂逻辑只需要一条SQL就搞定(前提是保证性能),这样能减少网络开销,只传输需要的数据,减少网络调用次数,同时也减少了应用服务器的压力。
后台程序太自由,标准不统一,维护成本更昂贵。
如果是一个Java专家或者架构师可能会这样说,将逻辑尽量写在后台代码中,理由如下:

后台服务的扩展比数据库扩展容易,理论上能无限水平扩展。
对数据库的性能依赖小,可移植性好,阿里曾经在去IEO的浪场中由O移植到Mysql。
对于大部分的应用性能瓶颈都在数据库的方面,表设计以及SQL应该尽量简单,这样各种ORM框架能发挥最大的用处。
关系数据库有性能扩展瓶颈,对于大型互联网应应该该鼓励去关系化。
以上是我总结的各门派的观点,任何一方大师都没有说错,但是拿到网上讨论的时候没有加上任何上下文会以偏概全。一个大型的系统信息输入量很大,我们需要将OLTP跟OLAP分开。对于OLTP系统,在乎的是响应时间,对于读多写少的数据我们使用本地、分布式缓存,而且有很多更新的事务操作,根据OO的职责单一原则,对于需要频繁访问或者对数据库性能把控不好的情况下,我们确实应该将SQL写的尽量不要太复杂,不要将业务写在trigger或者存储过程中。这里前提别忘了,数据库的性能瓶颈是对磁盘的IO, SQL依然能做很多方便的工作,比如分组计算,这是各种数据库最基本的功能,并不会产生太大的额外开销,而这种功能写在后台代码中需要通过网络将所有的数据传输过来再分组。对于分布式缓存,我们有很多的计算结果不一定来自于OLTP,我们可以将数据实时的复制到OLAP系统,让OLAP计算出结果了存入缓存以服务的方式提供给OLTP去调用。

  对于系统做迁移,我也谈谈我的看法,大家都一致认为由于数据库平台的差异性导致SQL的可一只性不怎么好,这个不可否认,但是如果一个系统需要迁移了,基本是旧的系统架构支撑不了日益增长的业务了,这种迁移工作本来就是一个很复杂的工程,涉到架构的变动是大概率事件,这种情况下还讨论可移植性还有多大意义? 通常都是换架构框架的多,单纯换数据库的少。

 对于可读性,我觉得都不应该以五十步笑百步,SQL的优势在于逻辑集中,而后台的服务程序分散,还要依赖于开发人员的素质。无论哪种方式都不如文档,无论什么形式的文档,只要能将问题表述清晰都是很有帮助的。曾经做过项目交接工作,当问项目负责人某个不常用看起来简单但是很重要功能的具体实现逻辑的时候,迟迟没有回应,后来我就自己去读代码,各种服务交叉调用,各种缓存到处设置,阅读起来非常吃力。而如果强调写SQL,我曾经看过让我看一眼就望而却步的SQL, 各种case when,各种函数,达到上千行。

————————————————
版权声明:本文为CSDN博主「lgreckey」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/lgreckey/article/details/84750154

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容