我有一个程序,使用c#实时列出列表框中运行的所有当前进程。我把它插入mysql数据库时遇到了问题。我从进程的线程列表框中检索数据,然后保存到数据库。当列表框刷新时我遇到了问题,它重复将相同的数据插入到mysql数据库中。
有人可以帮我解决这个问题吗?
这是示例代码
foreach (String item in listBox1.Items)
{
cmd.CommandText = "SELECT * FROM sample";
MySqlDataReader msdr = cmd.ExecuteReader();
while (msdr.Read())
{
var items = msdr["log"].ToString();
if(items != item)
{
String query = "INSERT INTO sample values('','"+item+"')";
cmd.CommandText = query;
using(MySqlDataReader reader = cmd.ExecuteReader())
{
reader.Close();
}
}
}
msdr.Close();
}
答案 0 :(得分:1)
首先:从不在INSERT
语句中使用字符串。 始终使用Parameters。
第二:它取决于在哪里调用此代码。如果在 refresh 事件中调用它,可能正确的做法是了解是否有实际更改的内容,并且仅在正结果上执行SQL查询。
答案 1 :(得分:1)
像(未经测试)的东西:
foreach (String item in listBox1.Items)
{
cmd.CommandText = "SELECT COUNT(*) as cnt FROM sample WHERE log = @log";
cmd.Parameters.AddWithValue("@log", item)
bool found = ((int)cmd.ExecuteScalar()) > 0
if(!found)
{
String query = "INSERT INTO sample values('',@log)";
cmd.CommandText = query;
cmd.Parameters.AddWithValue("@log", item);
cmd.ExecuteNonQuery();
}
}