0

我创建了一个虚拟场景,它反映了我必须编写的许多查询,以检查我们正在导入的某些数据是否正确。

例如,当您有 3 个表时

  1. 店铺
  2. 顾客
  3. 顾客订单

ACustomer可以属于许多商店,但只能OrderOnsale购买 1 个 x 客户 x 商店。

似乎无法正确处理。下面是表格和点头数据+我的尝试。

IF object_id(N'Store', 'U') IS NOT NULL
   DROP TABLE Store
GO

CREATE TABLE [dbo].[Store]
(
    [Id] [bigint] NOT NULL,
    [StoreName] [varchar](50) NOT NULL,
    CONSTRAINT [PK_Store] PRIMARY KEY CLUSTERED ([Id] ASC)
) ON [PRIMARY]
GO

IF object_id(N'Customer', 'U') IS NOT NULL
   DROP TABLE Customer
GO

CREATE TABLE [dbo].[Customer]
(
    [CustomerId] [bigint] NOT NULL,
    [StoreId] [bigint] NOT NULL,
    [Name] [varchar](50) NOT NULL,
    [Surname] [varchar](50) NOT NULL,
    CONSTRAINT [PK_Customer] PRIMARY KEY CLUSTERED ([CustomerId] ASC)
) ON [PRIMARY]
GO

IF object_id(N'CustomerOrder', 'U') IS NOT NULL
   DROP TABLE CustomerOrder
GO

CREATE TABLE [dbo].[CustomerOrder]
(
    [OrderId] [bigint] NOT NULL,
    [CustomerId] [bigint] NOT NULL,
    [OrderName] [varchar](50) NOT NULL,
    [OnSale] [bit] NOT NULL,
    CONSTRAINT [PK_CustomerOrder] PRIMARY KEY CLUSTERED([OrderId] ASC)
) ON [PRIMARY]
GO

begin tran
   INSERT INTO [dbo].[Store]([Id], [StoreName])
        SELECT 1, N'Harrods' UNION ALL
        SELECT 2, N'John Lewis'

        INSERT INTO [dbo].[Customer]([CustomerId], [StoreId], [Name], [Surname])
        SELECT 1, 1, N'John', N'Smith' UNION ALL
        SELECT 2, 2, N'Joe', N'Blogg'

        INSERT INTO [dbo].[CustomerOrder]([OrderId], [CustomerId], [OrderName], [OnSale])
        SELECT 1, 1, N'Toys', 1 UNION ALL
        SELECT 2, 1, N'Laptop', 1 UNION ALL
        SELECT 3, 2, N'Toys', 0

        commit

我不完整的尝试:

SELECT
   HasCustomerBoughtMoreThanO1ItemOnSale =
      CASE WHEN Count(T2.TotalBoughtOnSale) > 1 THEN 1 ELSE 0 END 
FROM 
   CustomerOrder co1 
INNER JOIN 
   customer c1 ON co1.CustomerId = c1.CustomerId
INNER JOIN 
   STORE S01 ON C1.StoreId = S01.Id
JOIN 
   (SELECT 
       CO2.CustomerId, S2.Id AS StoreId, 
       Count(CO2.OnSale) TotalBoughtOnSale
    FROM 
       CustomerOrder CO2
    INNER JOIN 
       customer c2 ON c2.CustomerId = CO2.CustomerId
    INNER JOIN 
       STORE S2 ON C2.StoreId = S2.Id
    WHERE 
       CO2.OnSale = 1       
    GROUP BY 
       CO2.CustomerId, S2.Id) AS t2 ON c1.CustomerId = T2.CustomerId 
                                    AND S01.Id = t2.StoreId
4

1 回答 1

0

如果您的目标是单个客户购买的商品多于一件OnSale,那么此查询就可以解决问题。

SELECT
CO.CustomerId, C.StoreId
FROM CustomerOrder CO
INNER JOIN Customer C ON CO.CustomerId = C.CustomerId
WHERE OnSale = 1
GROUP BY CO.CustomerId, C.StoreId
HAVING COUNT(*) > 1

我应该补充一点,鉴于表中的一列,a只能购买Customer单个商品。StoreStoreIdCustomer

于 2014-06-08T16:15:03.770 回答