;
帖子
3919 
精华
积分
11710 
鱼币
0 ¥ 
来自
大连 
在线时间
1858 小时 
注册时间
2007-6-11 
最后登录
2009-10-20 

贴图大师勋章新人进步勋章宣传大使勋章论坛元老勋章

3
发表于 2009-1-5 19:48 | 只看该作者
DataWindow鐨勬暟鎹紦鍐插尯 - 缂栫▼搴 - Powered by SupeSite

浣犵殑浣嶇疆锛缂栫▼搴 >> 璧勮 >> Power Builder >> DataWindow >> 璇︾粏鍐呭 鍦ㄧ嚎鎶曠ǹ

DataWindow鐨勬暟鎹紦鍐插尯

鍙戝竷: 2008-6-26 20:47 |  浣滆: admin |   鏌ョ湅: 11娆

DATAWINDOW鐨勫洓涓紦绔欏尯

鍦≒owerBuilder涓,DataWindow鏄敤鎴峰墠绔敤鏉ュ瓨鍌ㄣ佹搷绾垫暟鎹殑瀵硅薄銆傚湪姣忎竴涓狣ata Window瀵硅薄涓湁4涓簩缁磋〃浣滀负鏁版嵁缂撳啿鍖,鐢ㄦ潵瀛樺偍鏌ヨ鍒扮殑鏁版嵁銆傜敤鎴峰湪DataWindow涓鏁版嵁澶勭悊绯荤粺鍐呴儴鐨勬搷浣滃疄闄呬笂閮芥槸灏嗘暟鎹湪杩欏嚑涓紦鍐插尯涓繘琛岀殑淇敼鍜岀Щ鍔,鏈鍚庡湪鐢ㄦ埛鎻愪氦鏁版嵁搴撴椂,绯荤粺鏍规嵁杩欏洓涓紦鍐插尯涓殑淇℃伅褰㈡垚SQL鐨処N-SERT,UPDATE,DELETE绛夎鍙ャ傝繖鍥涗釜缂撳啿鍖烘槸:

Primary Buffer

杩欎釜缂撳啿鍖烘槸瀛樻斁濉厖绐楀彛涓璂ataWindow鎺т欢涓暟鎹殑,璋冪敤DataWindow鐨凴etrieve() 鍑芥暟鍜孖nsertRow()鍑芥暟鍙互灏嗘暟鎹~鍏ヨ繖涓紦鍐插尯涓傚綋浣跨敤鏈夊叧DataWindow鍒犻櫎鍜岃繃婊ゅ嚱鏁版椂,鐩稿簲璁板綍灏嗕粠杩欎竴缂撳啿鍖轰腑鍒犻櫎銆傝屽湪鎵цDataWindow鐨刄pdate()鍑芥暟鏃,PowerBuilder灏嗘煡鐪嬭繖涓缂撳啿鍖轰腑鐨勮褰,浠ュ舰鎴怱QL INSERT鍜孶PDATE璇彞銆

Delete Buffer

杩欎釜缂撳啿鍖轰繚瀛樼殑鏄敤DeleteRow()鍑芥暟浠嶱rimary Buffer涓垹闄ょ殑璁板綍,鎵цUpdate( )鍑芥暟鏃,绯荤粺鏍规嵁杩欎竴缂撳啿鍖虹殑璁板綍褰㈡垚DELETE璇彞銆

Filter Buffer

杩欎釜缂撳啿鍖哄瓨鍌ㄧ殑鏄粠Original Buffer浣跨敤Filter()鍑芥暟杩囨护鍒癙rimary Buffer涓悗鍓╀綑鐨勮褰曘

Original Buffer

杩欎竴缂撳啿鍖哄瓨鍌ㄧ殑鏄疍ataWindow鏈鍒濇墽琛宺etrieve()鍑芥暟鏃跺緱鍒扮殑鍏ㄩ儴璁板綍銆傚綋鎻愪氦鏁版嵁搴撴椂,鏍规嵁Primary Buffer鐢熸垚鐨刄PDATE璇彞鍜屾牴鎹瓺elete Buffer鐢熸垚鐨凞ELETE璇彞閮借渚濇嵁杩欎竴缂撳啿鍖烘潵鏋勯犺繖浜汼QL璇彞涓殑Where瀛愬彞銆

Original Buffer鐢盤owerBuilder鍐呴儴缁存姢,Power-Builder鎵鎻愪緵鐨勪换浣曞嚱鏁伴兘鏃犳硶鏀瑰彉瀹冪殑鍊,涓嶈繃閫氳繃PowerBuilder鎵鎻愪緵鐨凣etItem鈥︾郴鍒楃殑鍑芥暟鍙互璇诲嚭DataWindow鏈鍒濅粠鏁版嵁搴撲腑鏌ュ埌鐨勫師濮嬪笺傞氳繃杩欎簺鍑芥暟鎴戜滑鍙互缂栫▼瀹炵幇鎵璋撶殑"Undo"鍔熻兘,骞朵笖寰楀埌鍦ㄤ娇鐢ㄤ箰瑙傞攣鏃跺舰鎴愭彁浜ゆ暟鎹簱鐨刉HERE瀛愬彞銆

濡傛灉鎮ㄥ綋鍓嶄娇鐢ㄧ殑DataWindow娌℃湁璁剧疆淇敼鐨勬潈鍔,鎮ㄥ皢涓嶈兘瀵笵elete缂撳啿鍖哄拰Origin al缂撳啿杩涜鎿嶄綔,鑰屼笖褰撹皟鐢║pdate()鏃朵篃灏嗗紩璧风郴缁熼敊璇

鏁版嵁缂撳啿鍖虹殑鐘舵佸

Primary Buffer鍜孌elete Buffer閮芥湁琛岀骇鍜屽垪绾х殑鐘舵佸,杩欎釜鐘舵佸兼槸涓涓灇涓剧被鍨嬨傚湪鎻愪氦鏃剁敱璇ヨ鐨勭姸鎬佸兼潵鍐冲畾鏄惁瑕佷骇鐢烻QL璇彞,鍏朵腑Primary Buffer浜х敓鐨勬槸IN-SE RT鍜孶PDATE璇彞,鑰孌elete Buffer浜х敓鐨勬槸DELETE璇彞銆傛垜浠敤GetItem Status ()鍑芥暟鍜孲etItemStatus()鍑芥暟鍙互瀵硅繖涓鐘舵佸间綔鎿嶇旱銆傝繖涓鏋氫妇鐘舵佹湁浠ヤ笅鍥涚:

銉籒otModified!鈥曗曗曡琛屾垨琛岀殑鍊间负鏌ヨ鎵寰,娌℃湁鍙戠敓鏀瑰彉銆

銉籇ataModified!鈥曗曗曡琛屾垨鍒楃殑鍊间负鏌ヨ鎵寰,鍙戠敓浜嗘敼鍙樸

銉籒ew!鈥曗曗曡琛屾垨鍒椾负涓鎻掑叆鐨勬柊琛,鏁版嵁娌℃湁鍙戠敓鏀瑰彉(鏁版嵁涓虹┖鎴栫己鐪佸)銆

銉籒ewModified!鈥曗曗曡琛屾垨鍒椾负涓鎻掑叆鐨勬柊琛,鏁版嵁鍙戠敓鏀瑰彉

銆傛敼鍙樻槸閫氳繃鐢ㄦ埛閿洏杈撳叆鎴栬皟鐢ㄤ簡SetItem()鍑芥暟銆

璁╂垜浠潵鐪嬩笅闈㈣繖涓瀹炰緥:

鎴戜滑鏈夎繖鏍蜂竴寮犺〃,琛ㄤ腑鏈変笁涓瓧娈,鍏朵腑ITEM鏄富閿

ITEM CHAR(5);

NAME CHAR(20);

QUANTITY INT銆

鍦⊿cript涓垜浠煡璇㈣繖寮犺〃鐨勮褰,寰楀埌浠ヤ笅杩欎簺淇℃伅瀛樺偍浜嗗湪Primary鍜孫rigianalBu ffer涓,鍏朵腑鐨勮鍙锋槸缂撳啿鍖哄姞涓婄殑銆

鍦ㄧ獥鍙d腑,鎴戜滑缂栫▼杩囨护鎺夋暟閲忎负0鐨勮,骞朵笖鍔犱笂涓涓┖琛:

dw_1.SetFilter("quantity=0")

dw_1.Filter()

dw_1.InsertRow()

鐢ㄦ埛鍦ㄦ柊鎻掑叆琛屼腑杈撳叆鏁版嵁,鍒犻櫎浜嗙3琛屾暟鎹,骞朵慨鏀逛簡绗2琛屾暟鎹傚綋浠栫寮杩欎釜DataWindow鏃,Primary鍜孌elete缂撳啿鍖虹殑鐘舵

(浣犵煡閬撳悧锛)

杩欐椂鎵цdw_1.update()鍑芥暟,绯荤粺灏嗗熀浜庤繖涓や釜缂撳啿鍖虹敓鎴怱QL璇彞銆

鍦≒rimary Buffer涓,鐘舵佷负NotModified鍜孨ew!鐨勮灏嗚蹇界暐鑰屼笉浜х敓SQL璇彞銆傜姸鎬佷负DataModified鐨勮灏嗕骇鐢烾PDATE璇彞,鐘舵佷负NewModified鐨勮灏嗕骇鐢烮NSERT璇彞,鍦―ele te缂撳啿鍖轰腑鐨勮灏嗕骇鐢烡ELETE璇彞銆

鍥涗釜缂撳啿鍖哄湪缂栫▼涓殑杩愮敤

鏌愪簺DataWindow鎺т欢鐨勫嚱鏁版湁鎸囧畾DataWindow缂撳啿鍖虹殑鍔熻兘銆傚鏋滅己鐪,鍒欒〃绀篜rimar y缂撳啿鍖恒備笅鍒楁槸鍙互鎸囧畾缂撳啿鍖虹殑鍑芥暟:

銉籊etItemStatus()

銉籊etNextModified()

銉籊etUpdateStatus()

銉籗etItemStatus()

姝ゅ杩樻湁GetItem鈥︾郴鍒楃殑鍑芥暟,鐢ㄤ互鏌ヨDataWindow涓殑鍊笺傝繖浜涘嚱鏁版湁:

銉籊etItemDate()

銉籊etItemDataTime()

銉籊etItemDecimal()

銉籊etItemNumber()

銉籊etItemString()

銉籊etItemTime()

GetItem鈥︾郴鍒楀嚱鏁颁篃鍙互鎸囧畾缂撳啿鍖,鑰屼笖鍙互鍏佽鎮ㄦ寚瀹氭煡璇㈢殑鏄綋鍓嶅艰繕鏄師濮嬪(鏈鍒濅粠鏁版嵁搴撲腑鏌ュ埌鐨勫)銆傚:

dw_1.GetItemString(1,"name",Primary!,TRUE)

浣跨敤DataWindow鐨凴eset()鍑芥暟鍜孯etrieve()鍑芥暟浠ュ強鏀瑰彉DataObject灞炴ф椂,绯荤粺灏嗛噸缃繖鍑犱釜缂撳啿鍖恒

褰撶敤鎴锋彃鍏ヤ竴涓柊琛屾椂,缂栫▼鑰呭線寰瑕佽嚜鍔ㄥ湪鏂版彃鍏ヨ涓殑鏌愪簺鍒椾腑鎻掑叆涓浜涚己鐪佺殑鏁版嵁鍊笺傝繖鏃,鐢ㄦ埛骞舵病鏈夊鏁版嵁浣滀换浣曚慨鏀广傚彲鏄湪鐢ㄦ埛瑕佸叧闂繖涓绐楀彛鏃,濡傛灉鍦–loseQu ery浜嬩欢涓敤ModifiedCount()鍑芥暟鏌ョ湅鏁版嵁鏄惁淇敼,寰楀埌鐨勭粨鏋滄樉鐒舵槸鏈夋墍鏀瑰彉銆傜敤鎴峰皢寰楀埌涓涓彁绀轰俊鎭:"鏄惁鎵撶畻淇濆瓨鎵浣滅殑淇敼?鏄/鍚/鍙栨秷"鈥曗曗曡繖鏄剧劧鏄笉閫傚悎鐨:鑰屼笖濡傛灉鐢ㄦ埛閫夋嫨鐨勬槸淇濆瓨鏃,杩欎簺鍘熷簲鏄┖璁板綍鐨勮涔熸垚涓轰簡鏈夊唴瀹圭殑琛,绯荤粺灏嗗叾褰㈡垚SQL 鐨処NSERT璇彞鎻愪氦鏁版嵁搴,杩欐牱鐨勭粨鏋滄洿涓烘伓鍔c備负鏀瑰彉杩欎竴鐘跺喌,鎴戜滑鍙互鐢⊿etItemStatus()鍑芥暟灏嗚琛岀殑鐘舵佹敼涓篘ew!銆傚嵆褰撴湁鏂拌鎻掑叆骞朵笖璁剧疆浜嗙己鐪佸间箣鍚,璇ヨ鐨勭姸鎬佸间负New!銆備笅闈㈢殑绋嬪簭灏卞彲浠ュ緱鍒板涓婄殑鍔熻兘銆

鈭nsert a new row in dw_1

long 1_Row

1_Row=dw_1,InsertRow(dw_1,GetRow())

dw_1,SetItem(1_Row,"discount_pct",0,10)

鈭et th row status to New! so that the CloseQuery checkwill only detectus er entries.

dw_1.SetItemStatus(1_Row,0,Primary!,New!)

浣跨敤SetItemStatus鍑芥暟鏃舵湁涓浜涚姸鎬佽浆鎹㈢殑闄愬埗,涓嬭〃涓樉绀虹殑鏄皢鍘熸潵鐨勭姸鎬佹敼鍙樹负鍙︿竴鐘舵佹椂,浼氫骇鐢熺殑褰卞搷銆傝嫢琛ㄤ腑涓篘o,鍒欒鏄庣敤杩欎竴鍑芥暟杩涜杩欐牱鐨勮缃棤鏁;鑻ヨ〃涓粰鍑轰簡涓嶅悓鐨勭姸鎬,鍒欒鐘舵佹槸瀵规偍鎸囧畾鐨勭姸鎬佺殑鏇夸唬銆傚綋涓涓姸鎬佺殑鏀瑰彉涓嶈兘鍏佽鏃,鍙互澶氭璋冪敤SetItemStatus浠ュ緱鍒版湡鏈涚殑鐘舵併備緥濡, 浠嶯ew!鐘舵佷笉鑳芥敼鎴怤otModified!鐘舵,鍙皢鍏舵敼鎴怐ataModified!鐘舵,鐒跺悗鍐嶆敼鎴怤otMod ified!鐘舵併

鎵撳嵃 | 鏀惰棌姝ら〉 |  鎺ㄨ崘缁欏ソ鍙 | 涓炬姤
涓婁竴绡 涓嬩竴绡
 

璇勫垎锛0

鍙戣〃璇勮
鏌ョ湅鍏ㄩ儴鍥炲銆愬凡鏈0浣嶇綉鍙嬪彂琛ㄤ簡鐪嬫硶銆