WEB开发网      婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牆濮涚紓浣哄█缁犳牠寮诲鍫闂佸憡鎸诲銊╁箲閵忕姭妲堟繛鍡樺姇椤庢捇姊洪崨濠傚鐎殿喖鐖奸獮鏍箛椤旂偓锛忛梺鍛婃寙閸曨偅鐣梻浣哥枃椤宕归崸妤€绠栭柍鍝勫暊閸嬫捇宕烽鐐愩垺銇勯妷锔剧疄婵﹤鎼晥闁搞儜鈧崑鎾澄旈崨顓狅紱闂佽宕橀褎顢婇梻浣告啞濞诧箓宕归幍顔句笉婵炴垯鍨洪悡鏇熴亜閹板墎绋荤紒鈧崘鈹夸簻閹艰揪绱曟晥濠殿喖锕ㄥ▍锝囧垝濞嗗繆鏋庨柟顖嗗啫顥愰梻鍌欑閹芥粍鎱ㄩ悽绋跨婵炲棙鍔掔换鍡涙煟閵忊懚鍦矆鐎n偁浜滈柡宥冨姀婢规﹢鏌涢悙顏勫婵﹥妞藉Λ鍐归妶鍡欌姇闁瑰嘲鎳橀獮鎾诲箳瀹ュ拋妫滈梻鍌欑濠€閬嶅磿閵堝鈧啴宕卞☉妯煎幈闂佸湱鍎ら〃鍡涙偂閺囥垺鐓涢柛銉e劚婵$厧霉濠婂嫮鐭嬮柕鍥у缁犳盯鏁愰崨顓犵潉闂備礁鎼径鍥焵椤掆偓绾绢參寮抽崱娑欏€甸柨婵嗛婢т即鏌¢崱娆忊枅闁哄睙鍕嚤婵炲棙鍨甸崺宀勬⒑闂堟稒顥為悽顖涘浮閿濈偛鈹戠€n偄浜楅柟鑹版彧缁插ジ鎮介懡銈囩=濞达綀顕栧▓鏇㈡煕閵娿儳浠㈡い顐㈢箳缁辨帒螣鐠囧樊鈧挾绱撴担鍦槈妞ゆ垵鎳庨埢鎾活敇閻愨晜鏂€濡炪倖姊归弸濠氬礂椤掑倻纾奸柣妯挎珪瀹曞矂鏌曢崱鏇狀槮妞ゎ偅绻堥獮鍥ㄦ媴閸忓鐎告繝鐢靛Х閺佸憡鎱ㄩ銏犵;闁规崘绉ぐ鎺撴櫜闁搞儮鏂傞埀顒€锕弻锟犲焵椤掍胶顩烽悗锝庡亞閸樿棄鈹戦埥鍡楃仭妞ゆ垶鐟╁畷鐢碘偓锝庡厴閸嬫挾鎲撮崟顒€浠╅梺绋挎唉缁箖鎮橀崘顔解拺缂備焦鈼ら鍕靛殨闁割偅娲栭悿顕€鏌i幇顔芥毄缁炬儳銈搁弻娑氫沪閻愵剛娈ら柡浣哥墦閹鎲撮崟顒傤槰缂備緡鍠栫换妯挎闁诲酣娼ч幗婊兾涢鐐寸厵妞ゆ牕妫旂粈浣圭椤曗偓閹鈻撻崹顔界亪闂佺粯鐗滈崢褔鎮鹃悜鑺ュ亗閹煎瓨蓱椤秴鈹戦埥鍡楃仧閻犫偓閿曞倹鍊电€规洖娲ㄧ壕浠嬫煕鐏炲墽鎳呴柛鏂跨У閵囧嫰濡搁妷锔绘闂佷紮绲剧换鍫ョ嵁閺嶃劍濯存慨婵嗘湰閹蹭即姊绘担铏瑰笡婵☆偄鍟磋棢闁规崘顕уЧ鏌ユ倵閿濆骸鏋熼柣鎾跺枑娣囧﹪濡堕崒姘闂備胶绮〃鍛涘Δ鍛厺闁圭偓绶為弮鍫濆窛妞ゆ棁顫夌€氬ジ姊洪懡銈呅㈡繛鑼█閸┾偓妞ゆ帒鍟悵顏堟煟韫囧﹤浜鹃梻鍌氬€风粈渚€骞栭锕€绠犻柟閭﹀幗閸欏繘鏌熺紒銏犳灍闁稿鏅犻弻锝夊Χ鎼达紕浠滄繛瀛樼矊缂嶅﹪寮婚悢鍏煎€绘俊顖濆亹閻f椽姊洪崫鍕櫤缂佽鐗嗛~蹇撁洪鍜佹濠电偞鍨堕懝楣冦€傞崫鍕ㄦ斀闁宠棄妫楁禍婵嬫煟閻斿弶娅婇柕鍡曠閳诲酣骞掗弮鍌涙緫闂備礁鎼崯顐﹀磹婵犳碍鍎婇柛顐犲劜閳锋垶鎱ㄩ悷鐗堟悙闁诲繐寮剁换娑欐媴閸愭彃顏い鈺冨厴閺屻劑寮撮悙娴嬪亾瑜版帗鍋傞柡鍥ュ灪閻撳繐鈹戦悙鑼虎闁告柣鍊濋弻娑㈠煛鐎n剛蓱濡炪們鍔婇崕鐢稿箖濞嗘挸绾ч柟瀛樼箥濞兼碍淇婇妶鍥ラ柛瀣仱閺佸啴濮€閵堝啠鍋撴担绯曟瀻闁圭偓娼欏▓鎰版⒑閸愬弶鎯堟い鎴濇喘閻涱噣濮€閵堝棌鎷婚梺绋挎湰閻燂妇绮婇悧鍫涗簻妞ゆ劑鍩勫Σ鎼佹煟閿濆懎妲婚摶锝夋煠濞村娅囬柣鎾愁儏椤啴濡堕崱姗嗘⒖闂佽法鍠嗛崕鑼矉瀹ュ牄浜归柟鐑樻尵閸樼敻姊虹紒妯虹仸閽冮亶鎮樿箛锝呭箹闂囧绻濇繝鍌氭殶缂佸鍎ら幈銊︾節閸涱噮浠╃紓浣介哺鐢帟鐏掗梺鎯х箻閳ь剚绋掗、姗€姊婚崒娆戝妽閻庣瑳鍏犲搫顓兼径濠勬煣濠电偞鍨剁划搴㈢闁秵鈷掑ù锝呮啞閸熺偞绻涚拠褏鐣电€规洖缍婇弻鍡楊吋閸涱垰骞堥梻浣侯攰閹活亪姊介崟顖涘亗婵炲棙鎸婚悡鐘崇箾閺夋埈鍎愭繛鍛噹闇夐柣妯虹-閻﹪鏌嶇憴鍕伌闁搞劑绠栭幃娆撴寠婢跺鍨濋梻鍌欐祰椤曟牠宕板Δ鍛偓鍐川閺夋垹鍙€婵犮垼鍩栭崝鏇犵不閹惰姤鐓欓柟顖嗗苯娈堕悷婊勬緲濞层劎妲愰幘璇茬<婵炲棙鍨肩粣妤呮⒑閸濄儱校闁绘濞€閵嗕線寮介鐐茬獩闂佸湱鈷堥崢浠嬪疾閿濆鈷戠紒瀣硶缁犳娊鏌涘Ο鐘叉噺椤愪粙鏌i幇顔剧瘈缂佽妫欓妵鍕冀閵娧呯厒闁汇埄鍨辩粙鎺旀崲濞戙垹宸濇い鎾跺枎閺嬬姴鈹戦纭峰姛缂侇噮鍨堕獮蹇涘川鐎涙ê浠梻渚囧弿缁犳垵鈻撳┑鍫㈢=闁稿本鐟︾粊鐗堛亜閺囧棗娲ょ壕褰掓煕椤垵娅橀柛銈嗘礈缁辨挻鎷呯拹顖滅窗缂備讲妾ч崑鎾绘⒒娴h鍋犻柛搴灦瀹曟繂顓奸崨顏呯€洪梺鎼炲労閸撴岸鍩涢幋鐘电<閻庯綆鍋勯婊勭節閳ь剟骞嶉鍓э紲闁诲函缍嗛崑鍛暦瀹€鈧埀顒冾潐濞插繘宕规禒瀣畺濞寸姴顑呭婵嗏攽閻樻彃顏╂鐐搭殜濮婃椽鎮烽弶鎸庡€梺浼欑秵娴滎亜鐣风憴鍕瘈婵﹩鍓涢崢鎰版⒑閸濆嫭鍌ㄩ柛銊︽そ閹繝濡烽敂钘夊伎濠碘槅鍨伴悘婵嬫偂閹扮増鐓熼柟鎹愭硾閺嬫盯鏌i幙鍐ㄤ喊鐎规洖鐖兼俊鐑藉Ψ閵夈儛鎴犵磽閸屾瑧顦︽い鎴濈墕閻g兘鎮介崹顐綗闂佸湱鍎ゅ鑽ゅ閸忛棿绻嗘い鏍ㄧ箓娴滃綊鏌i敐鍫燁仩缂佽鲸鎸婚幏鍛存惞閻熸壆顐肩紓鍌欐祰椤曆囨偋閸℃稒鍋╃€瑰嫰鍋婂ḿ銊╂煃瑜滈崜姘┍婵犲偆娼扮€光偓婵犲唭銊х磽閸屾瑦绁板鏉戞憸閹广垽宕煎┑鎰稁缂傚倷鐒﹁摫濠殿垰顕槐鎺戔槈濮楀棗鍓板┑鐐茬墛閸旀瑥顫忓ú顏勭闁绘劖褰冮‖鍡涙⒑閸涘⿴娈旈柛鐔锋健閹箖鎮滅粵瀣櫖闂佺粯鍔樼亸娆愵殽閸ヮ剚鈷戦柣鐔煎亰閸ょ喎鈹戦鈧ḿ褔鍩㈤幘娣亝闁告劏鏂侀幏铏圭磽閸屾瑧鍔嶉拑閬嶆煃闁垮娴柡灞界Т閻o繝骞嶉灏栧徍闁诲孩顔栭崳顕€宕戞繝鍌滄殾闁圭儤顨嗛崐鐑芥倵閻㈢櫥褰掔嵁閸儲鈷掑ù锝囨嚀閳绘洟鏌℃笟鍥ф珝鐎规洘鍨块獮妯肩磼濡厧骞愰梻浣告啞娓氭宕板璺虹疇闁告侗鍠曠换鍡涙煕濞嗗浚妲稿┑顔兼喘閹藉爼鏁愭径瀣哗濠电偞鍨剁敮鎺撴櫠閺屻儲鐓涢柛灞绢殔娴滈箖姊婚崒姘偓鐑芥嚄閸撲礁鍨濇い鏍仜缁€澶愭煛閸モ晛鈧綁鎮㈤崫銉х槇闂佹悶鍎滈崘鈺佸姃闂傚倷鑳剁划顖炲蓟閵娾晜鍎嶆繝闈涱儏缂佲晠鏌ら幁鎺戝姌濞存粍绮撻弻锟犲礃閵婏箑顦╁銈冨劚椤︾敻寮诲☉銏犳閻犲洦绁撮崑鎾斥攽鐎n亞顔戦梺鍓插亝濞叉﹢宕愰悜鑺ョ厽闁瑰鍋嶇紓姘舵煕濮椻偓娴滆泛顫忓ú顏勪紶闁告洦鍓欓崑宥夋⒑閸涘﹥鐓ラ柡鍫墴瀵煡宕奸弴銊︽櫖闂佺粯鍔曢顓㈠储閸楃偐鏀介柣鎰级椤ユ粎绱掔紒妯虹缂侇喚绮换婵嗩潩椤撶姴骞愰梺璇茬箳閸嬬喖寮查锝嗘珡闂佽姘﹂~澶娒洪敃鍌氱;濠电姴鍊婚弳锕傛煟閺冨倵鎷¢柡浣告閺屽秷顧侀柛鎾寸懇閸┿垹顓兼径瀣珳闂佹悶鍎弲婵嬫晬濠靛洨绠鹃弶鍫濆⒔缁嬭崵鎲搁弶鍨殲缂佸倸绉归幃娆擃敆閸屾粎妲囬梻渚€娼ф蹇曞緤閸撗勫厹闁绘劦鍏欐禍婊堟煙鐎涙ḿ绠栫€瑰憡绻勭槐鎺楊敊閸撗冪闂侀潧鐗炵紞浣哥暦濮椻偓閸╋繝宕橀妸銉ь吋闂傚倷娴囬褏鈧稈鏅濈划娆撳箳閹寸姴绠甸柣鐘充航閸斿孩绋夊鍡樺弿婵$偠顕ф禍楣冩⒑閸濆嫯顫﹂柛鏂跨焸閸┿儲寰勬繛銏㈠枑瀵板嫰鎯傞崫銉戦梺闈涙搐鐎氱増淇婇幖浣规櫜闁告侗鍘艰闂傚倷娴囬鏍窗濡ゅ懏鍋¢柍鍝勬噷閳ь兛绶氬顕€宕煎┑鍫Ч婵$偑鍊栭幐鑽ゆ崲閸曨厾鐭嗛柛鏇ㄥ灡閳锋帡鏌涚仦鍓ф噭缂佷胶澧楅妵鍕即閻斿搫鈷岄悗瑙勬磻閸楀啿顕f禒瀣垫晝闁靛牆娴傚Σ绋库攽閻樺灚鏆╁┑顔芥尦瀹曟劖绻濆顒佽緢闂佹寧娲栭崐褰掓偂濞嗘劑浜滈柡宥庡亜娴犳粌霉濠婂懎顣煎ǎ鍥э躬閹崇姵锛愬┑鍡橆唲闂備礁鐤囬~澶愬垂閸ф鏄ラ柛鏇ㄥ灠缁€鍐煏婵炑冩噷閸嬧€斥攽閿涘嫬浜奸柛濞垮€濆畷銏°偅閸愩劎顦у┑鈽嗗灟鐠€锕傚吹閺囥垺鍋i柛銉e妿閵堝瓨淇婇幓鎺斿ⅵ闁哄本娲濈粻娑㈠即閻戝棙缍岄梻浣稿暱閹碱偊骞婅箛娑欏亗闊洦鎼╅悢鍡涙偣妤︽寧顏犲褎娲熼弻娑㈠籍閳ь剟骞愰幎钘夎摕婵炴垯鍨瑰Λ妯荤箾閸℃瑥浜惧Δ鏃傜磽閸屾瑦绁板瀛樻倐楠炴劖绻濆顒傤唵闂佸憡渚楅崹鎶芥儗濞嗘挸绠归悗娑櫳戠亸顓灻瑰⿰鍫㈢暫闁哄本绋戦埞鎴﹀礋椤愩垹袘闂備焦妞块崢浠嬪箰妤e啫绠熼柟闂寸劍閸嬪鏌涢锝囩畼闁荤喆鍔戝娲传閸曢潧鍓紓浣藉煐瀹€绋款嚕婵犳碍鍋勯柣鎾虫捣椤︻參鎮峰⿰鍐闁轰緡鍠栭埥澶愬閿涘嫬骞愰梻浣告啞娓氭宕板Δ鍛9闁规壆澧楅悡娑㈡倶閻愰鍤欏┑顔煎€块弻鐔碱敊閸濆嫧鍋撳┑鍡欐殾闁圭儤鍨熷Σ鍫熸叏濡も偓濡梻妲愰敓锟� ---闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻锝夊箣閿濆憛鎾绘煕婵犲倹鍋ラ柡灞诲姂瀵噣宕奸悢鍛婎唶闂備胶枪椤戝棝骞愰崜褍鍨濇い鎾跺亹濡插牊淇婇姘儓缂佺姾顕ч埞鎴︽倷閸欏鏋欐繛瀛樼矋缁捇骞冮垾鏂ユ闁靛骏绱曢崢鍗炩攽閻愭潙鐏ョ€规洦鍓熼悰顔嘉熷Ч鍥︾盎闂佸搫鍊圭€笛囁夐姀鈩冨弿濠电姴鎳忛鐘绘煙閻熸澘顏┑鈩冩倐婵$兘鏁傞幆褏绋堥梻鍌氬€烽懗鍫曞箠閹捐鍚归柡宥庡幖缁狀垶鏌ㄩ悤鍌涘
开发学院数据库DB2 理解 DB2 UDB JDBC 通用驱动程序:内部人士指南 阅读

理解 DB2 UDB JDBC 通用驱动程序:内部人士指南

 2009-11-23 00:00:00 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁惧墽鎳撻—鍐偓锝庝簻椤掋垺銇勯幇顖毿撻柟渚垮妼椤粓宕卞Δ鈧獮濠勭磽閸屾艾鈧懓顫濋妸鈺佺疅缂佸顑欓崥瀣煕椤愵偅绶氱紓鍐╂礋濮婂宕掑▎鎴М濠电姭鍋撻梺顒€绉甸幆鐐哄箹濞n剙濡肩紒鎰殜閺屸€愁吋鎼粹€茬敖婵炴垶鎸哥粔鐢稿Φ閸曨垰鍐€妞ゆ劦婢€濞岊亪姊虹紒妯诲蔼闁稿海鏁诲濠氭晲婢跺﹤宓嗛梺缁樺姈缁佹挳宕戦幘璇叉嵍妞ゆ挻绋戞禍鐐叏濡厧浜鹃悗姘炬嫹闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁惧墽鎳撻—鍐偓锝庝簼閹癸綁鏌i鐐搭棞闁靛棙甯掗~婵嬫晲閸涱剙顥氬┑掳鍊楁慨鐑藉磻濞戔懞鍥偨缁嬫寧鐎梺鐟板⒔缁垶宕戦幇鐗堢厵缂備焦锚缁椦囨煃瑜滈崜锕傚矗閸愵煈娼栭柛婵嗗珔瑜斿畷鎯邦槾濞寸姴銈稿铏规嫚閼碱剛顔夐梺鐓庣秺缁犳牠骞冩ィ鍐╁€婚柦妯侯槼閹芥洟姊洪棃娑辨濠碘€虫喘瀹曘垽鎮介崨濞炬嫼闁荤喐鐟ョ€氱兘宕箛娑欑厱闁绘ê纾晶鐢告煏閸℃鈧湱缂撴禒瀣窛濠电姴瀚獮鍫ユ⒑绾懎顥嶉柟娲讳簽濡叉劙寮撮悢鍝勨叞闂傚倸鍊风欢姘缚瑜嶇叅闁靛牆娲犻崑鎾愁潩椤愩垹绁梺缁樹緱閸o綁鐛幒鎳虫棃鍩€椤掑倻涓嶉柨婵嗘缁♀偓闂傚倸鐗婄粙鎴﹀汲濞嗗緷鐟扳堪閸垻鏆梺鍝勭焿缂嶄焦鎱ㄩ埀顒勬煃閹増纭炬繝鈧潏銊х彾闁哄洨鍠撶弧鈧┑顔斤供閸橀箖宕㈤悽鍛娾拺缂備焦锚婵箓鏌涢幘鏉戝摵闁诡喗蓱濞煎繘濡搁妶鍥╃暰闂備礁婀辩划顖滄暜閻愬瓨娅犳繛鎴炴皑绾捐偐绱撴担璐細婵炴彃顕埀顒冾潐濞叉牕鐣烽鍐簷闂備礁鎲¢崝鏇㈠疮閻樿绀堟繝闈涚墛瀹曞弶绻涢幋鐐ㄧ細闁哄棗妫楅埞鎴︽偐鏉堫偄鍘¢梺杞扮劍閻楁粎妲愰幘瀛樺濞寸姴顑呴幗鐢告⒑閸︻厽鍤€婵炲眰鍊濋幃楣冩倻閽樺顔婇梺瑙勬儗閸樹粙宕撻悽鍛娾拺闁荤喐婢橀幃渚€鏌i幒鐐电暤闁诡喗顨婇獮鏍ㄦ媴閸忓瀚藉┑鐐舵彧缁插潡宕曢妶澶婂惞闁逞屽墴濮婃椽骞栭悙娴嬪亾閺嶎厽鍋嬮柣妯垮吹瀹撲線鐓崶銊р姇闁哄懏鎮傞弻銊╂偆閸屾稑顏�婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘垿濡甸崟顖氱闁告鍋熸禒鑲╃磽娴e搫顎岄柛銊ョ埣瀵鈽夐姀鐘电杸闂傚倸鐗婄粙鎺楁倶閸儲鍊甸柣鐔哄閸熺偟绱掔拠鎻掓殻濠碉紕鏁诲畷鐔碱敍濮橀硸鍟嬮梺璇查叄濞佳囧箺濠婂牊鍋╁┑鍌氭啞閳锋垹鐥鐐村婵炲吋鍔栫换娑㈡嚑椤掆偓閺嬪孩銇勯銏㈢缂佽鲸甯掕灒闁兼祴鏅滈崵宀勬⒒娓氣偓閳ь剛鍋涢懟顖涙櫠椤旇偐鏆嗛柨婵嗙墕閸斿灚銇勯敂鐣屽弨闁诡噯绻濇俊鑸靛緞鐎n剙甯鹃梻浣稿閸嬪懐鎹㈤崘顔肩;妞ゅ繐鎳愮粻鍓р偓鐟板閸犳洜鑺辨繝姘畾闁绘柨鍚嬮埛鎴︽倵閸︻厼校闁靛棗鍟撮弻銈夊礃閼碱剙鐓熼悗瑙勬礃缁诲牓寮崘顔肩劦妞ゆ帒瀚ч埀顒佹瀹曟﹢顢欓崲澹洦鐓曢柍鈺佸枤濞堟﹢鏌i悢绋垮婵﹥妞介幃鈩冩償閳╁啯鐦i梻浣虹帛閻楁洟濡剁粙璺ㄦ殾闁绘垶岣跨弧鈧梺鎼炲劀閸愩劎銈梻鍌欑窔濞佳勵殽韫囨洘顫曢柡鍥ュ灩閸屻劍銇勮箛鎾跺闁抽攱鍨块弻鐔兼嚃閳轰椒绮堕梺鍛婃⒐椤ㄥ﹪寮婚敓鐘插窛妞ゆ棃鏁慨鍥╃磽娴gǹ鈧湱鏁悢濡撳洨鈧潧鎽滅壕濂稿级閸稑濡肩紒妤佺缁绘盯鎮℃惔锝囶啋闂佺硶鏂侀崜婵嬪箯閸涘瓨鐓ラ悗锝呯仛缂嶆姊婚崒姘偓宄懊归崶褜娴栭柕濞炬櫆閸婂潡鏌ㄩ弴鐐测偓鍝ョ不閺屻儲鐓曢柕澶樺枛婢ь噣鏌$€b晝绐旈柡宀€鍠栧畷婊嗩槾閻㈩垱鐩弻锟犲川椤旇棄鈧劙鏌$仦璇插闁诡喓鍊濆畷鎺戔槈濮楀棔绱�闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁惧墽鎳撻—鍐偓锝庝簻椤掋垺銇勯幇顖毿撻柟渚垮妼椤粓宕卞Δ鈧獮濠勭磽閸屾艾鈧懓顫濋妸鈺佺疅缂佸顑欓崥瀣煕椤愵偅绶氱紓鍐╂礋濮婂宕掑▎鎴М濠电姭鍋撻梺顒€绉甸幆鐐哄箹濞n剙濡肩紒鎰殜閺屸€愁吋鎼粹€茬敖婵炴垶鎸哥粔鐢稿Φ閸曨垰鍐€妞ゆ劦婢€濞岊亪姊虹紒妯诲蔼闁稿海鏁诲濠氭晲婢跺﹤宓嗛梺缁樺姈缁佹挳宕戦幘璇叉嵍妞ゆ挻绋戞禍鐐叏濡厧浜鹃悗姘炬嫹  闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻锝夊箣閿濆憛鎾绘煕閵堝懎顏柡灞诲€濆畷顐﹀Ψ閿旇姤鐦庡┑鐐差嚟婵潧顫濋妸褎顫曢柟鎹愵嚙绾惧吋绻涢崱妯虹瑨闁告﹫绱曠槐鎾寸瑹閸パ勭彯闂佹悶鍔岄悥鍏间繆閹绢喖绀冩い鏃傚帶缁愭盯姊洪崫鍕垫Ч闁搞劌缍婂畷銏犆洪鍛偓鍨殽閻愯尙浠㈤柛鏃€纰嶉妵鍕晜鐠囪尙浠搁悗瑙勬穿缁绘繈鐛惔銊﹀殟闁靛/鍐ㄥ闂傚倸饪撮崑鍕洪敃鈧叅闁哄秲鍔庢晶锟犳⒒閸屾瑦绁版い鏇嗗應鍋撻崹顐㈡诞鐎规洘绮撻幃銏$附婢跺绋侀梻浣瑰劤缁绘劕锕㈡潏鈺侇棜闁稿繘妫跨换鍡樸亜閺嶃劎顣查柟顖氱墛閵囧嫰顢曢姀銏㈠姱濠殿喖锕ュ钘夌暦閻戠瓔鏁囨繛鎴炵懃閻濋亶姊绘担鍛靛綊顢栭崨顓囨稑鈹戠€n亞鐣鹃梺閫炲苯澧柕鍥у缁犳盯骞樼€垫悶鍋愭繝纰樻閸ㄦ壆鈧碍婢橀~蹇撁洪鍕炊闂佸憡娲﹂崜姘跺箯閸楃偐鏀介柣鎰絻缁狙冪暆閿濆懏鍋ユ鐐村灴婵偓闁绘﹩鍋呴弬鈧┑鐘垫暩婵鈧凹鍣e鍫曞箹娴e厜鎷洪梺鍛婄箓鐎氼厼顔忓┑鍡忔斀妞ゆ梹鍎抽崢鎾煙椤旇宓嗗┑锛勫厴閸╋繝宕掑Δ浣割伜婵犵數鍋犻幓顏嗗緤娴犲绠规い鎰╁€栭弳婊堟偣鏉炴媽顒熼柣鏂挎閺岋綁鎮㈠畡鎵泿闂佽 鍋撻柤濮愬€楃壕濂告煕鐏炵偓鐨戠€涙繂螖濡ゅ﹣绨烽柛妤€鍟块悾鐑芥偂鎼搭喗鍍甸梺鎸庣箓閹冲秵绔熼弴銏♀拺闁告繂瀚弳娆撴煟濡も偓濡稓鍒掗崼銉ョ闁崇懓銇樼花濠氭椤愩垺鎼愭繛瀵稿厴钘濋柨鏇楀亾闂囧绻濇繝鍌滃ⅱ闁伙絾妞介弻锛勪沪鐠囨彃顬堥梺瀹狀潐閸ㄥ灝鐣烽崡鐐╂闁瑰吀绀佹禍鐐繆閵堝倸浜惧銈庡弨閸庡篓娓氣偓閺屾盯鎮╁畷鍥р拰濠电姭鍋撳〒姘e亾婵﹨娅g槐鎺懳熼弴鐔风伌闁诡喚鍏樻俊鐤槷闁稿鎸搁~婵嬫偂鎼淬垻浜剧紓鍌欑贰閸犳氨鍒掗鐐参ч柨婵嗩槸缁€鍐煃閸濆嫬鏆欐鐐茬墛娣囧﹪鎮欓鍕ㄥ亾閺嶎厼绀夐柟杈剧畱绾惧綊鏌¢崶銉ョ仼闁告垹濞€楠炴牕菐椤掆偓婵′粙鏌i幘璺烘灈闁绘搩鍋婂畷鎯邦檨闁稿骸绻橀弻娑㈠籍閳ь剛鍒掗幘璇茶摕闁哄洢鍨归悙濠勬喐瀹ュ鏁傛い鎾跺Л閸嬫挸鈻撻崹顔界亶濠电偛鍚嬮悷銊╂倶閹烘鈷戦柛娑橈功缁犳捇鎮楀鐓庡⒉妞ゃ倕鍊圭换婵堝枈婢跺瞼锛熼梺绋款儐閸ㄥ灝鐣烽幇鏉跨闁挎洍鍋撻柛銊ュ€圭换娑橆啅椤旇崵鍑归梺绋款儜缁绘繈寮诲澶婁紶闁告洦鍓欏▍锝囩磽娴e搫校闁绘濞€瀵顓兼径濠勫幐婵炶揪绲介幉鈥斥枔閺屻儲鈷戠紒瀣閹癸綁鏌涢悩宕囧⒌鐎殿喖顭峰鎾閻橀潧鈧偤鎮峰⿰鍐ら柤楦块哺缁绘繂顫濋鐘插箥闂備礁鎲¢崹顖炲磹閺嶎偀鍋撳鐐
核心提示:简介在 DB2 环境中的 Java 开发的演变过程中,最近的动向是 DB2 UDB JDBC 通用驱动程序,理解 DB2 UDB JDBC 通用驱动程序:内部人士指南,这种新的驱动程序提供了很多优点和改进,使它成为应用程序开发的最佳选择,更深入地理解 DB2 UDB JDBC 通用驱动程序,可以让您在 DB2 环境中进

简介

在 DB2 环境中的 Java 开发的演变过程中,最近的动向是 DB2 UDB JDBC 通用驱动程序。这种新的驱动程序提供了很多优点和改进,使它成为应用程序开发的最佳选择。在本文中,您将理解这种驱动程序的内部工作原理,并看它怎样匹配您的整个应用程序开发计划。

首先让我们来比较现有的两种驱动程序:

旧的 CLI 驱动程序

新的 JDBC 通用驱动程序

在第一节中,我们主要通过以下几个话题来展示这两种驱动程序之间的不同之处:

安装

连接

驱动程序初始化

特性

错误处理

事务管理

第二节将讨论问题诊断和对跟踪的分析。要理解如何做这件事,需要了解 SQLException,以及它与 JDBC 有怎样的关联。对于新的 JDBC 通用驱动程序,我们将讲解如何进行 JCC 跟踪,以及进行 JCC 跟踪时需要些什么。完成跟踪后,我们将深入了解跟踪由哪些部分组成,以及如何使用跟踪来帮助找到问题的根源。

旧的 JDBC 驱动程序与新的通用 JDBC 驱动程序的比较

要理解我们对 DB2 通用驱动程序的开发的讨论,需要理解 JDBC 规范如何定义用于 Java 的不同类型的驱动程序。

Type 1 驱动程序:

这类驱动程序的代码直接与高级本机 API 形成映射。JDBC 和 ODBC 是类似的 API,所以这种驱动程序常常与 JDBC-ODBC 桥联系在一起。

这类驱动程序与 DB2 UDB 产品没有太多的关联。

Type 2 驱动程序:

T2 驱动程序中有一个本机组件,该组件是驱动程序的一部分,但与数据访问 API 相分离。

这个本机组件和 Java 组件一起构成驱动程序。

对于 DB2 UDB,DB2 CLI 库包含本机组件。

Type 3 驱动程序:

这是一个 Java 客户机,使用独立于数据库的协议进行通信。

由于这种协议是独立于数据库的,这个优点使之适合于作为异构后端服务器的网关的中间件服务器。

Type 4 驱动程序:

这类驱动程序是纯 Java 的,它实现了用于特定数据源的网络协议。

客户机直接连接到数据源。

谈到 DB2 UDB,您只需关心 Type 2、3 和 4 驱动程序。有了前面介绍的知识,现在可以看看关于 Type 2 和 Type 4 驱动程序的一些专门信息,并考察在应用程序开发中使用 Type 4 驱动程序的优点。让我们来看旧的 CLI Type 2 驱动程序与 Type 4 通用 JDBC 驱动程序之间的比较。

安装

连接

驱动程序初始化

特性

错误处理

事务管理

安装

DB2 JDBC 支持包含在 DB2 UDB 客户机和服务器的 Java enablement 选项中。不需要专门安装 DB2 JDBC 驱动程序,您只需确保下载了适合于平台的 Java 开发工具箱(JDK)。DB2 Information Center 包含关于如何在 UNIX 和 Windows 上为 Java 设置环境的详细信息。

表 1. 安装比较
旧的 CLI 驱动程序通用驱动程序
旧的 CLI 驱动程序的物理表示是 db2java.zip 文件。通用 JDBC 驱动程序的物理表示是 db2jcc.jar 文件。
在 UNIX 环境中,只需在 CLASSPATH 中有 sqllib/java/db2java.zip,就可以使用旧的 Type 2 驱动程序。在 Windows 上也是如此。在 UNIX 环境中,只需在 CLASSPATH 中有 db2jcc_license_cu.jar 和 sqllib/java/db2jcc.jar,就可以使用 Type 4 通用驱动程序。在 Windows 上也是如此。
支持这类驱动程序的有 JDBC 2.0 和部分 JDBC 3.0。支持这类驱动程序的是大多数 JDBC 3.0 实现,只要安装了 JDK1.4.x 作为 Java 包的一部分,就提供了对这类驱动程序的支持。

连接

这两类驱动程序的不同之处表现在它们建立连接的方式上。JDBC 的基本功能是连接到数据库,并发送 SQL 语句到服务器。它能够处理结果集,并将其发送给请求者。

表 2. 连接比较
旧的 CLI 驱动程序通用驱动程序
到数据库的连接是通过一个本机数据库接口进行的。在这里,DB2 使用 CLI。JDBC 层位于 CLI 之上,CLI 是与数据库服务器通信的本机组件。一切都是纯 Java 的,与数据库的通信通过网络通信完成。DB2 UDB 使用分布式关系数据库架构(DRDA)来与服务器进行通信,并将请求传递给数据库服务器。
由于旧的 CLI 驱动程序需要公共客户机代码,所以它还需要一个 DLL/共享对象。为了使用这类驱动程序,必须安装 DB2 产品。这是一种纯 Java 的驱动程序,所以可独立于它所在机器上安装的产品而运行。也就是说,可以将它看作一个单独的实体,它是独立于附带它的那个 DB2 产品的。

驱动程序初始化

在使用不同的驱动程序时,用于装载该驱动程序的代码也会有所不同。有两种建立连接的方式。和所有 JDBC 资源一样,在使用完连接时,要调用连接关闭方法。

表 3. 驱动程序初始化比较
旧的 CLI 驱动程序通用驱动程序
为装载驱动程序和建立连接,需要三个基本步骤:

导入 JDBC 核心类(例如 import java.sql*)。

装载 JDBC 驱动程序 Class.forName (COM.ibm.db2.jdbc.app.DB2Driver)。

指定连接 URL: DriverManager getConnection jdbc:db2:coffebk。

通用驱动程序支持通过单个 driver.h 网络通信的 Type 2 和 Type 4 连接。DB2 UDB 使用分布式关系数据库架构(DRDA)来与服务器进行通信,并将请求传递给数据库服务器。

所使用的是 Type 2 还是 Type 4 驱动程序,是通过连接的形式来指定的。下面的连接形式表明使用的是 Type 2 还是 Type 4 驱动程序:

jdbc:db2//server:port/database
jdbc:db2//server/database

下面的连接形式意味着使用的驱动程序是 Type 2 驱动程序:
jdbc:db2:database

如果愿意,也可以使用 Type 3 驱动程序,在这种情况下,驱动程序的初始化就是: COM.ibm.db2.jdbc.net.DB2Driver可以通过所使用的连接级别在这两类驱动程序的物质层之间进行切换。

特性

随着 DB2 UDB, Version 8 的出现,Java 开发变得更加强大,而且编程工作也更具有独立性。现在,开发过程中的大部分精力都集中在添加新特性、改善新的 JDBC 通用驱动程序的内存管理和稳定性上。

表 4. 特性比较
旧的 CLI 驱动程序通用驱动程序
这类驱动程序需要专门安装 DB2 UDB 产品,因为它依赖于该产品的本机代码。这类驱动程序可以看作一个独立的产品。不需要安装产品,因为可以随很多 DB2 平台一起提供它。
旧的驱动程序版本是和 DB2 UDB 修复包相对应的,只能随一个修复包一起发布。JCC 驱动程序的发布独立于修复包。JCC 驱动程序有它们自己的版本,它们是根据 DB2 产品不同发行版的需要发布的。例如,DB2 V8.20 fp9 可能附带 2.3.9 版的 JCC 驱动程序,而 DB2 V8.20 OS/390 PTF UQ72081 可能附带 2.3.11 版的 JCC 驱动程序。

错误处理

这两类 JDBC 驱动程序处理错误的方式大相径庭。新驱动程序的错误消息仍在开发中,但是对于通用驱动程序而言,版本越新,其错误处理功能越好。典型的 JDBC 异常通常由 SQLErrorCode、SQLState 和 SQLMessage 组成。

表 5. 错误处理比较
旧的 CLI 驱动程序通用驱动程序
旧的驱动程序从 DB2 产品获得错误消息,然后将整个错误消息传递给应用程序。通用驱动程序不会重新创建由旧的 CLI/JDBC 产品发出的、预先存在的 SQL 错误代码。通用驱动程序有它自己定义的错误代码,其范围为 +/-4200 和 +/-4299。
 由通用驱动程序发出的未定义的错误代码被指定为 -99999。
 如果收到来自一个 DB2 子系统(例如底层 DB2 客户机库的 DB2 服务器)的错误,那么 JCC 只是回显那条错误消息。

事务管理

事务是一条或多条语句的集合,这些语句作为一个工作单元(UOW)一起执行。使用事务是为了确保一个 UOW 中的所有处理要么一起执行,要么都不执行。对于这些驱动程序,J2EE 指定了简单的事务管理。

表 6. 事务管理
旧的 CLI 驱动程序通用驱动程序
对于这类驱动程序,很早就已经提供了 XA 支持。从 V8.20 开始,Type 4 JDBC 通用驱动程序有了 XA 支持。

诊断问题和分析跟踪

JDBC 跟踪的组成

在 DB2 中,无论何时收到任何类型的异常,接下来的一步就是找出那个错误的来源。在大多数情况下,要找出错误的起因,需要进行某种类型的跟踪,以便通过跟踪来揭示导致错误的调用序列。

让我们来看看在 Java 中导致错误的调用序列,并研究在通常的 Java 应用程序中处理错误的机制。


图 1. Java 运行时环境
理解 DB2 UDB JDBC 通用驱动程序:内部人士指南

在 图 1 中可以看到,Java 运行时环境(JRE)包含用 Java 实现的错误处理机制。JRE 就像汽车中的引擎一样,使所有组件能够运行起来。

各组件可以由实际代码来表示,这些用 Java 编写的代码总是包含 try( ) 和 catch( ) 这两个代码块。每当实际代码碰到任何类型的错误,它就抛出一个异常,然后该异常就进入调用栈。调用栈将异常传递给 catch( ) 块,异常正是通过这种方式被返回给用户的。

为了允许 JDBC 程序抛出 SQLException,在技术实现上要确保程序能访问 com.ibm.db2.jcc.DB2Diagnosable 接口和 com.ibm.db2.jcc.DB2Sqlca 类。可以使用它们的完全限定引用,也可以导入它们:

import com.ibm.db2.jcc.DB2Diagnosable; 
import com.ibm.db2.jcc.DB2Sqlca 

SQLException 的组成

让我们来看看 SQLException() 类的一些细节,并弄清这个类的组成部分。总可以看到以下几个部分:

SQLException( 
Description of the error: null, string 
SQL State: null, string 
Error code: int value 
Next SQLException: null or pointer 
) 

通常可以通过调用 next SQLException 来返回链中的下一个异常。如果没有要返回的其他错误消息,则返回 null。

必要的存储过程

如果要使用通用 JDBC 驱动程序并连接到 OS/390,那么需要确保在主机上有一些必要的存储过程,这些存储过程将确保跟踪得以进行:

SQLCOLPRIVILEGES

SQLCOLUMNS

SQLFOREIGNKEYS

SQLGETTYPEINFO

SQLPRIMARYKEYS

SQLPROCEDURECOLS

SQLPROCEDURES

SQLSPECIALCOLUMNS

SQLSTATISTICS

SQLTABLEPRIVILEGES

SQLTABLES

SQLUDTS

SQLCAMESSAGE

这些存储过程是版本 6 的 PTF 附带的。需要 UQ72081 和 UQ72082。对于版本 7,PTF 号被定义为 UQ72083。如果需要关于如何安装这些 PTF 的具体信息,请参考 DB2 Information Center for z/OS,在那里可以获得详细的信息。

JCC 跟踪:概述

目前,JCC 驱动程序在跟踪和诊断问题方面的功能还不足以深入地诊断问题。目前的跟踪集还非常不稳定,主要是用于初步的分析。将来版本的 JCC 驱动程序将使跟踪功能更适合于问题诊断,并且更加面向问题。然而,JCC 跟踪中还是有几个关键的地方值得我们在后面加以讨论,它们有助于缩小问题的范围。

JCC 跟踪的实现有两种不同的方式,在接下来的两节中将详细讨论这两种方式。

如果您曾经见过 DRDA 格式的 DB2 跟踪,那么 JCC 跟踪看上去会非常熟悉。我们从 DRDA 跟踪中获取缓冲区,然后将它们放入实际的 JCC 跟踪中。别忘了,JCC 使用 DRDA 来与服务器进行通信。

如何进行 DB2 通用 JDBC 驱动程序跟踪

在跟踪一个 JCC 问题时,可以采取两种方法。根据环境的不同,可以使用以下两种方法之一:

把它作为一个独立的 JCC 应用程序来跟踪

在 WebSphere 中,嵌入 JCC 跟踪点

把 JCC 作为独立应用程序来跟踪

当把 JCC 组件作为独立应用程序来跟踪时,需要考虑与 DB2 通用 JDBC 驱动程序之间存在的连接的类型。

DataSource 接口
当为 JCC 连接使用数据源接口时,有两种方式来启用跟踪:

DB2DataSource > setTraceLevel > default TRACE_ALL

-javax.sql.DataSource.setLogWriter > TRACE_ALL only available

对于任何跟踪选项,除了 TRACE_ALL 属性外,还可以使用其他跟踪参数。根据所跟踪内容的不同,可以让 JCC 跟踪功能只跟踪以下属性:

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_NONE

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_CONNECTION_CALLS

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_STATEMENT_CALLS

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_RESULT_SET_CALLS

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_DRIVER_CONFIGURATION

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_CONNECTS

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_DRDA_FLOWS

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_RESULT_SET_META_DATA

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_PARAMETER_META_DATA

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_DIAGNOSTICS

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_SQLJ

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_XA_CALLS (仅适用于 Universal Type 2 Connectivity for DB2 UDB for Linux、UNIX 和 Windows)

com.ibm.db2.jcc.DB2BaseDataSource.TRACE_ALL

如果想跟踪不止一个特定的 traceLevel 属性,那么可以使用位操作符(|)来分隔不同的属性。通常,如果不知道想跟踪哪个特定的组件,那么最好使用缺省属性,即 TRACE_ALL。实际上,在大多数情况下,只需要知道这么多。但是如果需要更详细地规定跟踪某些 JDBC 通用驱动程序组件,那么可以通过位操作符来做到这一点。

另外提醒一点,如果想跟踪除了某个组件之外的所有组件,还可以使用另一个位操作符。这个位操作符就是(~)。

DriverManager
进行跟踪的第二种方法是使用连接的 DriverManager 接口,可以通过以下两种方法之一来打开跟踪:

DriverManager.getConnection
设置 info 参数或 URL 参数中的 traceLevel 属性。

DriverManager.setLogWriter
当使用这种方法打开跟踪时,可以指定跟踪目标,然后打开跟踪。下面是关于如何做到这一点的一个好例子:

清单 1. 使用 DriverManager.setLogWriter 的示例代码清单
// The traceLevel property is established through the URL syntax, 
// and driver tracing is directed to file "/temp/driverLog.txt" 
String databaseURL = 
"jdbc:db2://sysmvs1.stl.ibm.com:5021" + 
"/sample:traceFile=/temp/driverLog.txt;traceLevel=" + 
"(com.ibm.db2.jcc.DB2BaseDataSource.TRACE_DRDA_FLOWS " + 
"| com.ibm.db2.jcc.DB2BaseDataSource.TRACE_CONNECTS);"; 

还有一种方法也可以进行 JCC 跟踪,这种方法不用修改应用程序。 如果在客户机上创建一个名为 DB2JccConfiguration.properties 的文本文件,该文件中只有一行文本:
db2.jcc.override.traceFile=c:\jcc.trc
然后将该文件添加到 CLASSPATH 中,那么 JCC 跟踪将被自动启用。在不能更改任何源代码或 JCC 驱动程序属性的时候(例如,使用在内部使用 JCC 驱动程序的第三方产品),这种方法非常有用。请参考 DB2 Information Center 中的以下链接,以获得更详细的信息:
http://publib.boulder.ibm.com/infocenter/db2help/topic/com.ibm.db2.udb.rn.doc/rn/r0012130.htm.

在 WebSphere 跟踪中嵌入 JCC 跟踪点

如果在 WebSphere 环境中碰到一个 DB2 通用 JDBC 问题,那么可以在 WebSphere 跟踪中嵌入 JCC 跟踪点。这样就可以很方便地知道 JCC 组件在 WebSphere 调用中所扮演的角色,从而可以清晰地了解应用程序中所发生的事情。

下面是在 WebSphere 跟踪中设置 JCC 跟踪点的步骤:

在 WebSphere Application Server 中为 JDBC 设置跟踪属性。
进入 Resources > JDBC Provider > Data Sources > Additional Properties > Custom Properties。
需要设置的属性是:
traceLevel(-1 表示完全跟踪 TRACE_ALL)

打开跟踪。
进入 Troubleshooting > Logs and Trace > pick the server > Diagnostic Trace > Trace Specification: RRA=all=enabled:WAS.database=all=enabled
注意,这里可以指定两个跟踪字符串,之间用 ‘:’ 隔开,一个用于 WebSphere Application Server 资源适配器,另一个用于数据库(JDBC 驱动程序)。

通过使 traceFileName 属性空白,就足以自动在 WebSphere 跟踪中嵌入 JCC 跟踪点。可以动态地启用和禁用这种跟踪,在缩小问题范围的时候这样做会有所帮助。

JDBC 通用驱动程序错误代码

JCC 驱动程序只能发出少数几种 DB2 通用驱动程序错误代码。如果错误代码是通用驱动程序还没有定义的,那么它将回显一个 -99999 错误代码。下面是 DB2 通用 JDBC 驱动程序当前可用错误代码的一个参考:

表 7. 错误代码
4200在 XA 环境中,一个处在全局事务中的应用程序发出一个无效的提交或回滚
4498出现故障转移或故障恢复,事务失败
4499导致连接断开的严重错误
99999DB2 通用 JDBC 驱动程序发出没有错误代码的错误

目前由 -99999 这个通用错误代码定义的错误代码大约有 2000 条。下一阶段的 JCC 产品将用 SQLSTATE 和 SQLCODE 来定义这些错误代码。

JCC 跟踪的组成

在使用 JCC 驱动程序时,无论碰到何种类型的问题,为了作进一步的诊断,通常的做法是进行一个 JCC 跟踪。前面已经给出了进行 JCC 跟踪时所采取的步骤。现在让我们来剖析一个 JCC 跟踪,看看如何通过分析跟踪和找出错误的来源来彻底把问题弄清楚。


图 2. JCC 跟踪
理解 DB2 UDB JDBC 通用驱动程序:内部人士指南

图片看不清楚?请点击这里查看原图(大图)。

现在,让我们将一个跟踪分成几个部分,看看哪些部分在需要查看该诊断工具的各组件时会有用。在跟踪头中可以发现一些重要信息,这些信息对于理解环境非常有用。下面的编号对应 图 2 中的数字。

1. 所使用的 DB2 通用 JDBC 驱动程序版本
实际驱动程序版本是独立于修复包版本的。在 Java 应用程序开发支持页面上有一个详细的对照表,其中说明了每个 DB2 UDB 修复包所附带的 JCC 驱动程序的版本。

了解所使用的 JCC 驱动程序版本的另一种方法是在命令行中发出命令 db2jcc -version,该命令将显示当前使用的驱动程序的版本。

2. JDK 级别
表明和该 JCC 驱动程序一起使用的 Java 开发工具箱的版本。尽量使之与所使用的相应修复包保持同步。

跟踪头中包含的其他重要信息有:

操作系统的级别

路径信息

获得最新版本的 DB2 通用 JDBC 驱动程序的最好方法是下载最近用于 DB2 UDB for Linux、Unix 和 Windows 的修复包。

之所以要为 JDBC 驱动程序和相应的修复包使用不同的版本控制系统,是为了允许在所有 DB2 平台(包括 zSeries®、iSeries™ 等)上发布同一个驱动程序。这个驱动程序在所有 DB2 平台上是一致的。

现在让我们来看看 JCC 跟踪的主体,并试着将一些关键的元素拼接起来。

3. 跟踪标记
通过查看 JCC 跟踪中的标记,总可以确定所使用的通用驱动程序是 Type 4 风格的还是 Type 2 风格的:

[ibm][db2][jcc][t4] = 表明所使用的是 type 4 版本的驱动程序。

[ibm][db2][jcc][t2] = 表明所使用的是 type 2 版本的驱动程序。

4. DRDA 缓冲区
由于 JCC 规范是建立在 DRDA 协议之上的,我们将 DRDA 缓冲区嵌入在 JCC 跟踪中。这些缓冲区包含诸如 PreparedStatement 对象或 ResultSet 对象之类的项。如果熟悉 DB2 跟踪中常见的 DRDA 缓冲区,那么 JCC 跟踪中的 DRDA 缓冲区的感观看上去会很熟悉。如果在查看 DRDA 信息时有些迷惑,那么可以抓住关键的一点,那就是要执行的 SQL 语句。这条语句应该就嵌入在缓冲区中,并和 DB2 通用驱动程序将它发送到服务器进行处理时是一样的。

5. 使用的方法
如果您知道导致发生问题的 Java 方法,或者想在跟踪中看看一个特定的方法是如何使用的,那么可以从 JCC 跟踪中找到它。

如果您知道一个特定的语句或方法正在导致问题,那么总可以在 JCC 跟踪中搜索它,然后再对它进行上下搜索,从而发现任何值得怀疑的行为或错误消息,通过它们就可能找到能指示出问题所在的线索。

如果对错误感到没把握,那么可以从 DB2 UDB Technical Support 站点开始着手。

现在让我们来看一个有问题的跟踪的例子,该跟踪显示一个 -4499 错误,这是由 DB2 通用 JDBC 驱动程序定义的一个错误代码。

通常,当碰到任何与通用 JDBC 驱动程序有关的问题时,都将以某种类型的异常的形式来报告这个问题。


图 3. 跟踪例子
理解 DB2 UDB JDBC 通用驱动程序:内部人士指南

图片看不清楚?请点击这里查看原图(大图)。

从上面的跟踪中可以看到 -4499 这个返回代码。异常中还显示了通信错误,可以看到,在这种特定情况下,这就是要返回给应用程序的内容。

一个很好的技巧就是上下搜索这个异常,掌握在实际应用程序中所发生的情况。通过搜索发现这是否是与驱动程序有关的缺陷,如果是,那么试着使用最新版本的 JCC 驱动程序,在最新版本中这个问题可能已经被修复了。

结束语

通过比较基于 CLI 的旧 JDBC 驱动程序和新的 JDBC 通用驱动程序,我们看到,使用纯 Java 的 type 4 驱动程序有很多优点。通过进一步理解通用 JDBC 驱动程序所使用的跟踪,以及在进行跟踪时应搜索什么东西,可以帮助您解决在使用 JCC 驱动程序时可能碰到的任何问题。总而言之,更深入地理解 DB2 UDB JDBC 通用驱动程序,可以让您在 DB2 环境中进行下一阶段的 JDBC 应用程序开发时,在能力的提高上走得更远。

Tags:理解 DB UDB

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接