跨月字段SQL Server比较两个表之间的值
当前演示: 我要找的是在一个特定的月份里总共增加了多少个项目,但之后总共有多少个项目从未订购过 表:跨月字段SQL Server比较两个表之间的值,sql,sql-server,tsql,Sql,Sql Server,Tsql,当前演示: 我要找的是在一个特定的月份里总共增加了多少个项目,但之后总共有多少个项目从未订购过 表: CREATE TABLE Item ( ItemNo varchar(10) ,DateAdded varchar(10) ); CREATE TABLE Order1 ( OrderNo int, ItemNo varchar(10), OrderDate varchar(10) ); INSERT INTO Item (ItemNo, DateAd
CREATE TABLE Item (
ItemNo varchar(10)
,DateAdded varchar(10)
);
CREATE TABLE Order1 (
OrderNo int,
ItemNo varchar(10),
OrderDate varchar(10)
);
INSERT INTO Item (ItemNo, DateAdded)
VALUES ('111', 'Jan-17'),
('222', 'Jan-17'),
('333', 'Jan-17'),
('444', 'Feb-17'),
('555', 'Feb-17'),
('666', 'Feb-17');
INSERT INTO Order1 (ItemNo, OrderDate)
VALUES ('111', 'Jan-17'),
('111', 'Feb-17'),
('222', 'May-17'),
('333', 'Jan-17'),
('333', 'March-17'),
('444', 'Jan-17');
目前我有:
SELECT
-- b.OrderDate,
A.DateAdded,
COUNT(DISTINCT A.ItemNo) AS [Items Added],
COUNT(CASE WHEN c.ItemNo IS NULL THEN 1 END) as [Items Never Ordered]
FROM Item a
CROSS JOIN (SELECT DISTINCT OrderDate FROM Order1) b
LEFT JOIN Order1 c
ON a.ItemNo = c.ItemNo
AND b.OrderDate = c.OrderDate
GROUP BY A.DateAdded
产生:
| DateAdded | Items Added | Items Never Ordered |
|-----------|-------------|---------------------|
| Feb-17 | 3 | 11 |
| Jan-17 | 3 | 7 |
但我正在寻找一个结果集,例如:
| DateAdded | Items Added | Items Never Ordered |
|-----------|-------------|---------------------|
| Feb-17 | 3 | 2 |
| Jan-17 | 3 | 0 |
我正在努力让它工作。我是否需要子查询或其他东西来分别匹配这些项。有人能把我推向正确的方向吗?谢谢也许是这样:
WITH DataSource AS
(
SELECT A.*
,MAX([IsEverOrdered]) OVER (PARTITION BY ItemNo) [IsEverOrdered]
FROM Item A
OUTER APPLY
(
SELECT 1 [IsEverOrdered]
FROM Order1 B
WHERE A.[ItemNo] = B.[ItemNo]
) DS
)
SELECT DateAdded
,COUNT(DISTINCT ItemNo) AS [Items Added]
,SUM(CASE WHEN [IsEverOrdered] IS NULL THEN 1 ELSE 0 END) AS [Items Never Ordered]
FROM DataSource
GROUP BY DateAdded;
Commant表表达式返回是否有任何项已排序。然后,我们只需要计算/求和: