如何使用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后实现填充下拉列表的最佳方法是什么?

如何使用SP查询Xml文档,并从代码后填充ASP下拉列表

我会更改您的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())。