PL/SQL :: How To Preserve Order When Using UNION
			Oct 24, 2012
				I'm combining three queries using the UNION operator.
for ex: 
select 'a' from DUAL
union
select 'd' from DUAL
[Code]....
I would like to see the same order as 
a
d
b
c
but it is showing as 
a
b
c
d
is it possible without using ORDER BY clause?
	
	View 8 Replies
  
    
	ADVERTISEMENT
    	
    	
        Aug 24, 2012
        I have the following sql
select htf.escape_sc(su.sukey) a, htf.escape_sc(su.sukey) b
from udm_su su, udm_lde lde
where su.ldeid = lde.ldeid
and su.sukey in (select su_generic 
 
[code]...
	View 3 Replies
    View Related
  
    
	
    	
    	
        Nov 3, 2012
        Oracle version : 11.2.0.2 Linux EL6 server
I have a query like below:
select col1, col2, col3, col4
from tab1, tab2, tab3
where conditions
union
[Code]...
Now, the col4 is a date column and I have to order by the entire result sets on it. I know I can do it by (order by col4) or by (order by 4) at the end of the entire query.
But the problem is that, the output is coming in dd-Mon-yyyy (i.e 31-Nov-2012).
I want every output in dd/mm/yyyy format so I need to use to_char function.
But in that case, I cant use the order by clause, because in that case it is getting arranged by character i.e by 1,2,3,4,5 like this.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Apr 22, 2010
        Is it better to use UNION (or) UNION ALL with DISTINCT,Which one will improve performance.
Query1:
SELECT  deptno FROM emp
UNION
SELECT deptno FROM dept
Query2:
SELECT DISTINCT * FROM(SELECT deptno FROM emp 
UNION ALL
SELECT deptno FROM dept)
I mean to say query1 is better (or) query2 is better,which query improves the performance.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 20, 2012
        Which step in the following plan is the first step of execution
I reckon it is "TABLE ACCESS BY INDEX ROWID| BANK_BATCH_STATE"
Is that correct?
In the "Predicate Information (identified by operation id):"
section the predicates - access and filter for the step "TABLE ACCESS FULL            | PYMNT_DUES" are displayed first
Isn't there any relation between the order of execution steps and the order in which predicates are displayed?
Execution Plan
----------------------------------------------------------
Plan hash value: 538700484
-------------------------------------------------------------------------------------------------------------
| Id  | Operation                            | Name                 | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT                     |                      |     1 |  2364 |    15  (14)| 00:00:01 |
|*  1 |  FILTER                              |                      |       |       |            |       |
|   2 |   HASH GROUP BY                      |                      |     1 |  2364 |    15  (14)| 00:00:01 |
|   3 |    NESTED LOOPS                      |                      |     1 |  2364 |    14   (8)| 00:00:01 |
|   4 |     NESTED LOOPS                     |                      |     1 |  2313 |    13   (8)| 00:00:01 |
|   5 |      NESTED LOOPS                    |                      |     1 |  2281 |    12   (9)| 00:00:01 |
|   6 |       NESTED LOOPS OUTER             |                      |     1 |  2255 |    11  (10)| 00:00:01 |
|*  7 |        HASH JOIN                     |                      |     1 |   175 |     6  (17)| 00:00:01 |
|*  8 |         INDEX RANGE SCAN             | INDX_2               |    12 |   612 |     2   (0)| 00:00:01 |
|*  9 |         TABLE ACCESS FULL            | PYMNT_DUES           |    43 |  5332 |     3   (0)| 00:00:01 |
|  10 |        VIEW PUSHED PREDICATE         |                      |     1 |  2080 |     5   (0)| 00:00:01 |
|  11 |         NESTED LOOPS                 |                      |     1 |   154 |     5   (0)| 00:00:01 |
|  12 |          NESTED LOOPS                |                      |     1 |   103 |     4   (0)| 00:00:01 |
|* 13 |           TABLE ACCESS BY INDEX ROWID| BANK_BATCH_STATE     |     1 |    32 |     2   (0)| 00:00:01 |
|* 14 |            INDEX RANGE SCAN          | INDX_BBS_1           |     3 |       |     1   (0)| 00:00:01 |
|* 15 |           TABLE ACCESS BY INDEX ROWID| DAILY_CHECK          |     1 |    71 |     2   (0)| 00:00:01 |
|* 16 |            INDEX RANGE SCAN          | INDX_SEARCH          |     1 |       |     1   (0)| 00:00:01 |
|* 17 |          INDEX RANGE SCAN            | INDX_2               |     1 |    51 |     1   (0)| 00:00:01 |
|* 18 |       INDEX RANGE SCAN               | INDX_IAM_SR_NO       |     1 |    26 |     1   (0)| 00:00:01 |
|* 19 |      INDEX RANGE SCAN                | INDX_2               |     1 |    32 |     1   (0)| 00:00:01 |
|* 20 |     INDEX RANGE SCAN                 | INDX_2               |     1 |    51 |     1   (0)| 00:00:01 |
-----------------------------------------------------------------
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 6, 2011
        I have below tables,
describe rpthead
Name                        Null     Type          
--------------------------- -------- ------------- 
RPTNO                       NOT NULL NUMBER        
RPTDATE                     NOT NULL DATE          
RPTD_BY                     NOT NULL VARCHAR2(25)  
PRODUCT_ID                  NOT NULL NUMBER 
describe rptbody
Name          Null     Type          
------------- -------- ------------- 
RPTNO         NOT NULL NUMBER        
LINENO        NOT NULL NUMBER        
COMMENTS               VARCHAR2(240)  
UPD_DATE               DATE           
The fact is that we store some header in RPTHEAD and store real data in RPTBODY, the question is that if I use below SQL to query all data for a 'PRODUCT_ID'.
SELECT  t0.LINENO, t0.COMMENTS, t0.RPTNO, t0.UPD_DATE  
FROM RPTBODY t0 , RPTHEAD rpthead 
WHERE 
(
  t0.RPTNO = rpthead.RPTNO 
  AND 
  t0.UPD_DATE>=to_date('1970/01/01 00:00:00','YYYY/MM/DD hh24:mi:ss') 
  AND  
  rpthead.PRODUCT_ID IN ('4647')  
)
I do not want to have 'ORDER by' clause since data set is too large, the sorting takes long time, is there any way to get the result rows in the order sorted by RPTNO? We have the index for RPTNO on RPTBODY.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 12, 2012
        is there any difference between
 - returning from the procedure 2 ref cursors containing result set of 2 queries
- returning from the procedure 1 ref cursor containing result set of that 2 queries as one (with UNION ALL)?
Will 2nd option be faster or similar to 1st?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 30, 2010
        I have a query which has 5 unions, each clause of the union takes 1 hr to run and query results come back in 5 hrs,  Is there any way I can make these clause to run in parallel?
	View 13 Replies
    View Related
  
    
	
    	
    	
        Aug 23, 2012
        I am facing an issue in union clause
Below is my query Issue faced is  that based on union I want to limit the result and  does not want second query to give duplicate result as both queries deal with same table
SELECT  TAB1.ID, TAB1.CRNCY_CODE, TAB2.SCHEME_CODE, DECODE( 'INFENG',CAST( ''  AS VARCHAR(20)),
NVL(TAB2.ALT1_SCHEME_DESC,TAB2.SCHEME_DESC),TAB2.SCHEME_DESC),  
TAB1.SUB_HEAD_CODE,  DECODE( 'INFENG' ,CAST( ''  AS VARCHAR(20)),NVL(TAB1.ALT1_SUB_HEAD_DESC ,
TAB1.SUB_HEAD_DESC),TAB1.SUB_HEAD_DESC) 
[code]...
select null ID,null crncy_code,TAB2.SCHEME_CODE  ,
NVL(TAB2.ALT1_SCHEME_DESC,TAB2.SCHEME_DESC),TAB2.SCHEME_DESC,null SUB_HEAD_CODE from TAB2 where TAB2.SCHEME_TYPE ='SCHEME1'; 
[CODE]
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 17, 2011
        I'm just trying to see if there is another way of doing this query without using a UNION.  The only way I can see is using a UNION but maybe I'm missing something or a way to do it without a UNION.
Result:
Select any customer within the user_states table who lives in "MO"
Select any customer within the user_cars table who lives in "MO" and has a "White" car
Select any customer within the user_plates table who lives in "MO" and has a plate of "A" or "B"
Join to the user_names table to display the customers name
So, the result would be any customer who lives in "MO" who owns a "White" car and any customer who lives in "MO" who has a plate of "A" or "B".
SQL
select b.customer_id,
b.first_name,
b.last_name
[Code]....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 28, 2010
        I have an query i.e.
I want 3 lines input in 1 line using 2 union operator like
Input:-
'i love playing
football and
volleyball'
i want the output like:-
"i love playing football and volleyball" 
solve query using 2 union operator?
	View 9 Replies
    View Related
  
    
	
    	
    	
        Jul 1, 2010
        how can i get a union of two pl/sql tables. ??
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 11, 2012
        Cant find any artice on what is better to use unpivot or union all. I can achive same results using either but cant decide what would be better. For example a table has columns:
Name 1, Phone1, Name 2, Phone 2. The result I want would be:
Name 1, Phone 1
Name 2, Phone 2.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Dec 21, 2010
        Is there any alternative to Union or Union all of two different table. Example would be great.
	View 5 Replies
    View Related
  
    
	
    	
    	
        May 24, 2011
         I've got function with combined sql statement (union all), how do I split it into two sql requests? This is to avoid time increasing of sql executing. IMHO good solution is to write two functions, how do you think? 
FUNCTION f_LintOVRDUAH
(mydate date,
cid number )
[Code]....
	View 18 Replies
    View Related
  
    
	
    	
    	
        Jun 5, 2012
        SELECT b.KPCNO
,b.KPC_FULL_NAME
,min(c.time) in_time
FROM xxkpc_hr_personnel_v2  b
,xxkpc_fingerscan_data_v c 
[code]........       
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 29, 2012
        I am new to SQL Oracle programming and have a question on a union query.  I am trying to get results (example) for the following:
Org #    Full_date     Run_date
5        2/20/2012     2/20/2012
5        2/21/2012     2/21/2012
5        2/22/2012     null (there is not a record for this)
6        2/20/2012     2/20/2012
6        2/21/2012     null
6        2/22/2012     2/22/2012
7        2/20/2012     2/20/2012
7        2/21/2012     2/21/2012
7        2/22/2012     2/22/2012
The dw_time table would have the listing of all dates, (Full_date) and the dw_capacity_daily table would have the run_date.  Here is my 
select * from (
select distinct a.Organization_Nbr, d.full_date
  from CMBHS_DW.DW_ORGANIZATION a, cmbhs_DW.DW_Organization_Identifier b, cmbhs_DW.DW_Contract c, cmbhs_dw.dw_time d
  where a.ORGANIZATION_NBR = b.ORGANIZATION_NBR
 [code]....
	View 7 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2010
        which one is better?
unloading 5 tables of same structure using a ETL tool then merging the data
using Union operator to unload 5 tables then do transformations in ETL tool
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 15, 2013
        How I can get the union result of 2 queries and put them in xml result, but I want each query to be in seperate xml element. I don t want to put 1 single xmlelement and do a From then construct a virtual table uniting the 2 subqueries
I mean I don t want something like the following:
(Select 
XMLAGG(                  
XMLELEMENT("credit",    
[Code]...
Except the 2nd alternative is not working I get error message:  "SQL command not properly ended"
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 24, 2011
        I have one scenario in which i want to write the sql,but not able to write correct qry,
tables
1-emp
2-emp_hist
3-dept
4-dept_hist.
i want to retrieve data from the emp and hist able based on some conditions,but if data is not present in emp and dept tables.then fetch data from emp_hist and dept_hist.I have written below qry which is working fine,but my prob is i want to provide my emp_id only one place.
else i have to change my java code.
select * from emp,dept where emp.emp_id=dept.dept_id and  emp_id=5
union
select * from emp_hist,dept_hist where emp_hist.emp_id=dept_hist.dept_id and  emp_id=5
	View 20 Replies
    View Related
  
    
	
    	
    	
        Sep 19, 2013
        I would like to SELECT these 3 hardcoded titles from DUAL, and have a blank line under each, on the output in this order from the SQL. But the result does not end up that way
SQL> set heading off;
1  select '#ENCODING       WINDOWS-1252' from dual
2  union
  3  select ' ' from dual
  4  union
  5  select 'Language Section        EN-US' from dual
  6  union
  7  select '  ' from dual
  8  union
  9* select 'Catalog Section Title   Date    Source' from dual
SQL> /
#ENCODING       WINDOWS-1252
Catalog Section Title   Date    Source
Language Section        EN-US
- - - - - - - - - - - - - - - - - 
Desired Output:
#ENCODING       WINDOWS-1252
Language Section        EN-US
Catalog Section Title   Date    Source
	View 12 Replies
    View Related
  
    
	
    	
    	
        Sep 18, 2012
        I am writing a query and I did get it to work but it shouldn't be this hard, I feel like I am doing something wrong, and there has to be a more elegent solution.
This query works:
SELECT a.d
FROM (
     SELECT S_ID a, LOOKUP_DESC d, S_CODE f
     FROM SSS
     JOIN LOOKUP ON S_CODE LIKE LOOKUP_CODE
     UNION ALL
  
[Code]...
I feel like I should be able to execute the query like this: This query doesn't work:
SELECT a.d
FROM (
     SELECT S_ID a, LOOKUP_DESC d, S_CODE f
     FROM SSS
     JOIN LOOKUP ON S_CODE LIKE LOOKUP_CODE
 
[Code]...
 -- not some huge query
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 18, 2013
        I have a requirement in SQL that I have to number each row. Hence I thought of using ROWNUM. But the sql query I'm using uses UNION operator. Hence I used like this
select a,b,rownum as 'field1' from table1
union
select c,d,1 as 'field1' from table2
Will the above query solve my purpose?
	View 11 Replies
    View Related
  
    
	
    	
    	
        Mar 5, 2013
        select to_char(sysdate, 'mm/dd/yyy') "DATE", to_char(sysdate, 'HH24:MI AM') "TIME", sum(bytes)/1024/1024/1024 "TOTAL_GB"
from dba_data_files
UNION ALL 
select to_char(sysdate, 'mm/dd/yyy') "DATE", to_char(sysdate, 'HH24:MI AM') "TIME", sum(bytes)/1024/1024/1024 "USED_GB"
from dba_segments 
[/HTML]
I like to get the output from the queries above.
DATE         TIME           TOTAL_GB      USED_GB      %USED
3/5/2013    06:00 AM     3151.24316    2330.40381   73.95
3/5/2013    12:00 PM     3151.24316    2347.41551   74.49
3/5/2013    06:00 PM     3151.24316    2349.76498   74.56
.....
[/HTML]
how I can format.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 9, 2012
        I have a view that contain multiple tables with ( UNION all ) clause , is there any way that if i query from this view I can explicitly specify the table that i need the data from ? 
Let say i have view that contain salaries of 2011 
Create view sals_2011 as select * from sals_jan2011 union all sals_feb2011 ..... union all select * from sals_dec2011. 
if i issued select * from sals_2011 where emp_id >500 and date < 01-feb-2011 the explain plan show me that full tables and indexes are in processing, while i know that i need only to scan sal_jan2011, and of course it is taking much longer time than selecting from the original table only.
I am using oracle RAC 11g R2
	View 5 Replies
    View Related
  
    
	
    	
    	
        Oct 21, 2012
        I am trying to display the results from 2 queries, one is supposed to display the count of the employees, per department, who win over the average of the entire company and the other one is supposed to display the count of the employees, per department, who win under the average of the entire company.
I used a UNION ALL, but all it does is merge the results from the ones that win over and under the average into one row, is there a way to separate them? I tried assigning names to each salary using AS but it only displays the first I put in.
 
sql          
Original
- sql Code 
(
SELECT DE.DEPARTMENT_NAME, COUNT (EM.EMPLOYEE_ID) AS MAYORES
FROM DEPARTMENTS DE, EMPLOYEES EM
WHERE DE.DEPARTMENT_ID = EM.DEPARTMENT_ID
AND EM.SALARY > (SELECT AVG(EM.SALARY) FROM EMPLOYEES EM)
GROUP BY DE.DEPARTMENT_NAME
[code].....
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 24, 2010
        We have very large table having data more than 1000 millions rows. We divide this table into four physical tables say A, B, C and D. The physical horizontal partition of data of this original table is done based upon their business policy. 
Each partitioned table has contained data of particular business entity. Further each table has partition and sub partitions based upon business rule.
We have to retrieve data from all these tables as follows:
select a1, a2, a3, a4, a5, a6
from A
where < logical filter condition>
union all
select b1, b2, b3, b4, b5, b6
[code].....
We observed that above each query block execute in serial one after another and individual each query block capable to process data in parallel from respective table. 
How does this above query able to execute each query block in parallel?
	View 14 Replies
    View Related
  
    
	
    	
    	
        Oct 13, 2010
        I am an Oracle newbie. 
We have 2 fact tables and one lookup table in this structure:
FACTTABLE1 (C1_ID, C2, SALE)
FACTTABLE2 (C1_ID, C3, SALE)
LOOKUPTABLE (C1_ID, C1_NAME)
The DBAs have built 2 Materialized Views, which aggregates data in the fact tables at column C1 level
MAT_VIEW1 :SELECT C1_ID, SUM(SALE) SALES from FACTTABLE1 join LOOKUPTABLE on C1_ID
MAT_VIEW2: SELECT C1_ID, SUM(SALE) SALE from FACTTABLE2 join LOOKUPTABLE on C1_ID
We are using an old BI tool that can ONLY generate Inline Views in these formats.
CASE1:
select
   INL_VIEW.C1_ID
  ,LOOKUPTABLE.C1_NAME
  ,sum(SALE) SALE
from
(select C1_ID, C2_ID, null C3_ID, SALE from FACTTABLE1)INL_VIEW
join LOOKUPTABLE
  on INL_VIEW.C1_ID = LOOKUPTABLE.C1_ID
group by INL_VIEW.C1_ID, LOOKUPTABLE.C1_NAME
CASE2:
select
   INL_VIEW.C1_ID
  ,LOOKUPTABLE.C1_NAME
  ,sum(SALE) SALE
from
(select C1_ID, null C2_ID, C3_ID, SALE from FACTTABLE2)INL_VIEW
join LOOKUPTABLE
  on INL_VIEW.C1_ID = LOOKUPTABLE.C1_ID
group by INL_VIEW.C1_ID, LOOKUPTABLE.C1_NAME
CASE3:
select
   INL_VIEW.C1_ID
  ,LOOKUPTABLE.C1_NAME
  ,sum(SALE) SALE
from
(
select C1_ID, C2_ID, null C3_ID, SALE from FACTTABLE1
union all
select C1_ID, C2_ID, null C3_ID, SALE from FACTTABLE2
)INL_VIEW
join LOOKUPTABLE
  on INL_VIEW.C1_ID = LOOKUPTABLE.C1_ID
group by INL_VIEW.C1_ID, LOOKUPTABLE.C1_NAME
Oracle 11g rewrites Case 1 and Case 2 to use the correct materialized views. But for case 3, it goes to the base fact tables 1 and 2. Is there a way to make oracle use the MVs even if there is a UNION ALL in the inline view? There is a 1:M Foreign Key relationship between LOOKUPTABLE.C1_ID and the 2 fact tables.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jan 14, 2011
        i have a union all query (two quiries i suppose) that runs fine and returns the results i am after.... when i try to use this query to create a view I get 
SQL Command: CREATE OR REPLACE FORCE Failed: Warning: execution completed with warning
CREATE OR REPLACE FORCE VIEW "schema1"."name_of_view" ("column1", "column2", "column3") AS 
SELECT b.column1, a.column2, c.column3
[Code].....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 6, 2012
        select 
a.empno,a.ename,a.job,
B.DNAME
from scott.emp a,scott.dept b
where ( a.ename like 'S%' and a.deptno=b.deptno)
union
select
a.empno,a.ename,a.job,
'aaa'  AS DNAME
from scott.emp a,scott.dept b
where ( a.ename like 'S%' and a.job not like 'SALES%');
Output:
7369SMITHCLERKRESEARCH
7369SMITHCLERKaaa
7788SCOTTANALYSTRESEARCH
7788SCOTTANALYSTaaa
Quote:There is other way to improve the query so that UNION can be removed.
	View 3 Replies
    View Related