Solved

SQL - combine queries without using UNION ALL

Posted on 2013-01-19
7
406 Views
Last Modified: 2013-01-20
How can I combine the queries below without using UNIION ALL?
 
 SELECT ORDERS.orderid,
INVENTORY.partid,
Inventory.description,
ORDERITEMS.qty,
 Inventory.price,
 (OrderItems.qty * Inventory.price) AS 'Total Original Price',
 
 -----If an order contains ten or more units of a given product, give a 5% discount on that line item.

 (OrderItems.qty * Inventory.price *
CASE WHEN OrderItems.qty >=10 THEN 0.05 END) AS 'Total Discount Value' ,

----Get Total_Final_Price_After_Discount

 OrderItems.qty * Inventory.price - (OrderItems.qty * Inventory.price *
CASE WHEN OrderItems.qty >=10 THEN 0.05 END) AS 'Total_Final_Price_After_Discount'

FROM orders, inventory, orderitems
 WHERE ORDERS.ORDERID = ORDERITEMS.ORDERID AND ORDERITEMS.PARTID = INVENTORY.PARTID
 AND ORDERITEMS.qty >=10

 UNION ALL

 SELECT ORDERS.orderid,
INVENTORY.partid,
Inventory.description,
ORDERITEMS.qty,
 Inventory.price,
 (OrderItems.qty * Inventory.price) as 'Total Original Price',
 
----If an order contains five or more units of a given product, give a 2% discount for that line item.

(OrderItems.qty * Inventory.price *
CASE WHEN OrderItems.qty < 10 THEN 0.2 END) as 'Total Discounted Value',

----Get Total_Final_Price_After_Discount

 OrderItems.qty * Inventory.price - (OrderItems.qty * Inventory.price *
CASE WHEN OrderItems.qty < 10 THEN 0.2 END) AS 'Total_Final_Price_After_Discount'
 
 FROM orders, inventory, orderitems
 WHERE ORDERS.ORDERID = ORDERITEMS.ORDERID AND ORDERITEMS.PARTID = INVENTORY.PARTID
 AND ORDERITEMS.qty BETWEEN 5 AND 9
 ORDER BY ORDERS.orderid, INVENTORY.partid
0
Comment
Question by:ocdc
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
7 Comments
 
LVL 35

Expert Comment

by:David Todd
ID: 38797701
Hi,

Can you explain why you don't want to use union all?

Regards
  David
0
 

Author Comment

by:ocdc
ID: 38797723
would like to use CASE Statement only.   Also how can I  add STR   function for formatting dollar amounts  with two decimal place?  Thank you.

 CASE WHEN OrderItems.qty >=10 THEN 0.05 END) AS 'Total_Final_Price_After_Discount'
0
 
LVL 35

Expert Comment

by:David Todd
ID: 38797736
Hi,

Does this help?

I reformatted your select so it was readable and added this line to each case statement
else 0.00

SELECT 
	ORDERS.orderid
	, INVENTORY.partid
	, Inventory.description
	, ORDERITEMS.qty
	, Inventory.price
	, (OrderItems.qty * Inventory.price) AS 'Total Original Price'
  
	-----If an order contains ten or more units of a given product, give a 5% discount on that line item.

	, (
		OrderItems.qty 
		* Inventory.price 
		* CASE 
			WHEN OrderItems.qty >=10 THEN 0.05 
			-- added line
			else 0.00
		END
		) AS 'Total Discount Value'

	----Get Total_Final_Price_After_Discount

	, OrderItems.qty 
		* Inventory.price 
		- (
			OrderItems.qty 
			* Inventory.price 
			* CASE 
				WHEN OrdeItems.qty >=10 THEN 0.05 
				-- added line
				else 0.00
			END
		) AS 'Total_Final_Price_After_Discount' 

Open in new window

HTH
  David
0
Enterprise Mobility and BYOD For Dummies

Like “For Dummies” books, you can read this in whatever order you choose and learn about mobility and BYOD; and how to put a competitive mobile infrastructure in place. Developed for SMBs and large enterprises alike, you will find helpful use cases, planning, and implementation.

 

Author Comment

by:ocdc
ID: 38797774
I combined it as follows:  I get  5% and 2% discount as output for each item.   That is fine but  I need to format the Dollar values of  the  output columns.  Example: I am getting 10.000 which is correct . I need to format it to 10.00.

 So How can I format   OrderItems.qty
            * Inventory.price
            * CASE
                  WHEN OrderItems.qty >=10 THEN 0.05
                  -- added line
                  else 0.00
            END
            ) AS 'Total Discount Value'



SELECT
      ORDERS.orderid
      , INVENTORY.partid
      , Inventory.description
      , ORDERITEMS.qty
      , Inventory.price AS 'Unit price'
      , (OrderItems.qty * Inventory.price) AS 'Original Cost'
 
      -----If an order contains ten or more units of a given product, give a 5% discount on that line item.

      , (
            OrderItems.qty
            * Inventory.price
            * CASE
                  WHEN OrderItems.qty >=10 THEN 0.05
                  -- added line
                  else 0.00
            END
            ) AS 'Total Discount Value'

      ----Final Cost

      , OrderItems.qty
            * Inventory.price
            - (
                  OrderItems.qty
                  * Inventory.price
                  * CASE
                        WHEN OrderItems.qty >=10 THEN 0.05
                        -- added line
                        else 0.00
                  END
            ) AS 'Final Cost'  
            
            FROM ORDERS, INVENTORY, ORDERITEMS
 WHERE ORDERS.OrderID = ORDERITEMS.OrderID  AND ORDERITEMS.PartID = INVENTORY.PartID
 AND ORDERITEMS.qty >=10
 ORDER BY ORDERS.OrderId, INVENTORY.PartId
 
 UNION ALL
 
 SELECT
      ORDERS.orderid
      , INVENTORY.partid
      , Inventory.description
      , ORDERITEMS.qty
      , Inventory.price AS 'Unit price'
      , (OrderItems.qty * Inventory.price) AS 'Original Cost'
 
      -----If an order contains ten or more units of a given product, give a 5% discount on that line item.

      , (
            OrderItems.qty
            * Inventory.price
            * CASE
                  WHEN OrderItems.qty < 10 THEN 0.2
                  -- added line
                  else 0.00
            END
            ) AS 'Total Discount Value'

      ----Get Total_Final_Price_After_Discount

      , OrderItems.qty
            * Inventory.price
            - (
                  OrderItems.qty
                  * Inventory.price
                  * CASE
                        WHEN OrderItems.qty < 10 THEN 0.2
                        -- added line
                        else 0.00
                  END
            ) AS 'Final Cost'  
            
            FROM ORDERS, INVENTORY, ORDERITEMS
 WHERE ORDERS.OrderID = ORDERITEMS.OrderID  AND ORDERITEMS.PartID = INVENTORY.PartID
  AND ORDERITEMS.qty BETWEEN 5  AND  9
 ORDER BY ORDERS.OrderId, INVENTORY.PartId
0
 
LVL 35

Expert Comment

by:David Todd
ID: 38797841
Hi

With the lines I added to the case, loose the where clause, and loose the union all.

Formatting is something best left to presentation layer - excel, SSRS, web, application, etched.

Hth
  David
0
 

Author Comment

by:ocdc
ID: 38797854
Hi,

you only did -----If an order contains ten or more units of a given product, give a 5% discount

I also need one  for -----If an order contains 5 or more units of a given product, give a 2% discount.  And need to combine both in the CASE statement.  

As far as formatting is concern, I need to format the output columns to 2 decimal.    Thank you
 for your help.
0
 
LVL 35

Accepted Solution

by:
David Todd earned 500 total points
ID: 38797898
Hi

You should be able to add the 5+ Line into the case - they are evaluated top to bottom so test for 10+ then 5-10 etc.

Regards
  David
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

When writing XML code a very difficult part is when we like to remove all the elements or attributes from the XML that have no data. I would like to share a set of recursive MSSQL stored procedures that I have made to remove those elements from …
Introduction: When running hybrid database environments, you often need to query some data from a remote db of any type, while being connected to your MS SQL Server database. Problems start when you try to combine that with some "user input" pass…
NetCrunch network monitor is a highly extensive platform for network monitoring and alert generation. In this video you'll see a live demo of NetCrunch with most notable features explained in a walk-through manner. You'll also get to know the philos…
If you’ve ever visited a web page and noticed a cool font that you really liked the look of, but couldn’t figure out which font it was so that you could use it for your own work, then this video is for you! In this Micro Tutorial, you'll learn yo…

615 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question