SQL & PL/SQL :: Creating Oracle Query To Fetch Information Using PIVOT Option?
			Feb 27, 2013
				creating Oracle SQL query to fetch the information using PIVOT option.We are populating audit table using triggers. For every update, there will be two rows into audit table, one row with all OLD values and another with all NEW values. Also every updated is uniquely identified by Sequence No. Example for phone audit is mentioned below :
CREATE TABLE test_audit_phone 
( 
emplid VARCHAR2(10), 
seqno  NUMBER, 
action VARCHAR2(3), 
office NUMBER, 
mobile NUMBER 
); 
Insert some rows into table.
INSERT INTO test_audit_phone VALUES ('100',1,'OLD',1111,9999) 
/
INSERT INTO test_audit_phone VALUES ('100',1,'NEW',2222,9999) 
/
INSERT INTO test_audit_phone VALUES ('100',2,'OLD',2222,9999) 
/
INSERT INTO test_audit_phone VALUES ('100',2,'NEW',2222,8888) 
/
Table will look like the following :
SQL> SELECT * FROM sysadm.test_audit_phone ;
EMPLID          SEQNO ACT     OFFICE     MOBILE                                 
---------- ---------- --- ---------- ----------                                 
100                 1 OLD       1111       9999                                 
100                 1 NEW       2222       9999                                 
100                 2 OLD       2222       9999                                 
100                 2 NEW       2222       8888                                 
Now we have to present data in different format. For each field, display OLD and NEW values in column format.
EMPLIDFIELDOLDNEW
-----   ------  ----    -----
100OFFICE11112222
100MOBILE99998888
Challenges : 
1) Make pivoting with old and new values 
2) For each field we have to show old and new values 
3)if old and new values are same, dont show in report.
	
	View 8 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Jan 24, 2011
        I have a requirement to write a single sql query where i can generate the pivot report. Found some of the examples in Google search. But here we are hard coding the values if it is limited like month in this example.
i want to write similar  query to represent the amount based on product type , i have around 200 types of products. I can't write case/ decode statement those many times.
query which will produce the output in pivot format , dynamically depending the number of values.
select Product,
sum(case when Month=�Jan� then Amount else 0 end) Jan,
sum(case when Month=�Feb� then Amount else 0 end) Feb,
sum(case when Month=�Mar� then Amount else 0 end) Mar
from Sales
group by Product
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jul 13, 2010
        the view from where we can fetch information for a foreign key viz. reference table, referenced columns etc.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jun 10, 2011
        I am getting error while trying to create a table
SQL>
SQL> CREATE OR REPLACE TABLE CEE_OSPCM_DETAILS
  2  (
  3  ORD_NBR                    VARCHAR2(10) NOT NULL,
  4  ORD_APPNDX         NUMBER(2)    NOT NULL,
  5  FRCOI_NBR          NUMBER,
  6  PRINT_NBR          VARCHAR2(4),
[code]....
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 4, 2011
        I got a error  while creating a partition table
I did following steps
SQL> show user
USER is "ROSE"
SQL>
SQL> create table sales (year number(4),
  2  product varchar2(10),amt number(10,2))
  3  partition by range (year)
[code]....
ORA-00922: missing or invalid option
SQL>
SQL> SELECT NAME FROM V$TABLESPACE;
NAME
------------------------------
SYSTEM
UNDOTBS1
SYSAUX
USERS
[code]....
	View 8 Replies
    View Related
  
    
	
    	
    	
        Jul 22, 2013
        I have an application connected to Oracle 11g that sends its own querys to the db based on what the user is clickng on. The applicaiton is connected via one user id and I was wondering, is there a way that I can capture the tiem each query starts, the sql itself, and the amount of time it took to fetch the data?
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jul 22, 2009
        I'm trying to do a pivot query in oracle to get the years from a column and make a separate column for each. I found an example of the code to use on the internet and i changed it for my own tables but i'm getting errors. Namely a "FROM keyword not where expected" error at the beginning of the 'avg(...' statements.
I have copied the code used in 
select stud_id, 2006, 2007, 2008, 2009
from (
select stud_id, 
avg(case when year=2006 then ((present/poss)*100) else null end) 2006,
avg(case when year=2007 then ((present/poss)*100) else null end) 2007,
avg(case when year=2008 then ((present/poss)*100) else null end) 2008,
avg(case when year=2009 then ((present/poss)*100) else null end) 2009
from attendance.vw_all_attendance_perc
group by stud_id
);
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jun 28, 2012
        I am having two tables 
Table 1 having 16 cror rows .
Table 2 having 1000 rows
I joined both the tables and fetch all inforamtion from big table for those key present in small table.Join query taking more time to fetch the rows .
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 3, 2013
        I have a form on a table that allows me to edit, delete, or create records. If I choose to edit a record from the report the form get populated correctly and edits or deletes work fine. My problem is when I choose to create a new record. I get a blank form which is what I want, but once I fill it out and click the create button, the automated row fetch fires again and gives me a no data found error.  How do I get it to not fire when the create button is pressed?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 23, 2007
        Is there anyway to pivot the results of a query?
so if i have:
SELECT GROUP, count(*)
FROM GROUP
GROUP BY GROUP
And it give the following output:
A      10
B      50
c      24
Is there anyway to put into this format?
A     B      C
10   50     24
I am doubting that there is and that i am going to have to handle this in my code later, but it never hurts to ask!
	View 1 Replies
    View Related
  
    
	
    	
    	
        Dec 17, 2011
        I've tried for pivot query feature of Oracle 11g, but I'm trying for pivot result on multiple column.
Herewith I'm displaying my try on single column pivot query.
SQL> select * from
  2  (select deptno,job,sal
  3  --,comm
  4  from emp)
  5  pivot (sum(sal) as payment for job in('CLERK','SALESMAN','MANAGER'))
  6  order by 1;
[code]....
I've tried this one also, but it didn't seems to be working.
SQL> select * from
  2  (select deptno,job,sal,comm
  3  from emp)
  4  pivot (sum(sal) as payment_sal,sum(comm) as payment_comm for job in('CLERK','SALESMAN','MANAGER'))
  5  order by 1;
[code]....
        
I want result like below.
    DEPTNO PAYMENT 'CLERK'_PAYMENT 'SALESMAN'_PAYMENT 'MANAGER'_PAYMENT
---------- ------- --------------- ------------------ -----------------
        10 SAL1300                                 2450
        20 SAL1900                                 2975
        30 SAL 950               5600              2850
        30 COMM 2200 
is it possible to have multiple column pivot query.
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 27, 2011
        I'm using pivot query feature of oracle 11g and came across a strange situation where i need to pass a "select statement" in a "in clause" of pivot query. 
SQL> CREATE TABLE TEST1
  2  (
  3    UIN         NUMBER(8)                         NOT NULL,
  4    TESTING_ID  NUMBER(4),
  5    PFA_RESULT  VARCHAR2(30 BYTE)
  6  );
[code]....
I have tried with pivot xml but it not giving desired output in sql*plus session.It is giving unreadable output.
select * from 
(select uin,testing_id,pfa_result from test1)
pivot xml (max(pfa_result) as result
for (testing_id) in (select distinct testing_id from test1));
[code]....
Here actually i want to use "select distinct id from test1" instead of "in (11,12,13,14,15)". Because i don't know how many id's will be there and of which values. e.g. 11 or 21 or 25.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jul 20, 2011
         me in building a query. I want to show the result of the query just like pivot table.
Test case
CREATE TABLE CPF_YEAR_PAYCODE
(
  CPF_NO        NUMBER(5),
  INC_DATE      DATE,
  PAYCODE_TYPE  CHAR(1 BYTE),
 
[code]...
I want that my query should look like the format as attached in the xls sheet.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 22, 2012
        I am attempting to user PIVOT and DENSE RANK in a query the following is the query and the record set it returns (condensed and de-identified)
"select * from(
select * from (select dense_rank() over (partition by 1 order by cal.weeksort desc) WEEK_nbr, 
u.user_title Manager_Title, replace(hier.manager, '<br>',' - ') Manager, 
replace(hier.user_hin, '<br>',' - ') user_name, 
to_char(cal.calendar_date_week - 6, 'MM/DD/YYYY') ||' - '|| to_char(cal.calendar_date_week, 'MM/DD/YYYY') Week_of, 
upper(substr(cal.day_of_week, 1,3)) DOW, count(distinct Pers_gen_key) cnt from apexim.hrw_member_action act
[code]....
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 8, 2012
        I am having the following pivot query but I am not able to run it is giving error msg
ORA-00937: not a single-group group function
  SELECT   DISTINCT
           C.SHORT_NAME,
           MAX (
              COUNT (DECODE (TO_CHAR (a.reg_date_cur, 'MON'), 'JAN', A.CAR_NO))
        
[code]...
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 23, 2013
        Just a general query on parallel query.  My customer having 4 cpus and running the database in 11.2.0.3 in AIX 5.3(One is in AIX 6.1). Under which circumstances, we can propose to user parallel query options.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 25, 2007
        Is it possible to query a mp3 file's ID3 information, or the properties where you can put in artist, album, etc. information?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 5, 2010
        i'm trying to display the heirarichal relationship between the tables (parents-child-subchild).
[b]table structure[/b]
DEPT
 |PK-DEPT_ID
 |
EMP
 |pk-EMP_ID
[code]....
Expected output
table_name                  path
DEPT                        DEPT
EMP                         DEPT/EMP
EMP_AUTHORIZATION           DEPT/EMP/EMP_AUTHORIZATION
EMP_AUTHRIZATION_CARD       DEPT/EMP/EMP_AUTHORIZATION/EMP_AUTHRIZATION_CARD
EMP_AUTHRIZATION_DUP        DEPT/EMP/EMP_AUTHORIZATION/EMP_AUTHRIZATION_CARD/EMP_AUTHRIZATION_DUP
but by using below query i am getting complete heirarichy.
SELECT    LEVEL, 
Table_Name,
Constraint_Name,
R_Constraint_Name ,
SYS_CONNECT_BY_PATH(Table_Name, '/') Path
[code]....
	View 6 Replies
    View Related
  
    
	
    	
    	
        Feb 6, 2013
        We are importing data from one DB to other.Schema contains 200 tables and each table contains 1million rows. We are using query option to subset the data using different conditions instead of loading full table data .
We want to subset from different tables. But query option in expdp only taking 1800 characters only. why it is taking upto 1800 characters only. Any restriction imposed on query option.how to increase query clause length?
below is the example of export command.
otispa/********@otisua1 schemas=tbaadm directory=PA_OTIS_DIR dumpfile=tbaadm
data.dmp CONTENT=all tableexists_action=replace query='tbaadm.ACCOUNT_LIEN_HISTORY_TABLE:"where ACID in(select FINACLE_INT_BNK_ACC
T_ID from INIT_ACCT_LD)"','tbaadm.DISCRET_ADVN_TABLE:"where ACID in(select FINACLE_INT_BNK_ACCT_ID from INIT_ACCT_LD)"','tbaadm.TEMP
DISCRETADVN_TABLE:"where ACID in(select FINACLE_INT_BNK_ACCT_ID from INIT_ACCT_LD)"','tbaadm.PYMNT_RCPT_DET_TABLE:"where ACID in(s*
*elect FINACLE_INT_BNK_ACCT_ID from INIT_ACCT_LD)"','tbaadm.STOP_PAYMENT_ADDTNL_TABLE:"where ACID in(select FINACLE_INT_BNK_ACCT_ID f*
*rom INIT_ACCT_LD)"','tbaadm.STOP_PAYMENT_REG_TABLE:"where ACID in(select FINACLE_INT_BNK_ACCT_ID from INIT_ACCT_LD)"','tbaadm.GEN_AC*
[code].....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 5, 2012
        how to write the query option in expdp ....in expdp by using query option...
where columnname between '05-May-12 02:57:00.000 AM' and '6-May-12 02:59:59.999 AM';
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 28, 2011
        I want to create a materialized view for the last 10 days with the enable query rewrite option.
e.g. i want to create a view with the list of employees who joined the company in the last 10 days.
create materialized view  M_Employee
refresh fast on commit
enable query rewrite  as
select joining_date , name
from
employee
where joining_datde   <   TRUNC(sysdate) - 10
I seem to get the error SQL Error: ORA-30353: expression not supported for query rewrite
30353. 00000 -  "expression not supported for query rewrite"
*Cause:    The select clause referenced UID, USER, ROWNUM, SYSDATE.
This error is self explanatory , but is there any work around to have a query liek this to list the employees based on sysdate.
	View 23 Replies
    View Related
  
    
	
    	
    	
        Sep 3, 2012
        export a subset of the data only from one database to another. Both on AIX.
Source/testdatabase 11.2.0.3 (non-partitioned tables)
Target productiion database 11.2.0.3 (partioned tables)
Tables same column names but diffrenet index structures and traget one to be partitioned hence only want to import the content Each table on source datbaase hascolumn seq number and only want to extract the last few months of data.
TABLES:table1,table2...
DUMPFILE=dump_dir
CONTENT=data_only
QUERY= table1:"WHERE seq_num >100 "want to use expdp but not sure about how to ensure all tables have the WHERE seq_num >100 condition, if leave table1: out and just have
QUERY= "WHERE seq_num >100 " will this condition be applied to all tables which is what we want.
I'm assuming also can use impdp CONTENT=data_only?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Feb 16, 2013
        While executing parallel query we are getting the below errors.
(SQLState = HY010) - java.sql.SQLException: [tibcosoftwareinc][Oracle JDBC Driver][Oracle]ORA-01002: fetch out of sequence"
(SQLState = HY000) - java.sql.SQLException: [tibcosoftwareinc][Oracle JDBC Driver][Oracle]ORA-12842: Cursor invalidated during parallel execution
Database Version: Release 11.2.0.1.0 (Non-RAC)
SQL Query:
SELECT /*+ PARALLEL 4 */
DISTINCT
AI.STORE_ID STORE_ID, AI.DUE_DATE DUE_DATE, AI.INSTRUCTION_ID INSTRUCTION_ID,
DECODE (ASR.ADT_INSTR_KEY, NULL, 'F', ASR.ADT_INSTR_KEY, 'S') QCCHECK
FROM NSOAPP.DA_INSTRUCTION_INFO AI,
[code]....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 18, 2013
        I am to trying to fetch session id of a previously submitted process of a search button......so that i can display the search results in a different page.....so is there any sql query or pl/sql procedure to fetch the session id.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jul 26, 2013
        I am trying to write a proper query to fetch data from database. Scenario:
I need to retrieve employees who are not working in multiple departments. scott@TESTCRM> select * from emp1;      
EMPNO     DEPTNO
---------- ----------      
7654         30      7698         30      7788         20      7788         30      7876         20      7900         10      7900         30    7902     20    7934     10  
scott@TESTCRM>  
Ouput Expected is       
EMPNO     DEPTNO
---------- ---------- 
 7654         30      7698         30      7876         20      7902         20      7934         10
	View 9 Replies
    View Related
  
    
	
    	
    	
        Mar 15, 2011
        I have 3 tables, Emp(Emp_id,emp_name),dept(dept_no,dept_name),emp_dept(emp_id,dept_no). Emp tabl ehas some 20 employes id who belongs to different departments.There are few employee who belongs to multiple departments as well. I want to fetch records of emp_id, emp_name, dept_no in the following format.
Name   id      dept_no
Ram    101    10
                    20
                    30
Ani       201   10
                    20
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 25, 2013
        Lets say I have a table in ORACLE database like:
ACC_ID | ACC_AMT
111    | 10000
111    | 12000
111    | 14000
222    | 25000
222    | 30000
333    | 18000
333    | 27000
333    | 13000
333    | 15000
I want to get the output as:
ACC_ID_1 | ACC_AMT_1 | ACC_ID_2 | ACC_AMT_2 | ACC_ID_3 | ACC_AMT_3
111      | 10000     | 222      | 25000     | 333      | 18000
111      | 12000     | 222      | 30000     | 333      | 27000
111      | 14000     | null     | null      | 333      | 13000
null     | null      | null     | null      | 333      | 15000
I need each different ACC_ID with ACC_AMT in different columns. The table may have other different ACC_ID also, but I will fetch only what I need. What is the best way to do this?
So far I have tried this:
SELECT 
(CASE WHEN ACC_ID=111 THEN ACC_ID END) AS ACC_ID_1,
(CASE WHEN ACC_ID=111 THEN ACC_AMT END) AS ACC_AMT_1,
(CASE WHEN ACC_ID=222 THEN ACC_ID END) AS ACC_ID_2,
(CASE WHEN ACC_ID=222 THEN ACC_AMT END) AS ACC_AMT_2,
(CASE WHEN ACC_ID=333 THEN ACC_ID END) AS ACC_ID_3,
(CASE WHEN ACC_ID=333 THEN ACC_AMT END) AS ACC_AMT_3
FROM <TABLE_NAME>
But I am not getting the desired result.
	View 22 Replies
    View Related
  
    
	
    	
    	
        Sep 28, 2011
        I got a issue with a query to fetch records between two dates for fixed timings
Date
 From 29-09-2011 to 04-10-2011
Time
From 00:00:00hrs to 08:00:00hrs
I tried the below queries, it doesnt work
select a.detectorid,sum(b.totalvolume),a.updatetime,a.averagespeed from traffic_data a left outer join volume_data b on a.traffic_id=b.traffic_data_id 
where pollinterval=1 and detectorid=�AIDC_0154� and updatetime between to_date(�29-aug-2011:00:00:00�,�DD-MON-YYYY:HH24:MI:SS�)
[code]...
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 16, 2012
        I need to fech parent records only when no child record with status 'N' exists. There are only two possible values for status column of child table 'Y' / 'N'.
Below are table structures and insert statements for data.
CREATE TABLE MASTER
(
COL1  NUMBER,
[Code]....
COMMIT;Query I framed is below
select * from master where exists (select null from child where child.col2 = master.col1
group by child.col2 having count(distinct col3) =1 )
Output in above case would be 3 as for 1 there's one record with status as 'N' and for 2 there's no child record. I am on 10g.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 6, 2010
        This is how data is in table.
SQL> SELECT order_num, jcds.change_num, jcds.object_status, jcds.time_changed
  2    FROM tjcds_f jcds
  3   WHERE change_num = '001'
  4     AND object_status IN ('E0001', 'I0002', 'I0009', 'I0028') 
  5     and order_num='000001000001';
ORDER_NUM    CHANGE_NU OBJECT_STAT TIME_CHANGED
------------ --------- ----------- --------------------------------------------
000001000001 001       I0002       01-NOV-10 02.52.56.000000 PM
000001000001 001       I0009       01-NOV-10 09.30.20.000000 AM
000001000001 001       I0028       01-NOV-10 10.36.32.000000 AM
Needed Output:
ORDER_NUM    CHANGE_NU E0001       I0002                           I0009                          I0028  
------------ --------- ----------- ------------------------------- ------------------------------ ---------------------------------
000001000001 001                   01-NOV-10 02.52.56.000000 PM    01-NOV-10 09.30.20.000000 AM   01-NOV-10 10.36.32.000000 AM
My Query: 
 SELECT order_num, jcds.change_num, 
 decode(jcds.object_status,'E0001', jcds.time_changed) E0001 ,
 decode(jcds.object_status,'I0002', jcds.time_changed) I0002,
 decode(jcds.object_status,'I0009', jcds.time_changed) I0009,
[code]...
how do i get the above requirement in one row? is it possible.
	View 5 Replies
    View Related