0

我在 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;
4

2 回答 2

0

我认为主要问题是从服务器返回的 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;
于 2018-08-08T07:37:54.160 回答
0

首先,您应该显示准确的查询,尤其是准确的 where 子句

我不能使用任何过滤器,因为我必须明智地展示数据位置。

这条线不清楚。这条线很重要,要理解。

对于 2 千万行来说distinct,这很重要。

删除不同。

还有为什么你会一次获取这么多记录。你必须应用分页。

根据您的可见查询,

在注册日期创建非聚集索引

Create non clustered index ix_Test on [Warehouse Entry]([Registering Date])include( [Location Code]
    ,[Bin Code]
    ,[Item No_]
    ,[Quantity]
    ,[Qty_ (Base)]
    ,[Zone Code]
    ,[Bin Type Code]
    ,[Lot No_]
)
于 2018-08-08T08:09:41.313 回答