以文本方式查看主题

-  昂捷论坛  (http://enjoyit.com.cn/bbs/index.asp)
--  □-技术研讨会  (http://enjoyit.com.cn/bbs/list.asp?boardid=36)
----  xml转换为关系数据  (http://enjoyit.com.cn/bbs/dispbbs.asp?boardid=36&id=6664)

--  作者:netsnopy
--  发布时间:2009/12/13 10:38:54
--  xml转换为关系数据

在学习自定义表单的过程中,增加表格域后,我们如何把表格中的数据取出来的?
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编辑过]

--  作者:wangxiaoxiao
--  发布时间:2009/12/13 10:54:35
--  

试一下。