Database 板


LINE

※ 引述《FireLake (XXX)》之铭言: : ※ 引述《JoeHorn (每天都在公司玩OLG)》之铭言: : : 一个 DB connection 可以执行很多次 SQL statements, : : 你举的这个例子只需要 transaction,但是.. 可以用同一个 connection。 : : 更何况,很多程式语言有 connection pool 管理能力。 : : (因为可以用同一个 connection,以下我就不回了.. 因为都不是考量因素) : 这部份完全没有解释performance上的问题,用不用 connection pool 都 : 一样。 : 一个 DB connection 的确是可以执行好几个SQL,但要注意到的是每执行 : 一个SQL就是一次从client到server的 round trip。重复使用同一个 DB : connection 或是用 connetion pool 只能省下 login, authetication, : 和一些 initialization 的时间,但是执行每一个 SQL,还是需要从 client/ : application 把 sql statement 或是 binding variable 的值传到 : server/db (当已有curosr时)。此外,执行完後 server/db 还要把结果传 : 回去。这不只是传输时间而已,处理每一个 SQL 时,database要花时间在 : 解析sql statement、处理cursor、binding variable、重新取得lock上面, : 非常没有效率。 : 用个简单的例子,现在有10个SQL要执行,就叫做 SQL 1 到 SQL 10 好了, : SQL 10 要依据 SQL 9 的结果,SQL 9 要依据SQL 8 的结果,以此类推。用 : stored procedure 只要一个 round trip,不用的话就要10次,这在效能上 : 有很大的差别,而且如果其中有几个SQL要传回大量的资料,不用 stored : procedure 的效能会是最糟糕。 : 把 logic 放在 stored procedure 或是 application 各有利弊,但在 : performance 上,使用 stored procedure 有很大的优势。 对一半 一般来说 performance 当然直接用 SP 比较好. 如你所说, 省了 round trip 就差很远了. 问题在於 scalability. DB 相比起 app server, scalability 不可同日而语. 你的系统可能用 SP, 应付一百人没问题, 但要应付一 千人, DB 机器的 CPU, memory 都花在 biz logic 上, 你要找一部更强的 DB 并不是想那麽容易, 价钱也可以 吓你一大跳. 同样能应付一百人份量的复杂 SP 的 DB, 单用来作简 单的CRUD operation, biz logic 移回 app server, DB 应付一千人份量的 simple CRUD 说不定也绰绰有余. 一般作为 transactional 类型的 application, 要应付 多一些 user, 差不多按比例加 app server 数类就行了. (DB 可不是简单加 server 就能应付更多 user) 当然不能一刀切. 有些大量资料的处理, 比如 batch processing 之类, 把部份东西放回 SP 做也是蛮正常 的做法. (这类单谈 performance/scalability, multi-tier 对 於架构和设计上的好处就不说了) --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 61.238.156.185







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Boy-Girl站内搜寻

TOP