婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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的應用一例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 崇仁县| 乌拉特后旗| 大同市| 西和县| 唐河县| 东台市| 砀山县| 台前县| 海淀区| 扎兰屯市| 楚雄市| 海伦市| 峨山| 丰台区| 浦北县| 八宿县| 涟源市| 定日县| 乐平市| 盘锦市| 丰城市| 如皋市| 海伦市| 延庆县| 老河口市| 凭祥市| 教育| 澄江县| 西丰县| 綦江县| 类乌齐县| 垦利县| 湘乡市| 滦平县| 扎赉特旗| 武夷山市| 延寿县| 横峰县| 明星| 电白县| 阜城县|