【问题标题】:Data wont get inserted into database, heisql数据不会被插入数据库,heidisql
【发布时间】:2018-01-08 13:50:24
【问题描述】:

我想在我的数据库 (heidisql) 中插入一些数据。 但它不会被插入。知道为什么吗?

在我的表中loginname,email,algovarcharhashsaltchar。而stretch的数据类型为int

MySqlCommand cmd2;

cmd2 = dbConStr.CreateCommand();
cmd2.CommandText = "INSERT INTO `user` (Loginname, Email, Algo, Stretch, `Hash`, Salt) VALUES ('@loginname', '@email', '@algo', '@stretch','@hash', '@salt');";

cmd2.Parameters.Add("@loginname", MySqlDbType.VarChar).Value = loginname;
cmd2.Parameters.Add("@email", MySqlDbType.VarChar).Value = email;
cmd2.Parameters.Add("@algo", MySqlDbType.VarChar).Value = algo;
cmd2.Parameters.Add("@stretch", MySqlDbType.VarChar).Value = Convert.ToInt32(stretch);
cmd2.Parameters.Add("@hash", MySqlDbType.VarChar).Value = hash;
cmd2.Parameters.Add("@salt", MySqlDbType.VarChar).Value = salt;

MySqlDataReader r2 = cmd.ExecuteReader();

while (r2.Read())
{ }

r2.Close();

【问题讨论】:

  • 您是否遇到特定错误?
  • ExecuteReader()?不应该是ExecuteNonQuery()吗?您希望读取什么,尤其是在空循环的情况下?另外,我认为您不需要(甚至不需要)在值参数周围加上引号。这甚至是 MySQL 中参数的语法吗?已经有一段时间了,但我认为这只是一个?
  • 您可以使用ExecuteNonQuery....也可以使用heidisql 不是数据库,而是客户端GUI...您能更具体一点吗?
  • 省略每个参数的引号并使用 executeNonQuery 代替 reader
  • @David 确实,没有注意到,但看起来 '@' 也是有效的。几乎与stackoverflow.com/questions/13580993/… 重复

标签: c# heidisql


【解决方案1】:

在应为ExecuteNonQuery() 的ExecuteReader 旁边,您声明了错误的插入参数,不应单引号。试试:

INSERT INTO `user` (Loginname, Email, Algo, Stretch, `Hash`, Salt) VALUES (@loginname, @email, @algo, @stretch, @hash, @salt)

顺便说一句,有些数据库有不同的参数分隔符,不确定heidisql中是否是'@'

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-05-02
    • 2019-04-25
    • 1970-01-01
    相关资源
    最近更新 更多