Rss & SiteMap

昂捷论坛 http://www.enjoyit.com.cn

中国零售业界精英论坛!
共2 条记录, 每页显示 15 条, 页签: [1]
[浏览完整版]

标题:xml转换为关系数据

1楼
netsnopy 发表于:2009/12/13 10:38:54

在学习自定义表单的过程中,增加表格域后,我们如何把表格中的数据取出来的?
c_data是xml类型的字段,所以表单域的所有值都在xml序列中,
无论query还是value返回的只是一个值,不能返回多值。那么如何像查询关系型数据一样,
返回xml序列中多个同名元素节点的内容呢。如:
<rows>
  <row>
    <e_vend>多个供应商</e_vend>
    <c_user />
    <eform_s_user>0000</eform_s_user>
    <e_dt>
      <drows>
        <drow>
          <v_tel>asdf</v_tel>
          <v_add>asdf</v_add>
          <v_name>asdfasd</v_name>
        </drow>
        <drow>
          <v_tel>电话2</v_tel>
          <v_add>第二个供应商的地址</v_add>
          <v_name>第二个供应商</v_name>
        </drow>
        <drow>
          <v_tel>电话3</v_tel>
          <v_add>第三个供应商的地址</v_add>
          <v_name>第三个供应商</v_name>
        </drow>
      </drows>
    </e_dt>
  </row>
</rows>
如何像取关系型数据一样,返回供应商名称、电话、地址三个字段的值。
在这里使用nodes()表值函数 和Apply 运算符来实现。APPLY 有两种形式:CROSS APPLY
和 OUTER APPLY。CROSS APPLY 仅返回外部表中通过表值函数生成结果集的行。
OUTER APPLY 既返回生成结果集的行,也返回不生成结果集的行,其中表值函数生成的列中的值为 NULL。
对于nodes()和apply还么有看的很明白,但是给我们提供了解决问题的方法,方法如下:
select T2.aa.query('.').value('(/drow/v_name)[1]','nvarchar(100)') as 供应商名称,
T2.aa.query('.').value('(/drow/v_tel)[1]','nvarchar(100)') as 供应商电话,
T2.aa.query('.').value('(/drow/v_add)[1]','nvarchar(100)') as 供应商地址
from tbc_eform_data
cross APPLY c_data.nodes('for $i in /rows/row/e_dt/drows/drow where $i/v_name!="" return $i' ) as T2(aa)
where c_guid='B71DC77C-6617-4743-B6AB-5E534970FB80'

这样对于自定义表单,可在审批后,通过执行sql脚本吧自定义表单的内容放置的数据库中,如采购员发起的供应商审批,可以在审批后把多个供应商信息或者合同信息按规则保存到系统中,省掉再录入一次供应商或者合同的过程,实现流程审批与业务系统自动化结合。

[此贴子已经被作者于2009-12-16 11:08:10编辑过]
2楼
wangxiaoxiao 发表于:2009/12/13 10:54:35

试一下。

共2 条记录, 每页显示 15 条, 页签: [1]

Copyright © 2006-2010 EnjoyIT.com.cn
网友言论或观点与昂捷公司无关!涉及版权/著作权问题请与发帖者直接联系
Powered By Dvbbs Version 8.2.0
Processed in 0.16406 s, 2 queries.