如何将参数传递给dataadapter?

问题描述 投票:0回答:1

我有下面的代码,我使用dataadapter从sql数据库表中选择数据,但我抛出一个错误:

“必须声明标量变量”@UserName“

代码中的错误在哪里????

我已经尝试了下面的代码,它会抛出错误“必须声明标量变量”@UserName“

 Dim Query as string ="SELECT *FROM UserLogins WHERE [Login Name]= 
 @Username  AND Password=@passcode"

 // add parameters to dataadapter select command
 SQL.da.SelectCommand.Parameters.AddWithValue("@Username", "%" + 
 txtuserName.Text + "%")
 SQL.da.SelectCommand.Parameters.AddWithValue("@passcode", "%" + 
 txtpasslogin.Text + "%")

  //execute query and fill dataset
        da = New SqlDataAdapter(Query,Con)           
        cb = New SqlCommandBuilder(da)
        ds = New DataSet
        da.Fill(ds)
 Datagridview1.Datasource=ds.tables(0)
sql vb.net dataadapter sqlparameters sqlcommandbuilder
1个回答
0
投票

哇,好吧,这段代码发生了很多奇怪的事情。

第一。两个斜杠(//)不是如何在VB.NET中完成注释。这是C#语法。改为使用单引号(')

接下来,您收到的错误是来自SQL Server的错误。

“必须声明标量变量@UserName”

LarsTech在他的评论中特别提到,您提供的代码首先添加变量,然后立即创建SQLDataAdapter的新实例。如果您修改代码以首先创建数据适配器,然后填充变量,您应该会得到更好的结果。

我不会假设已经声明了变量da,cb和ds,但是变量Con在某处被声明了。

Dim Query as string ="SELECT * FROM UserLogins WHERE [Login Name]=     
@Username  AND Password=@passcode"

'Note that I moved these two lines up here and made sure they were properly declared
Dim da as New SqlDataAdapter(Query,Con)           
Dim cb as New SqlCommandBuilder(da)

' add parameters to dataadapter select command
da.SelectCommand.Parameters.AddWithValue("@Username", "%" + 
    txtuserName.Text + "%")
da.SelectCommand.Parameters.AddWithValue("@passcode", "%" + 
    txtpasslogin.Text + "%")

' execute query and fill dataset

ds = New DataSet
da.Fill(ds)
Datagridview1.Datasource=ds.tables(0)

最后,你的sql语句也应该在*和FROM之间有一个空格,正如Mary在评论中所提到的,这里不需要%符号,因为你没有这样做。

© www.soinside.com 2019 - 2024. All rights reserved.