从SQL Server中的表中选择子列表数量

时间:2015-01-16 06:14:48

标签: sql sql-server-2008

我正在使用SQL服务器表,在技术方面我遇到了问题。 下面我附上了表查询的屏幕截图,结果也是必需的逻辑。 enter image description here 查询有两个部分,一个是没有任何条件,第二个是条件选择" qty"当parent_id为NULL时,else print 0,

我想打印"数量"子项目的数量与其父项的差异"数量"

这是脚本:

        GO

        CREATE TABLE [dbo].[#Temp_order](
            [order_id] [int] IDENTITY(1,1) NOT NULL,
            [orderdate] [datetime] NULL
        ) ON [PRIMARY]

        GO
        GO

        CREATE TABLE [dbo].[#Temp_order_list](
            [order_list_id] [int] IDENTITY(1,1) NOT NULL,
            [order_id] [int] NOT NULL,
            [qty] [int] NOT NULL,
            [price] [money] NOT NULL,
            [type] [int] NOT NULL,
            [parent_id] [int] NULL,
         CONSTRAINT [PK_Temp_order_list] PRIMARY KEY CLUSTERED 
        (
            [order_list_id] ASC
        )WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
        ) ON [PRIMARY]

        GO

        /*
        */
        INSERT INTO #Temp_order
                ( orderdate )
        VALUES  ( '2015-01-16 05:08:53'  -- orderdate - datetime
                  )
        INSERT INTO #Temp_order_list
                ( order_id, qty, price, type, parent_id )
        VALUES  ( (SELECT MAX(order_id) FROM #Temp_order), -- order_id - int
                  1, -- qty - int
                  10, -- price - money
                  2, -- type - int
                  NULL  -- parent_id - int
                  )  
        DECLARE @ParentID  AS INTEGER
        SELECT @ParentID =  MAX(order_list_id) FROM #Temp_order_list
        INSERT INTO #Temp_order_list
                ( order_id, qty, price, type, parent_id )
        VALUES  ( (SELECT MAX(order_id) FROM #Temp_order), -- order_id - int
                  1, -- qty - int
                  12, -- price - money
                  3, -- type - int
                   @ParentID -- parent_id - int
                  ) 
        INSERT INTO #Temp_order_list
                ( order_id, qty, price, type, parent_id )
        VALUES  ( (SELECT MAX(order_id) FROM #Temp_order), -- order_id - int
                  4, -- qty - int
                  13, -- price - money
                  3, -- type - int
                  @ParentID  -- parent_id - int
                  )    


        SELECT * FROM #Temp_order_list WHERE order_id = 1
        SELECT #Temp_order.order_id ,#Temp_order_list.order_list_id,#Temp_order_list.price,#Temp_order_list.type,
                CASE WHEN #Temp_order_list.parent_id IS NOT NULL THEN 0
                ELSE
                    ISNULL(#Temp_order_list.qty ,'') END AS quantity
                    FROM #Temp_order
                    INNER JOIN #Temp_order_list ON #Temp_order.order_id = #Temp_order_list.order_id

                    WHERE #Temp_order.order_id = 1

        DROP TABLE #Temp_order
        DROP TABLE #Temp_order_list

有更好的解决方案吗?

1 个答案:

答案 0 :(得分:1)

查看您的上一条评论,我建议您添加自我加入并检查该条件:

SELECT ordr.order_id,
       list.order_list_id,
       list.price,
       list.type,
       CASE
         WHEN parentlist.order_list_id IS NOT NULL THEN list.qty
         WHEN list.parent_id IS NOT NULL THEN 0
         ELSE ISNULL(list.qty, '')
       END AS quantity
FROM   #Temp_order ordr
       INNER JOIN #Temp_order_list list
               ON ordr.order_id = list.order_id
       LEFT JOIN #Temp_order_list parentlist
              ON parentlist.order_list_id = list.parent_id
                 AND list.qty > parentlist.qty
                 AND list.type = 3
WHERE  ordr.order_id = 1