使用VB.net来改变存储参数

时间:2015-02-23 20:33:29

标签: asp.net vb.net stored-procedures

我在使用VB.net修改存储过程变量时遇到问题。我在这个主题上发现了许多帖子,使它看起来像一个简单的.AddWithValue解决方案,但我最终得到了以下例外:

  

IListSource不包含任何数据源。

存储过程是一个动态数据透视表,可以很好地使用@dcs的静态值

CREATE PROCEDURE [dbo].[dcspull]
as
DECLARE @cols AS NVARCHAR(MAX),
        @colsNull AS NVARCHAR(MAX),
        @query  AS NVARCHAR(MAX),
        @dcs AS INT



select @cols = STUFF((SELECT ',' + QUOTENAME(FirstName) 
               FROM[Training Data]
               WHERE DataCenterID = @dcs 
               GROUP by FirstName
               ORDER by FirstName
        FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'),1,1,'')

select @colsNull = STUFF((SELECT  ', coalesce(' + QUOTENAME(FirstName)+''''') 
                AS '+QUOTENAME(+FirstName)
                FROM [Training Data]
                WHERE DataCenterID = @dcs
                GROUP by FirstName
                ORDER by FirstName
        FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'),1,1,'')


set @query = 'SELECT Topic, ' + @colsNull + ' 
                 FROM
                 (SELECT FirstName, Topic, Level
                 FROM [Training Data]) x
                 PIVOT
                    (MAX(Level)
                    FOR FirstName IN (' + @cols + ')) p'

execute(@query)

我试图通过VB.Net改变的唯一值是@dcs。静态设置@dcs时,Gridview会按预期填充,但只要我尝试将值传递给参数就会中断。

Dim SQLCon As String = ConfigurationManager.ConnectionStrings("tCString").ToString
Dim DBConnSQL As New SqlConnection(SQLCon)
Dim da As New SqlDataAdapter
Dim ds As New DataSet
DBConnSQL.Open()
Dim dbcheckone As New SqlCommand("dcspull", DBConnSQL)
dbcheckone.parameters.addwithvalue("@dcs", Convert.ToInt64(DropDownList1.Text))
da.SelectCommand = dbcheckone
da.Fill(ds)
GridView1.DataSource = ds
GridView1.DataBind()

我对存储过程相当新,我认为这是我对这段关系不了解的事情。

1 个答案:

答案 0 :(得分:0)

首先,我在您的存储过程中看不到任何参数。他们应该在AS之前来。 示例创建SP:

CREATE PROCEDURE HumanResources.uspGetEmployeesTest2 
    @LastName nvarchar(50), 
    @FirstName nvarchar(50) 
 AS 

现在,当您添加这些参数时,它应该在以下条件下工作:

  1. 您需要设置命令类型
  2. dbcheckone.CommandType = CommandType.StoredProcedure

    1. 即使您在通话期间未使用其他参数,您的程序签名和程序本身也不匹配。您不能省略非可选参数。所以你需要列出每个参数
    2. dbcheckone.parameters.addwithvalue("@cols"... dbcheckone.parameters.addwithvalue("@colsNull"... dbcheckone.parameters.addwithvalue("@query"... dbcheckone.parameters.addwithvalue("@dcs", Convert.ToInt32(DropDownList1.Text))

      关于此处的最后一行 - 您在代码中将其设置为Convert.ToInt64,但您的参数为int,因此它应与int32匹配。