校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > powerbuilder(pb)中 xml的應用一例

powerbuilder(pb)中 xml的應用一例

熱門標簽:南寧網絡外呼系統運營商 本地電話機器人 r語言數據可視化地圖標注 如何修改多個百度地圖標注 400電話辦理包年 微信地圖標注合并了 東營電銷 隨州外呼調研系統 高德地圖地圖標注服務中心

示例文件如下(不貼DTD了,舉簡單例子說明一下)

復制代碼 代碼如下:

trans>
transdetail>
order>date/>/order>
orderdetail>product/>/orderdetail>
orderdetail>product/>/orderdetail>
/transdetail>
transdetail>
order>date/>/order>
orderdetail>product/>/orderdetail>
orderdetail>product/>/orderdetail>
/transdetail>
/trans>

我的表結構,我想大家的表也應該都是這樣設計的
order(銷售訂單,包括客戶,日期等信息)
orderdetail(銷售訂單明細,包括產品,數量及價格信息)

至此,可能明眼人一眼就能看出,這個xml的格式設置有些問題,例如這樣可能更加合理
復制代碼 代碼如下:

trans>
!--transdetail 這個節或許是多余的-->
order>
date/>
detail>!-- 明細是一個訂單的一部分,不應該脫離訂單頭-->
orderdetail>product/>/orderdetail>
orderdetail>product/>/orderdetail>
/detail>
/order>
order>
date/>
detail>
orderdetail>product/>/orderdetail>
orderdetail>product/>/orderdetail>
/detail>
/order>
/trans>

不過人家是ZF部門,改不了的,所以蹩腳也得做

pb9中的處理代碼:其實在pb9種只寫了三行代碼,真正的代碼其實只有一行,就是增加了一個窗口,上面放了一個數據窗口,一個按鈕,按鈕里寫了這么一行代碼,呵呵
dw_export.save("c:\test.xml",xml!,false)

其實真正要處理的是定義個兩個數據窗口,主要是定義他們的xml模版:
d_order(訂單頭數據出口,第二行代碼,可以在EITX中設置)
1.新建數據窗口(這里注意,如果如何條件的數據有多行時,最好在SQL中進行group,否則生成的數據會有重復)
3.在export/import template xml(下面簡稱EITX)編輯區點右鍵,save as另一個名字
4.把data export下的use template設置為你剛剛保存的模版名
定義好的模版如下所示:
復制代碼 代碼如下:

?xml version=~"1.0~" encoding=~"gb2312~" standalone=~"no~"?>
trans>
transdetail __pbband=~"detail~">!-- 在EITX中的transdetail節上點右鍵選中"starts detail" [注1] -->
order>
date>order_date/date>
/order>
dw_detail !-- 在EITX中的transdetail節上點右鍵選"add child"下的"datawindow control refrence" [注2] -->
/transdetail>
/trans>

有兩點需要注意
[注1]這個start detail,將控制數據的循環,所以需要選中,但是每個xml只能定義一個,這里就會產生一個問題,如果我訂單頭循環后,如何再讓訂單明細循環,結論是,在一個數據窗口中無法實現,必須分數據窗口進行處理,也就有了注2
[注2]我們需要在d_order中插入一個report,也就是d_orderdetail,在d_order中的control list(同在datawindow control refrence中相同)中就是dw_detail(默認名稱是dw_1,我改名了)

d_orderdetail(訂單明細數據出口,也就是上面report,dw_detail引用的數據窗口,第三行代碼,可以在EITX中設置)
1.新建數據窗口
2.在export/import template xml(下面簡稱EITX)編輯區點右鍵,save as另一個名字
3.把data export下的use template設置為你剛剛保存的模版名
?xml version=~"1.0~" encoding=~"gb2312~" standalone=~"no~"?>
detail>!-- 這兒定義為orderdetail是沒用的,牽套時,會被忽略 [注3]-->
orderdetail __pbband=~"detail~">!-- [注4] -->
product>product_name/product>
/orderdetail>
/detail>
[注3]注意,當我們在d_order中導出xml時,d_orderdetail中的xml聲明和頂節點會被忽略
[注4]這個地方定義的就是orderdetail部分,因為一個訂單可能會有多條明細信息,所以我們需要設置為start detail,也就是循環。

最后生成的文件如下
復制代碼 代碼如下:

trans>
transdetail>
order>date>20080101/date>/order>
orderdetail>product>甲/product>/orderdetail>
orderdetail>product>已/product>/orderdetail>
/transdetail>
transdetail>
order>date>20080102/date>/order>
orderdetail>product>甲/product>/orderdetail>
orderdetail>product>丙/product>/orderdetail>
/transdetail>
/trans>

注:如果讓你設計一個xml接口文件,請一定要考慮使用者的方便性

您可能感興趣的文章:
  • 使用PBFunc在Powerbuilder中支付寶當面付款功能

標簽:西雙版納 宿遷 拉薩 德州 益陽 果洛 寧夏 黃石

巨人網絡通訊聲明:本文標題《powerbuilder(pb)中 xml的應用一例》,本文關鍵詞  powerbuilder,中,xml,的,應用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《powerbuilder(pb)中 xml的應用一例》相關的同類信息!
  • 本頁收集關于powerbuilder(pb)中 xml的應用一例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 耿马| 清远市| 玉屏| 邻水| 息烽县| 弋阳县| 隆德县| 五河县| 崇仁县| 简阳市| 信阳市| 黑龙江省| 广灵县| 庐江县| 页游| 邹城市| 平遥县| 孟津县| 墨脱县| 新郑市| 天峨县| 横山县| 吉林省| 邯郸市| 阿拉善右旗| 河源市| 延安市| 湄潭县| 边坝县| 兴文县| 英山县| 哈尔滨市| 安义县| 镇原县| 镇安县| 麻栗坡县| 锦州市| 霍邱县| 晋州市| 仙居县| 平顺县|