Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/78.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql 查询运行太慢_Mysql_Sql - Fatal编程技术网

Mysql 查询运行太慢

Mysql 查询运行太慢,mysql,sql,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

我正在开发一个查询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;

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

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

我将假设tbl2.addrs是唯一的键。如果不是,那么您正在进行交叉连接,这既非常昂贵,也可能不是您想要的

这就是说:确保在tbl1.id和tbl2.addrs上有索引,还可以选择tbl1.date。

我假设tbl2.addrs是唯一的键。如果不是,那么您正在进行交叉连接,这既非常昂贵,也可能不是您想要的


这就是说:确保在tbl1.id和tbl2.addrs上有索引,还可以选择tbl1.date。

在查询中不需要表t3。您选择的唯一字段是addrs。但是,由于您要在该字段上加入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应用程序。使用查询参数。它们的可取之处之一是有时会加快查询速度。

在查询中不需要表t3。您选择的唯一字段是addrs。但是,由于您要在该字段上加入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应用程序。使用查询参数。它们的可取之处之一是有时会加快查询速度。

@user…您尝试过为表编制索引吗?请再次粘贴代码,这次选择整个块,然后单击“代码”按钮!手动运行查询需要多长时间?MySql Performance post还注意到字符串索引需要具有适当的大小写敏感度,否则速度会非常慢。在这种情况下,MySQL ADO.NET实现很奇怪。而且它只适用于MySQL ADO,我测试的所有其他连接器都工作得很好。@用户……您尝试过为表编制索引吗?请再次粘贴代码,这次,选择整个块,然后单击“代码”按钮!手动运行查询需要多长时间?MySql Performance post还注意到字符串索引需要具有适当的大小写敏感度,否则速度会非常慢。在这种情况下,MySQL ADO.NET实现很奇怪。而且它只适用于MySQL ADO,我测试的所有其他连接器都工作正常。