SQL & PL/SQL :: Distinct With Analytical Query And IN Statement?
			Nov 18, 2011
				We've got a query which returns one row, but uses an IN statement. The IN statement links to more than one row in the subquery. When we use a combination of DISTINCT and an ANALYTICAL sum, the sum total is multiplied by the number of rows in the sub query. Remove the DISTINCT and we get a single value. 
A simplified example of the problem is below.
I can't see how a query which returns a single row then returns multiple values with the addition of a DISTINCT. Removing the analytical sum also provides a single row, but we need this in the actual query we're running. So it seems to be some combination of DISTINCT, ANALYTICAL SUM and IN query is causing multiple values to be returned.
CREATE TABLE go_test_distinct1  
(gtd_value     NUMBER);
-- Three identical values
-- To replicate the three identical values returned by 
[code].....
	
	View 12 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Mar 8, 2012
        can we use distinct keyword with the count and sum analytical functions?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2013
        I need to calcaulate the salary avarage for three days prior, leaving the current row. That should happen to every row moving back words.I have given all the details.
create table Employee(
      ID                 VARCHAR2(4 BYTE)         NOT NULL,
      name              varchar(20),
      Start_Date         DATE,
      Salary             Number(8,2),
      mv_avg         number(8,2)
[code]....
	View 17 Replies
    View Related
  
    
	
    	
    	
        Jul 2, 2013
        My table has two date columns EFF_DT which is the start date and TERM_DT is the end date. The EFF_DT of the next record should be the next date of the TERM_DT record.
My table looks like this.
Input Table:
-----------
CK_IDPI_IDEFF_DT        TERM_DT
Mem1ABC1-Jan-1331-Mar-13
Mem1ABC1-Apr-1331-May-13
Mem1ABC1-Jun-1330-Sep-13
Mem1ABC15-Oct-1331-Dec-13
Mem1ABC1-Jan-1431-Mar-14
Mem1XYZ1-Apr-1430-Jun-14
Mem1XYZ1-Jul-1431-Dec-14
Expected Output:
----------------
CK_IDPI_IDEFF_DT        TERM_DT
Mem1ABC1-Jan-1330-Sep-13
Mem1ABC15-Oct-1331-Mar-14
Mem1XYZ1-Apr-1431-Dec-14
In the fourth record, the effective date should be 1-Oct-13 which is the next date to the last TERM_DT 30-Sep-13.As the is the break in the date, the output should show 15-Oct-13 sa the second start date.
Note: Refer to the PI_ID columns, there is a break in the date for the sale PI_ID 'ABC'.
Here I am trying to generate a pseudo column, so that the table with the pseudo column looks like as shown below. and I can use first_value and LAST_value by partitioning on the pseudo column to get the desired output.
1) CNT_VAL is the pseudo column:
-----------------------------
CK_IDPI_IDEFF_DT        TERM_DT   CNT_VAL
Mem1ABC1-Jan-1331-Mar-131
Mem1ABC1-Apr-1331-May-131
Mem1ABC1-Jun-1330-Sep-131
[code].....
My Query :
----------
I not getting the desired output  here as the value in pseudo column is 3.
select CK_ID, PI_ID,EFF_DT,TERM_DT, 
(case 
when case_CONT - LAG(case_CONT,1) over (ORDER BY EFF_DT) = 0 then to_char(case_CONT)
when case_CONT - LAG(case_CONT,1) over (ORDER BY EFF_DT) <> 0 then to_char(LAG(case_CONT,1) over (ORDER BY EFF_DT) + 1)
else to_char(nvl(case_CONT,0))
[code].....
Scripts:
--------------------
Create table lead_test(
CK_ID varchar2(10),
PI_IDvarchar2(10),
EFF_DTDate,
TERM_DT date);
[code].....
	View 1 Replies
    View Related
  
    
	
    	
    	
        Nov 30, 2010
        I have a table which has the attached data.
Sample data is here
LOGON_DATE        NUMBER_OF_LOGINS
11/28/2010 02:00:001
11/28/2010 03:00:001
11/28/2010 04:00:002
11/28/2010 06:00:004
11/28/2010 07:00:002
11/28/2010 08:00:003
11/28/2010 09:00:006
[Code] ........
I am trying to do a report like this.
Date     PeakUsersBetween6AMand6PM    AVGUsersBetween6AMand6PM     PeakUsersBetween6PMand6AM     AVGUsersBetween6PMand6AM        
Output should be
11/28/2010     25      11     49     27     
11/29/2010...
I am using analytical function to do this, It throws an error range cannot be used for dates.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jan 22, 2013
        I am having a table with 5 lakhs transactions. I want to fetch the last balance for a particular date. So i have have returned a query like below.
SELECT curr_balance
FROM transaction_details
WHERE acct_num = '10'
[Code]...
This has to be executed for incrementing of 12 months to find the last balance for each particular month. But this query is having more cpu cost, 12 times it is taking huge time. how to remodify athe above query to get the results in faster way using analytical query. Whether this can be broken into two part in PL/SQL to achive the performance. ?
	View 9 Replies
    View Related
  
    
	
    	
    	
        Jul 18, 2010
        in 10g report builder i have written this query
----------------------------------------------------
SELECT DISTINCT(A.TRANS_NUM)
, A.POST_CD
, A.TRANS_DT
, A.EFF_DT
, A.TRANS_TYPE
, ( SELECT DES FROM SMT_CODE_LIST WHERE CD = A.TRANS_TYPE)   DTRANS_TYPE
, A.TIME_STAMP
[code]....
this query returns multiple row. how to get distinct row.
	View 5 Replies
    View Related
  
    
	
    	
    	
        May 27, 2013
        i have a table with a clob column and i have 150 records i want retrieve distinct values from the clob using distinct operator on clob will not work
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 11, 2012
        I'm posting below test case in which I'm not able to understand output for LAST_VALUE function. I'm expecting maximum value for the salary in a department. Because I'm partitioning by department and ordering a partition as assending so being last value it should give me maximum value within a partition i.e. department in this case.
CREATE TABLE EMP_MST 
( 
    EMP_ID NUMBER(5), 
    EMP_NAME VARCHAR2(30),
    CONSTRAINT PK_EMP_MST PRIMARY KEY(EMP_ID)
[code]...
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 10, 2010
        I was reading a tutorial for analytical function and i found something like this
sum(princial) keep(dense_rank first order by d_date) over partition by (userid, alias, sec_id, flow, p_date)
How to translate this into simple queries / subquery? i am aware that analytical function are faster but i would like to know how this can translate to using query without analytical  function.
	View 12 Replies
    View Related
  
    
	
    	
    	
        Dec 6, 2012
        Is there any way to apply the restriction on analytical functions, just like  WHERE and HAVING .AS we know that we can apply the restriction on table by  using  WHERE  and grouping functions by using HAVING clause . 
For Ex:  Departments wise count including all employees record : 
SQL> select count(*) over(partition by deptno) dept_Count, ce.*
  2    from scott.emp ce
  3   order by deptno, job;
   
DEPT_COUNT EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO
---------- ----- ---------- --------- ----- ----------- --------- --------- ------
         3  7934 MILLER     CLERK      7782 1/23/1982     1300.00               10
         3  7782 CLARK      MANAGER    7839 6/9/1981      2450.00               10
         3  7839 KING       PRESIDENT       11/17/1981    5000.00               10
         5  7788 SCOTT      ANALYST    7566 4/19/1987     3000.00               20
 [code]....        
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jul 11, 2011
        Here is the test-table creation script:
CREATE TABLE TEST1 (AGG_DATE DATE, COL1 NUMBER(9), COL2 NUMBER(9), COL3 NUMBER(9));
Here is the test-data population script:
insert into TEST1 (AGG_DATE, COL1, COL2, COL3)
values (to_date('01-01-2012', 'dd-mm-yyyy'), 1, 1, 1);
[code]....
The problem is when I wrote an analytical query, it is giving the BEGIN_DATE and END_DATE by taking all the partition values together and so instead of the values above, it is creating an answer as follows:
Wrong Dataset
BEGIN_DATEEND_DATECOL1COL2COL3
1/1/20121/8/2012111
1/1/20121/8/2012111
1/1/20121/8/2012111
1/1/20121/8/2012111
1/4/20121/11/2012222
1/4/20121/11/2012222
[code]....
Only the last row is correct. What can I do to get the right answer as I know am falling short? Here is my current query:
SELECT MIN(AGG_DATE) OVER(PARTITION BY COL1, COL2, COL3) BEGIN_DATE,
   MAX(AGG_DATE) OVER(PARTITION BY COL1, COL2, COL3) END_DATE,
   COL1,
   COL2,
   COL3
FROM TEST1;
	View 6 Replies
    View Related
  
    
	
    	
    	
        Sep 27, 2012
        I have simplified this for ease of understanding. I have a Data column and a Month_ID column like this:
Values Month_ID
--------- -------------------------------------------------------
AAA 1
BBB 2
I split this out to values per year like this
Value_2011 Value_2012 Month_ID
-------------------------------------------------------------------------
AAA 1
BBB 2
Now i am trying to get the max(Value_2011) keep (dense_rank Last order by Month_ID) but i get a NULL. I can understand its because the Month_ID accomodates all years but i only need it to look at Month_ID for 2011 and return me the last dense_rank value, how can i achieve this?
I tried a couple of different methods like Last_Value() but i have group by in my original statement and i think analytical functions dont like GROUP by if they are not part of it. How can i achieve this?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Aug 12, 2010
        I have used a decode statement in my query instead of using select * from <table_name> where value in <>
Instead I have used decode(value,<value1>, <value2>)
Which would be a better performance code?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Oct 5, 2010
        I need to calculate the sum of values over a period of exactly one month (including the current row). Now if I use a windowing clause of "range between interval '1' month preceding and current row", the total period length is 1 month plus one day (being the day in the current record).
Basically, I want to sum over a period starting at  "add_months(startdate, -1) + 1" up until startdate of each row.
drop table window_tst;
create table window_tst 
( id number primary key
[Code]....
So instead of having 01-feb going back to 01-jan, it should only include 02-jan till 01-feb
I could of course recalculate the period length back to a number of days for each row, but that is not really what I would prefer, as it would make the code rather unreadable. 
	View 5 Replies
    View Related
  
    
	
    	
    	
        Sep 18, 2012
        I want to use Analytical function instead of group by clause for below query..
select   
CASE
    WHEN ADMT.SOURCESYSTEM ='CLU'
    THEN COUNT(ADMT.TOTAL_COUNT)*5
    ELSE COUNT(ADMT.TOTAL_COUNT)
  END TOTAL_COUNT
from   ESMARTABC.ABC_DRVR_MFAILS_TMP ADMT
group by ADMT.SOURCESYSTEM
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 31, 2011
        how to write this query using all three tables in one query statement.
Result:
 Input value of "GM" would return "GM@EMAIL.COM"
 Input value of "GM" and "GMC" would return "GMC@EMAIL.COM"
If "GM" is supplied, then only return the "GM@EMAIL.COM" email.
If "GM" and "GMC" is supplied, then only return the "GMC@EMAIL.COM" email
Test Case : GM would return "GM@EMAIL.COM" email
Test Case : GM and GMC would return "GMC@EMAIL.COM" email
select email
from email       a,
company     b,
sub_company c
where (company = "GM" but no match found in sub_company)
(company = "GM" and sub_company_name = "GMC"  match is found in sub_company)
[code]....
	View 11 Replies
    View Related
  
    
	
    	
    	
        Sep 28, 2011
        I'm unable to create a select statement which calculates & brings the below fields :
 
- Act_Net_Last_Month (LastMonth)
- Act_Net_Same_Month_Last_Year (LM_LastYear)
My Table :
Acc_ID - Period_Name - Period_Year - Act_Net
000044 -   Aug-2011  -    2011     -  4493
000044 -   Aug-2010  -    2010     -  4300
000044 -   Jul-2011  -    2011     -  4389
000044 -   Jul-2010  -    2010     -  4266
Example :
Acc_ID - Period_Name - Period_Year - Act_Net - LastMonth - LM_LastYaer 
000044 -   Aug-2011  -    2011     -  4493   -   4389    -   4266
	View 7 Replies
    View Related
  
    
	
    	
    	
        Nov 19, 2012
        I have following queries:-
#select name from v$database;
#select log_mode from v$database;
#select count(*)"INVALID_OBJECTS" from dba_objects where status='INVALID';
#select count(*) "INVALID_N/A_INDEXES" from dba_indexes where status!='VALID';
#select count(*)"Invalid Triggers" from user_objects where OBJECT_NAME like '%TRIGGERS%' and status='VALID';
#select count(*) "Broken Jobs" from dba_jobs where broken!='Y';
#select count(*) "Block Corruption" from v$database_block_corruption;
i want a table which can be generated just by select cmd and it will list the result of all the above queires as follow:-
DB_NAME ARCH_MOD INV_OBJ INV_IDX INV_TRG B_JOB BLK_CRP
---------- -------------------------------------- -------------------------------------- ---------- ---------- ---------- ----------
PROD NOARCHIVELOG 0 86 6 3 0
I mean to say i want multiple select queries into 1 table (note:- i m not saying to create a tables and then insert,update(using select from other tables), its just a sheel script that will fetch these record into a txt file)
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jun 21, 2012
        The "HAVING" statement from the query below removes all rows where the "name" field starts with "Port" and it removes all rows where count is less than 11.  What I want is to removes all rows where the "name" field starts with "Port" and the count for that row is less than 11.
SELECT deviceEventClassId "Event ID", deviceAddress "Device Address", name "Event Name",  deviceHostName "Device Host Name", count( concat(deviceEventClassId, deviceHostName, name)) "Count"
FROM    events
WHERE   (deviceVendor = "Bilbo"  and
    
[code]...
	View 1 Replies
    View Related
  
    
	
    	
    	
        Nov 16, 2012
        I've seen this example numerous places, and tried to implement it, but I keep getting an "invalid identifier" error message, despite the fact that I've got the table and column specifically identified.For instance, my query reads like:
UPDATE tbl1
SET tbl1.EMPID =
(SELECT  tbl2.EMPIDA  FROM tbl2  
WHERE LOWER(tbl1.EMAILCOL) =  LOWER(tbl2.EMAILCOL2) 
)
WHERE tbl2.EMPIDA IN ('Z1O435','S8M4722','M0D5156')
AND EXISTS 
(SELECT tbl2.EMPIDA
 FROM tbl2 
 WHERE  tbl1.EMAILCOL= tbl2.EMAILCOL2 );
But I'll keep getting flagged at the tbl2.EMPIDA column reference. I have not tried this in SQL Plus, just in TOAD, but it seems to repeatedly fail.I have had to dump records to standalone Access tables and link back to perform the updates. 
	View 12 Replies
    View Related
  
    
	
    	
    	
        Jan 3, 2012
        what is the purpose of over and partition by keywords in analytical functions
	View 3 Replies
    View Related
  
    
	
    	
    	
        Dec 22, 2012
        how to delete duplicated records from a table without using row_id. I found the duplicated rows from a table using Analytical Function. But i could not use the Analytical function in the where condition. 
My table(tab2) Structure is 
   DEPTNODEPT_NAMEEMPIDSEXID1
107jadf         1F1
40asdf         55
10purchase 2M2
10sales         3M3
30HR         4F4
I found the Duplicate Record by using the query
 with a as
  (select deptno,dept_name,empid,sex,id1,row_number()over(partition by deptno order by deptno) rnum from tab2)
select * from a where rnum >1
how to delete duplicate record .
	View 19 Replies
    View Related
  
    
	
    	
    	
        Oct 6, 2010
        I am running one update statement which is running almost one hour still no response.
I would like to know either query is processing or hanging(suppose to finish the update within few minutes).
Is there any way or sql to find either the statement(my update query) is running or hanging.
	View 4 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
  
    
	
    	
    	
        Aug 23, 2012
        I am new to oracle. I am creating a view, where in the inner query returns below kind data.
column1   column2
-------------------
a       y
a       y
b       y
b       n
c       y
d       n
I want to extract all column1 values which always has "y" in column2. 
In this case, output has to be
output
------
a
c
	View 10 Replies
    View Related
  
    
	
    	
    	
        Sep 3, 2013
        I have table desc xx_testName     
Null     Type          
 -------- -------- -------------- 
COL1     NOT NULL NVARCHAR2(100)  COL2     NOT NULL NVARCHAR2(100) COL3     NOT NULL NVARCHAR2(100)
i am able to query select * from xx_test however if i query as select col1 from xx_test then it is giving error.
ORA-00904: "COL1": invalid identifier00904. 00000 -  "%s: invalid identifier"*
Cause:    *Action:Error at Line: 3,131 Column: 13  
Let me know how to query NVARCHAR2 column and how can we put in WHERE condition ?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 16, 2013
        i have employee table i want to update salary with all employee 5 percent
	View 4 Replies
    View Related
  
    
	
    	
    	
        Feb 1, 2012
        DECLARE @MainTable TABLE (UniqueID INTEGER, Category VARCHAR(200), WeekDate DATETIME, VALUE INTEGER)
INSERT INTO @MainTable VALUES(123, 'Shirts', '10/07/2011', 5000)
INSERT INTO @MainTable VALUES(123, 'Shirts', '10/14/2011', 8000)
INSERT INTO @MainTable VALUES(124, 'Pants', '10/07/2011', 4000)
INSERT INTO @MainTable VALUES(125, 'Shorts', '10/14/2011', 8000)
INSERT INTO @MainTable VALUES(126, 'Shoes', '10/21/2011', 9000);
--select * from @MainTable;
[code]...
The query works with all the CTEs up to the last select statement. Oracle does not support the OUTER APPLY statement, how should the last piece be written to make it work in Oracle?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 25, 2010
        I want to convert the below SQL to a dynamic sql to be executed from execute immediate statement.
UPDATE transaction SET loannum = lpad(loannum,12,'0')
	View 15 Replies
    View Related