查询运行太慢

时间:2013-04-02 21:55:30

标签: mysql sql

我正在研究一个查询MySQL数据库的C#WinForm应用程序。查询所需的时间令人难以置信(30秒 - 1分钟)。我对DB的经验很少,我似乎无法弄清楚我的查询有什么问题。有人可以指出我做错了什么。

string sql = "SELECT t1.date, t1.name, t2.name, t3.addrs
              FROM tbl1 t1 JOIN tbl2 t2 ON tbl1.id = tbl2.id
              JOIN tbl3 t3 ON t3.addrs = t2.addrs WHERE t1.date = '2013-04-01';";

string connStr = "Server = 10.10.10.100; Database = mydb; etc...";
MySQLConnection conn = new MySQLConnection(connStr);
MySQLCommand cmd = new MySQLCommand(sql, conn);
MySQLDataReader rdr = null;
DataTable dt = new DataTable();

dt.Columns.Add("Id","FirstName","LastName","Address","Date");

rdr = cmd.ExecuteReader();

while(rdr.Read())
{
    dt.Rows.Add(rdr["ID"], rdr["FirstName"], rdr["LastName"], rdr["Address"],rdr["Date"]);
}

conn.Close();
rdr.Close();

dataGridView.DataSource = dt;

3 个答案:

答案 0 :(得分:3)

我会确保你在连接字段和日期上有索引。

答案 1 :(得分:0)

我将假设tbl2.addrs是一个唯一的密钥。如果不是,那么你正在进行交叉加入,这既非常昂贵,也可能不是你想要的。

说:确保您在tbl1.idtbl2.addrs以及tbl1.date选择了索引。

答案 2 :(得分:0)

您的查询中不需要表t3。您选择的唯一字段是地址。但是,由于您要在该字段上加入t2,因此您只需从t2中选择它即可。这将是您的查询。

SELECT t1.date, t1.name, t2.name, t2.addrs
FROM tbl1 t1 JOIN tbl2 t2 ON tbl1.id = tbl2.id
WHERE t1.date = '2013-04-01'

此外,这看起来像.net应用程序。使用查询参数。他们的救赎品质之一是他们有时会加快查询速度。