前往Shuct.Net首页

Shudepb PB反编译专家长时间以来,为业内同类软件事实上的唯一选择.细节,彰显专业.态度,决定品质.

关于PowerBuilder的搜索

PowerBuilder(pb)中 xml的应用一例_XML示例_脚本之家 脚 本 之 家 www.jb51.net 首页 网页制作 脚本专栏 网络编程 数据库 脚本下载 CMS教程 电子书籍 平面设计 媒体动画 操作系统 网站运营 网络安全 XML基础 XML示例 WML教程 特色栏目: vbscript 正则表达式 javascript 批处理 服务器软件 素材下载 页面导航: 首页 → 网络编程 → XML/RSS → XML示例 → 正文内容 PowerBuilder xml PowerBuilder(pb)中 xml的应用一例 发布:mdxy-dxy 字体:[增加 减小] 类型:转载 PowerBuilder中的数据窗口真是好的不得了,工作基本上都是围绕它做,很高效,这几天项目上需要用导出xml文件,就用pb9(xml导出导入功能是从PowerBuilder9.0增加的功能)做了一个demo以验证可行性 示例文件如下(不贴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接口文件,请一定要考虑使用者的方便性 QQ空间 新浪微博 腾讯微博 搜狐微博 人人网 开心网 百度搜藏 更多 Tags:PowerBuilder xml 复制链接收藏本文打印本文关闭本文返回首页 上一篇:javascript xml xsl取值及数据修改下一篇:UTF8转成GB2312乱码问题解决方案 相关文章 一个用xslt样式将xml解析为xhtml的类TransformBi用Asp与XML实现交互的一个实例源码在服务器端的XSLT过程中的编码问题本站用的rss输出javascript xml xsl取值及数据修改asp读取xml文件和记数XML中显示HTML的小技巧使用Spry轻松将XML数据显示到HTML页的方法 文章评论 最 近 更 新 PowerBuilder(pb)中 xml的应用一例气象 XML 数据源应用程序开发指南-内容目在服务器端的XSLT过程中的编码问题使用XSL将XML文档中的CDATA注释输出为HTMUTF8转成GB2312乱码问题解决方案asp下利用xml打包网站文件用xslt将xml解析成xhtml的代码一个用xslt样式将xml解析为xhtml的类Tranjscript与vbscript 操作XML元素属性的代码XML 增、删、改和查示例 热 点 排 行 PowerBuilder(pb)中 xml的应用一javascript xml xsl取值及数据修读大数据量的XML文件的读取问题jscript与vbscript 操作XML元素属用xslt将xml解析成xhtml的代码一个用xslt样式将xml解析为xhtml使用Spry轻松将XML数据显示到HTMasp下利用xml打包网站文件使用XSL将XML文档中的CDATA注释输XML中显示HTML的小技巧 关于我们 - 广告合作 - 联系我们 - 免责声明 - 网站地图 - 投诉建议 - 在线投稿 CopyRight &copy; 2006-2014 脚本之家 JB51.Net , All Rights Reserved