首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查询运行速度太慢

查询运行速度太慢
EN

Stack Overflow用户
提问于 2013-04-03 05:55:30
回答 3查看 131关注 0票数 0

我正在开发一个查询MySQL数据库的C# WinForm应用程序。查询所需的时间慢得令人难以置信(30秒-1分钟)。我几乎没有使用数据库的经验,而且我似乎不知道我的查询出了什么问题。谁能指出我做错了什么。

代码语言:javascript
复制
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;
EN

回答 3

Stack Overflow用户

发布于 2013-04-03 06:00:42

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

票数 3
EN

Stack Overflow用户

发布于 2013-04-03 06:06:59

我将假设tbl2.addrs是一个唯一的键。如果不是,你就是在做交叉连接,这是非常昂贵的,而且可能也不是你想要的。

也就是说:确保在tbl1.idtbl2.addrs上有索引,也可以在tbl1.date上有索引。

票数 0
EN

Stack Overflow用户

发布于 2013-04-03 06:53:23

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

代码语言:javascript
复制
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应用程序。使用查询参数。它们的一个可取之处是,它们有时会加快查询速度。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15775151

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档