2

我有一张桌子,我正在寻找一种方法来提高它的性能。下面是要执行的查询列表。

dbo.CustomersSmallOrders
(
    ID INT NOT NULL IDENTITY(1,1) PRIMARY KEY CLUSTERED,
    CustomerName VARCHAR(MAX) NOT NULL,
    OrderDate DATETIME NOT NULL,
    Quantity INT NOT NULL,
    Amount DECIMAL(15,2) NOT NULL,
    AvailableAmount DECIMAL(15,2) NOT NULL,
    Type TINYINT NOT NULL,
    Status TINYINT NOT NULL
)

您能否帮我重写下面的查询并向表中添加索引以提高其性能?

SELECT *
FROM CustomersSmallOrders
WHERE Left(CustomerName, 4) = 'Levis'

SELECT *
FROM CustomersSmallOrders
WHERE DateDiff(month, OrderDate, GetDate()) >= 30

SELECT *
FROM CustomersSmallOrders
WHERE Quantity * 2 < 3400

SELECT 
    SUM(CASE 
            WHEN Type = 2 AND STATUS IN (0, 1, 2) THEN Amount 
            ELSE 0 
        END)
    ,SUM(CASE 
             WHEN Type = 1 AND STATUS IN (0, 1) THEN Amount 
             ELSE 0 
         END)
    ,SUM(CASE 
             WHEN Type = 2 AND STATUS IN (0, 1) THEN Amount - AvailableAmount 
             ELSE 0 
         END)
FROM CustomersSmallOrders
WHERE STATUS IN (0, 1, 2)
4

1 回答 1

2

查询改进:

正如马丁史密斯所说,第一个查询可以转换为

SELECT TOP 0 * FROM CustomersSmallOrders

因为矛盾。

如果是

WHERE Left(CustomerName, 5) = 'Levis'

然后将条件更改为

WHERE CustomerName LIKE 'Levis%'

将保持查询sargable并允许使用索引。

可以通过更改条件并在 OrderDate 上添加索引来改进第二个查询:

SELECT *
FROM CustomersSmallOrders
WHERE OrderDate <= DATEADD(Mounth, -30, GetDate()) 

第三个(在数量上添加索引):

SELECT *
FROM CustomersSmallOrders
WHERE Quantity < 1700

第 4 次 - 在 STATUS 上添加一个索引,其中还包含 Type、Amount 和 AvailableAmount(虽然我不明白他为什么要两次 Amount。我认为这可能是一个错误,他只想要 1 列输出):

SELECT 
SUM(CASE 
        WHEN Type = 2 THEN Amount 
        ELSE 0 
    END)
,SUM(CASE 
         WHEN Type = 1 AND STATUS IN (0, 1) THEN Amount 
         ELSE 0 
     END)
,SUM(CASE 
         WHEN Type = 2 AND STATUS IN (0, 1) THEN Amount - AvailableAmount 
         ELSE 0 
     END)
FROM CustomersSmallOrders
WHERE STATUS IN (0, 1, 2)
于 2015-03-26T08:35:46.593 回答