[英]SQL Server : clustered index slow
我有2个数据库表:
Message
表 MessageData
我加入他们以获得2个日期之间的传感器值。
查询以99%的时间缓慢返回结果,以寻找聚簇索引。
如何改善这个表现? 在索引或查询方面有什么建议吗?
我对联接运行以下查询:我使用主键> 3264353049进行过滤,以防止查找日期与过去几年的行有关
SELECT
t.MessageId, t.DataSourceId, t.[Value],
DataSource.SourceNameId, DataSource.Name
FROM
[MessageData] t
INNER JOIN
[Message] m ON t.MessageId = m.MessageId
LEFT JOIN
DataSource ON t.DataSourceId = DataSource.DataSourceId
WHERE
t.MessageId > 3264353049
AND m.ObjectId = @objId
AND m.GpsTime BETWEEN @dtFrom AND @dtTo
AND m.Valid = 1;
我有这些索引:
ALTER TABLE [MessageData]
ADD CONSTRAINT [AnalogData_PK]
PRIMARY KEY CLUSTERED ([MessageId] ASC, [DataSourceId] ASC)
CREATE NONCLUSTERED INDEX [MessageData_DataSourceId_IDX]
ON [MessageData] ([DataSourceId] ASC)
GO
CREATE NONCLUSTERED INDEX [IX_gpstime_objectid]
ON [Message] ([GpsTime] ASC)
INCLUDE ([MessageId], [ObjectId])
GO
CREATE UNIQUE CLUSTERED INDEX [Message_Object_UK]
ON [Message] ([ObjectId] ASC, [GpsTime] ASC, [MessageId] ASC)
GO
消息表数据:
MessageId ObjectId VectorAngle VectorSpeed Altitude GpsTime X Y VisibleSatelites
-------------------- ----------- ----------- ----------- ----------- ------------------------------ ---------------------- ---------------------- ----------------
9988600080 192 0 0 0 2017-07-19 00:03:20 0 0 0
9988600082 192 0 0 0 2017-07-19 00:08:20 0 0 0
9988600086 192 0 0 0 2017-07-19 00:13:20 0 0 0
9988600089 192 0 0 0 2017-07-19 00:18:20 0 0 0
9988600092 192 0 0 0 2017-07-19 00:23:20 0 0 0
和MessageData
表数据:
MessageId DataSourceId Value SourceNameId Name
-------------------- ------------ ---------------------- ------------ ------------------------------
9988600080 6364 0 1 Engine
9988600080 6365 0 2 Digital Input Status 2
9988600080 325346 0 179 DOUT 1
9988600080 325347 0 180 DOUT 2
9988600080 334214 0 69 Bettary
9988600082 6364 0 1 Engine
9988600082 6365 0 2 Digital Input Status 2
9988600082 325346 0 179 DOUT 1
9988600082 325347 0 180 DOUT 2
9988600082 334214 0 69 Bettary
9988600086 6364 0 1 Engine
9988600086 6365 0 2 Digital Input Status 2
9988600086 325346 0 179 DOUT 1
9988600086 325347 0 180 DOUT 2
9988600086 334214 0 69 Bettary
9988600089 6364 0 1 Engine
9988600089 6365 0 2 Digital Input Status 2
9988600089 325346 0 179 DOUT 1
9988600089 325347 0 180 DOUT 2
9988600089 334214 0 69 Bettary
9988600092 6364 0 1 Engine
9988600092 6365 0 2 Digital Input Status 2
9988600092 325346 0 179 DOUT 1
9988600092 325347 0 180 DOUT 2
9988600092 334214 0 69 Bettary
就像评论中提到的那样,我一定会更新我的统计信息。 但是之后,我将查看此索引:
CREATE UNIQUE CLUSTERED INDEX [Message_Object_UK]
ON [Message] ([ObjectId] ASC, [GpsTime] ASC, [MessageId] ASC)
该查询执行该讨厌的嵌套循环连接,因为它必须查找并找到具有特定messageID的记录,该记录必须从Message表索引中的EACH记录中提取。 尝试将其更改为:
CREATE UNIQUE CLUSTERED INDEX [Message_Object_UK]
ON [Message] ([MessageId] ASC, [ObjectId] ASC, [GpsTime] ASC )
这有可能使您获得哈希或合并联接
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.