减少与 DB2 for z/OS 的会话:第 2 部分(更多经过检验的基础知识和一些新的编程技巧)
2010-06-16 00:00:00 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鎮㈤崗灏栨嫽闁诲酣娼ф竟濠偽i鍓х<闁诡垎鍐f寖闂佺娅曢幑鍥灳閺冨牆绀冩い蹇庣娴滈箖鏌ㄥ┑鍡欏嚬缂併劎绮妵鍕箳鐎n亞浠鹃梺闈涙搐鐎氫即鐛崶顒夋晬婵絾瀵ч幑鍥蓟閻斿摜鐟归柛顭戝枛椤牆顪冮妶搴′簼缂侇喗鎸搁悾鐑藉础閻愬秵妫冮崺鈧い鎺戝瀹撲礁鈹戦悩鎻掝伀缁惧彞绮欓弻娑氫沪閹规劕顥濋梺閫炲苯澧伴柟铏崌閿濈偛鈹戠€n€晠鏌嶆潪鎷屽厡闁汇倕鎳愮槐鎾存媴閸撴彃鍓卞銈嗗灦閻熲晛鐣烽妷褉鍋撻敐搴℃灍闁绘挻娲橀妵鍕箛闂堟稐绨肩紓浣藉煐濮樸劎妲愰幘璇茬闁冲搫鍊婚ˇ鏉库攽椤旂》宸ユい顓炲槻閻g兘骞掗幋鏃€鐎婚梺瑙勬儗閸樺€熲叺婵犵數濮烽弫鍛婃叏椤撱垹纾婚柟鍓х帛閳锋垶銇勯幒鍡椾壕缂備礁顦遍弫濠氱嵁閸℃稒鍊烽柛婵嗗椤旀劕鈹戦悜鍥╃У闁告挻鐟︽穱濠囨嚃閳哄啰锛滈梺褰掑亰閸欏骸鈻撳⿰鍫熺厸閻忕偟纭堕崑鎾诲箛娴e憡鍊梺纭呭亹鐞涖儵鍩€椤掑啫鐨洪柡浣圭墪閳规垿鎮欓弶鎴犱桓闂佸湱枪閹芥粎鍒掗弮鍫熷仺缂佸顕抽敃鍌涚厱闁哄洢鍔岄悘鐘绘煕閹般劌浜惧┑锛勫亼閸婃牠宕濋敃鈧…鍧楀焵椤掍胶绠剧€光偓婵犱線鍋楀┑顔硷龚濞咃絿妲愰幒鎳崇喓鎷犻懠鑸垫毐闂傚倷鑳舵灙婵炲鍏樺顐ゆ嫚瀹割喖娈ㄦ繝鐢靛У绾板秹寮查幓鎺濈唵閻犺櫣灏ㄥ銉р偓瑙勬尭濡繂顫忛搹鍦<婵☆垰鎼~宥囩磽娴i鍔嶉柟绋垮暱閻g兘骞嬮敃鈧粻濠氭偣閸パ冪骇鐎规挸绉撮—鍐Χ閸℃ê闉嶇紓浣割儐閸ㄥ墎绮嬪澶嬪€锋い鎺嶇瀵灝鈹戦埥鍡楃仯闁告鍕洸濡わ絽鍟崐鍨叏濡厧浜鹃悗姘炬嫹

在之前的专栏中,我提到过不必要的 SQL。目标是让程序员停下来想想每条语句,确定在某个特定的时间它是完全必要的。我展示了两类 SQL 示例:一类是可以完全去掉的 SQL;另一类 SQL 可以延迟到之后某个合适的时间,然后只在仍然必要的时候执行。
在本期的专栏中,我将继续提供一些 SQL 示例,包括执行太过频繁以及可以使用新的、更好的 SQL 替换的 SQL 示例。现在,欢迎进入减少与 IBM DB2 会话的第二部分(共三部分)。
经过验证的技术
控件中断逻辑
编写程序,尤其是批量程序时我们应该遵守的性能基本规则之一是,在可能时使用控件中断逻辑。这不是一个专门的 DB2 概念 —— 它只是一个好的编程实践。查看控件中断或值的更改,可以减少与 DB2 的连接,因为您只有在担心它与上次查询的值不同时才在表格中查询值。
优化控件中断逻辑要求以特定的顺序输入数据;例如,ITEM 位于 STORE 中,STORE 位于 REGION 中。但是,即使输入数据以特定的顺序存储,也可以使用中断逻辑,确保 REGION 需要的任何 SQL 都只对每个 REGION 执行一次;对于 STORE,只对该 REGION 的每个 STORE 执行一次;对于 ITEM,只对该 STORE 中的每个 ITEM 执行一次。
顺便提一下,DB2 执行的引用完整性不使用控件中断逻辑。对每个 INSERT、UPDATE、DELETE 和 MERGE 检查外键值,即使目标列值与之前执行了 INSERT(等操作)的行中的值相同。使用程序执行的引用完整性时,我们可以选择只在目标列值与前一个行中的值不同时进行验证;即在控件中断时验证。
将小型引用表预先加载到程序内存
性能优化的另一个基本规则是将小型引用表预先加载到工作存储表(当这样做恰当时),以避免不必要地多次连接 DB2。
- ››减少电脑关机的时间
- ››db2 对float类型取char后显示科学计数法
- ››DB2中出现SQL1032N错误现象时的解决办法
- ››DB2 锁升级示例
- ››db2诊断系列之---定位锁等待问题
- ››Form Reset Function
- ››db2 命令选项解释
- ››FOREACH 宏之GCC实现
- ››DB2 最佳实践: 使用 DB2 pureXML 管理 XML 数据的...
- ››DB2 9.5 SQL Procedure Developer 认证考试 735 准...
- ››DB2 9.5 SQL Procedure Developer 认证考试 735 准...
- ››DB2 9.5 SQL Procedure Developer 认证考试 735 准...
更多精彩
赞助商链接