-- 作者: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编辑过]
|