如何使用SP查询Xml文档,并从代码后填充ASP下拉列表
本文关键字:代码 填充 下拉列表 ASP SP 何使用 查询 Xml 文档 | 更新日期: 2023-09-27 17:49:45
给定xml:
<?xml version="1.0" encoding="UTF-8"?>
<root>
<lfSpec1ForLoc>
<a href="/spec.aspx?id=20" title="AI">AI</a>
</lfSpec1ForLoc>
<lfSpec2ForLoc />
<lfSpec3ForLoc />
<lfSpec4ForLoc />
<lfSpec5ForLoc />
<lfSpec6ForLoc />
<lfSpec7ForLoc />
<lfSpec8ForLoc />
<lfSpec9ForLoc />
<lfSpec10ForLoc />
</root>
我的URL是:www.mypage.com/off.aspx?id=12
我有以下存储过程:
ALTER PROCEDURE [dbo].[MySP]
(
@LstrID varchar(200), -- 12 {from the query string in the above URL}
)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
SELECT
CAST ([con] AS XML).query('/root/lfSpec1ForLoc/a') AS [Spec1]
, CAST ([con] AS XML).query('/root/lfSpec2ForLoc/a') AS [Spec2]
, CAST ([con] AS XML).query('/root/lfSpec3ForLoc/a') AS [Spec3]
, CAST ([con] AS XML).query('/root/lfSpec4ForLoc/a') AS [Spec4]
, CAST ([con] AS XML).query('/root/lfSpec5ForLoc/a') AS [Spec5]
, CAST ([con] AS XML).query('/root/lfSpec6ForLoc/a') AS [Spec6]
, CAST ([con] AS XML).query('/root/lfSpec7ForLoc/a') AS [Spec7]
, CAST ([con] AS XML).query('/root/lfSpec8ForLoc/a') AS [Spec8]
, CAST ([con] AS XML).query('/root/lfSpec9ForLoc/a') AS [Spec9]
, CAST ([con] AS XML).query('/root/lfSpec10ForLoc/a') AS [Spec10]
FROM
[myDB1].[dbo].[con]
WHERE
[folder_id] = 106
AND
[content_id] = '%' + Lstr + '%'
END
SP的结果是:
Spec1 Spec2 Spec3 Spec4 Spec5 Spec6 Spec7 Spec8 Spec9 Spec10
<a href="/spe.aspx?id=1" title="AI">AI</a> <a href="/spe.aspx?id=5" title="QW">QW</a>
我想填充下面的下拉列表:
<ASP:DropDownList runat="server" ID="ddl1"></ASP:DropDownList>
所以HTML输出如下:
<SELECT>
<option value="/spe.aspx?id=1">AI</option>
<option value="/spe.aspx?id=5">QW</option>
</SELECT>
在执行SP后实现填充下拉列表的最佳方法是什么?
我会更改您的PROC
以更好地使用Xquery和Sql Server的xml解析功能。
您可以从您的PROC中做的是项目(URL, Title)
对表从您的xml记录在您的表中的查询简单如:
SELECT Nodes.node.value('(a/@href)[1]', 'varchar(100)') AS URL,
Nodes.node.value('(a/@title)[1]', 'varchar(100)') AS Title
FROM
(
SELECT CAST(con.con AS XML) AS con,
folder_id,
content_id
FROM con
) x
CROSS APPLY x.Con.nodes('/root/*[a]') as Nodes(node)
WHERE
[folder_id] = 106
AND
[content_id] LIKE '%' + @LstrID + '%';
/root/*[a]
将导航所有lfSpecxForLoc
节点(无论名称),并仅过滤那些具有a
子元素的节点,从而避免了过滤掉null的需要。此外,通过将元素投影为单独的行,您不需要删除10个显式列—有多少行就有多少行。
下面是上述查询投影的结果表的SqlFiddle。
从这里开始,将结果集拉入ADO数据阅读器或将其绑定到下拉列表是一个简单的任务(例如将.DataSource
设置为数据阅读器,并在DropDownList
上调用.DataBind()
)。