xml 路径的存储过程 - 按不起作用排序

Stored Proc for xml path - order by not working

我正在尝试使用可选的排序方式从数据库中提取记录。为此,我创建了一个存储过程(为了便于阅读,省略了几列):

CREATE PROCEDURE [dbo].[sp_VendorOverview] (@sortCol nvarchar(50)=NULL)

AS

BEGIN

    SET NOCOUNT ON;
    select v.Vid, s.Salutation, v.LastName, CONVERT(varchar(100), CAST(v.VAT AS decimal(38,0))) AS VAT
    from vendors v
    inner join Salutations s
    on v.salutation=s.anrede

    order by
        CASE WHEN @sortCol='LastName' THEN v.LastName
            WHEN @sortCol='FirstName' THEN v.FirstName
            ELSE NULL
        END,
        CASE WHEN @sortCol ='VendorNumber' THEN v.VendorNumber
            ELSE v.Vid
        END
    for xml path('VendorBasic'), root('Vendors')
END

当运行这个sp在SSMS中时,一切正常,结果符合预期。 然而,当尝试从 C# 应用程序中读取时,情况并非如此:

var vendoren = new List<VendorBasic>();

using (var con = new SqlConnection(ConfigurationManager.ConnectionStrings["Vendor"].ConnectionString))
{
    var xml = string.Empty;
    con.Open();
    using (var cmd = new SqlCommand("dbo.sp_VendorOverview", con))
    {
        if (!string.IsNullOrEmpty(orderby))
            cmd.Parameters.AddWithValue("@sortCol", orderby);

        using (XmlReader idr = cmd.ExecuteXmlReader())
        {
            if (idr.Read())
            {
                xml = idr.ReadOuterXml();
            }
            idr.Close();
        }
        con.Close();
    }
    if (xml != string.Empty)
    {
        XmlRootAttribute xRoot = new XmlRootAttribute
        {
            ElementName = "Vendors",
            IsNullable = true
        };
        var engine = new XmlSerializer(typeof(List<VendorBasic>), xRoot);
        vendoren = (List<VendorBasic>)engine.Deserialize(new StringReader(xml));
    }
}

反序列化工作正常,为 VendorBasic 设置了 XmlRoot 属性 class。 我确实得到了结果。 除了 Vid 之外,它们从未被其他任何东西订购过。我设置了一个断点来检查参数是否正确应用,以防我想按任何其他列排序。它是:

我错过了什么吗?我做错了什么吗?

您需要通过

告诉SqlCommand您正在执行存储过程而不是任意命令
cmd.CommandType = CommandType.StoredProcedure;

否则,它基本上会忽略所有参数并使用默认参数执行过程(在本例中为 null)。您可能会在这个问题中找到关于此的更多信息:When executing a stored procedure, what is the benefit of using CommandType.StoredProcedure versus using CommandType.Text?.