首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SqlCommand AddWithValue

SqlCommand AddWithValue
EN

Stack Overflow用户
提问于 2012-01-17 14:11:43
回答 3查看 17.4K关注 0票数 1
代码语言:javascript
复制
SqlCommand command = new SqlCommand("SELECT * FROM users WHERE Username =  ? AND Password = ?", connection);
command.Parameters.AddWithValue("Username", username);
command.Parameters.AddWithValue("Password", password);
SqlDataReader reader = null;
reader = command.ExecuteReader();

当我运行程序时

语法错误在“?”附近。

在这条线上:

代码语言:javascript
复制
reader = command.ExecuteReader();

有人能看到我做错了什么吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-01-17 14:12:37

代码语言:javascript
复制
using(SqlCommand command = new SqlCommand("SELECT * FROM users WHERE Username =  @Username AND Password = @Password", connection))
{
  command.Parameters.AddWithValue("@Username", username);
  command.Parameters.AddWithValue("@Password", password);
  using(SqlDataReader reader = command.ExecuteReader())
  {
    while(reader.Read())
    {
      //do actual works
    }
  }
}

使用using关键字进行改进,这是不必要的,但建议

票数 9
EN

Stack Overflow用户

发布于 2012-01-17 14:13:55

代码语言:javascript
复制
SqlCommand command = new SqlCommand(
    "SELECT * FROM users WHERE Username = @Username AND Password = @Password",
    connection);
command.Parameters.AddWithValue("Username", username);
command.Parameters.AddWithValue("Password", password);
SqlDataReader reader = null;
reader = command.ExecuteReader();

您可能需要阅读sql。

票数 1
EN

Stack Overflow用户

发布于 2012-01-17 14:14:05

您使用的是哪个DBMS?如果使用的是Server,则查询的语法不正确。你需要:

代码语言:javascript
复制
SqlCommand cmd = 
    new SqlCommand(@"select * 
                     from users 
                     where username = @username and password = @password");

command.Parameters.AddWithValue("@username", username);
command.Parameters.AddWithValue("@password", password);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8896025

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档