SQL 内连接查询极慢
SQL query on inner join extremely slow
我在 SQL 服务器中有一个数据库。里面有2个table,暂且称它们为MASTER
和SLAVE
。它们之间是一对多的关系,所以一个MASTER
条记录可以连接到许多SLAVE
条记录。
这里是 table 创建者 SQL 命令(你也可以在那里看到我的索引):
CREATE TABLE [MASTER]
(
[gprs_id] INTEGER IDENTITY NOT NULL,
[date_time] DATETIME NOT NULL,
[valid] TINYINT NOT NULL,
[lat] REAL NOT NULL,
[lon] REAL NOT NULL,
CONSTRAINT MASTERPrimaryKey PRIMARY KEY NONCLUSTERED(gprs_id)
);
CREATE CLUSTERED INDEX MASTERDate ON MASTER (date_time);
CREATE TABLE [SLAVE]
(
[io_id] INTEGER IDENTITY NOT NULL,
[recordid] INTEGER NOT NULL,
[ioid] TINYINT NOT NULL,
[iovalue] FLOAT NOT NULL,
CONSTRAINT SLAVEPrimaryKey PRIMARY KEY CLUSTERED(io_id)
);
我进行了以下查询以从 SLAVE 查询数据:
DECLARE @fromdate datetime;
DECLARE @todate datetime;
SET @fromdate = '2014-01-01T00:00:00.000';
SET @todate = '2015-01-01T00:00:00.000';
SELECT
MASTER.date_time, SLAVE.*
FROM
MASTER
INNER JOIN
SLAVE ON MASTER.gprs_id = SLAVE.recordid
WHERE
date_time >= @fromdate
AND date_time <= @todate;
我的 SLAVE
table 中有大约 500 000 条记录,MASTER
中有大约 50 000 条记录。我发现查询非常慢,超过一分钟(如果我从 .net 代码的 SQL Server Management Studio 进行测试,也是一样的)。
我怎样才能加快速度?
感谢大家!
这是您的查询:
SELECT m.date_time, s.*
FROM MASTER m INNER JOIN
SLAVE s
ON m.gprs_id = s.recordid
WHERE m.date_time >= @fromdate AND m.date_time <= @todate;
此查询的最佳索引是:master(date_time, gprs_id)
和 slave(recordid)
。您现有的索引不是最优的。
在 [SLAVE].[io_id] 上创建索引并声明 FK 关系
我在 SQL 服务器中有一个数据库。里面有2个table,暂且称它们为MASTER
和SLAVE
。它们之间是一对多的关系,所以一个MASTER
条记录可以连接到许多SLAVE
条记录。
这里是 table 创建者 SQL 命令(你也可以在那里看到我的索引):
CREATE TABLE [MASTER]
(
[gprs_id] INTEGER IDENTITY NOT NULL,
[date_time] DATETIME NOT NULL,
[valid] TINYINT NOT NULL,
[lat] REAL NOT NULL,
[lon] REAL NOT NULL,
CONSTRAINT MASTERPrimaryKey PRIMARY KEY NONCLUSTERED(gprs_id)
);
CREATE CLUSTERED INDEX MASTERDate ON MASTER (date_time);
CREATE TABLE [SLAVE]
(
[io_id] INTEGER IDENTITY NOT NULL,
[recordid] INTEGER NOT NULL,
[ioid] TINYINT NOT NULL,
[iovalue] FLOAT NOT NULL,
CONSTRAINT SLAVEPrimaryKey PRIMARY KEY CLUSTERED(io_id)
);
我进行了以下查询以从 SLAVE 查询数据:
DECLARE @fromdate datetime;
DECLARE @todate datetime;
SET @fromdate = '2014-01-01T00:00:00.000';
SET @todate = '2015-01-01T00:00:00.000';
SELECT
MASTER.date_time, SLAVE.*
FROM
MASTER
INNER JOIN
SLAVE ON MASTER.gprs_id = SLAVE.recordid
WHERE
date_time >= @fromdate
AND date_time <= @todate;
我的 SLAVE
table 中有大约 500 000 条记录,MASTER
中有大约 50 000 条记录。我发现查询非常慢,超过一分钟(如果我从 .net 代码的 SQL Server Management Studio 进行测试,也是一样的)。
我怎样才能加快速度?
感谢大家!
这是您的查询:
SELECT m.date_time, s.*
FROM MASTER m INNER JOIN
SLAVE s
ON m.gprs_id = s.recordid
WHERE m.date_time >= @fromdate AND m.date_time <= @todate;
此查询的最佳索引是:master(date_time, gprs_id)
和 slave(recordid)
。您现有的索引不是最优的。
在 [SLAVE].[io_id] 上创建索引并声明 FK 关系