获得当前的运行过程

时间:2012-09-03 09:44:41

标签: c# mysql

我有一个程序,使用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();
}

2 个答案:

答案 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();

    }  
}