首页 > 解决方案 > 如何在超过 2000 万行的 sql 中加快查询速度

问题描述

我在 SQL 中有一个超过 2000 万行的表。数据从该表中的多个位置存储。我必须对日期进行查询。我不能使用任何过滤器,因为我必须明智地展示数据位置。从单个表运行数据需要 30 多分钟。我该如何管理它?我也尝试过索引,但没有任何区别

--  declare @DateTo as DateTime ='2018-08-01';

select distinct 
     [Location Code]
    ,[Bin Code]
    ,[Item No_]
    ,[Quantity]
    ,[Qty_ (Base)]
    ,[Zone Code]
    ,[Bin Type Code]
    ,[Lot No_]
    ,[Registering Date]
from 
    [Warehouse Entry]  
where  
    [Registering Date] <= @DateTo;

标签: sqlsql-serversql-server-2008

解决方案


我认为主要问题是从服务器返回的 20 000 000 条记录。它的时间成本很高。特别是,如果您正在查询“大”数据类型(xml、二进制等),并且您的服务器位于远程且互联网连接速度较慢。

小问题是 DISTINCT。您正在对所有要返回到前端的记录执行此操作。

永远不要将所有数据集返回到前端。请改用分页。

这是如何做到这一点的方法:

--  declare @DateTo as DateTime ='2018-08-01';
--  declare @page_size int = 25;
--  declare @page int = 1;

;with [data] as (
    select distinct 
         [Location Code]
        ,[Bin Code]
        ,[Item No_]
        ,[Quantity]
        ,[Qty_ (Base)]
        ,[Zone Code]
        ,[Bin Type Code]
        ,[Lot No_]
        ,[Registering Date]
    from 
        [Warehouse Entry]  
    where  
        [Registering Date] <= @DateTo
)
select
     [Location Code]
    ,[Bin Code]
    ,[Item No_]
    ,[Quantity]
    ,[Qty_ (Base)]
    ,[Zone Code]
    ,[Bin Type Code]
    ,[Lot No_]
    ,[Registering Date]
from 
    [data]   
order by     
    [Registering Date] asc
offset 
    @page_size * (@page - 1) rows fetch next @page_size rows only;

推荐阅读