SQL Query - Return Operation Over Multiple Dates
			Feb 16, 2011
				I am new to SQL and I am just wondering if there is a solution to a problem I am having.I am using the piece of code below.Essentially what I am doing is selecting a field from a table and ordering that field in descending order. Using the Row_Number feature I then specify which Row I want to return.
Every day the row I will want is the Count of field1 for that day divided by 100 minus 1. This returns a single value of field1 and a single value of R.
I perform this operation every day. The only fields I change every day are the dates and the value of R. I use a seperate piece of SQL code to calculate R each day.
My problem is I have to often populate historical tables with this data. I can only run the code once for each day and for each value of R. Is there anyway I can alter this code such that it can return multiple values of field1 over several dates?The only way I can think of is to repeat the code multiple times using UNION but I am hoping there is a more efficient way.
SELECT * 
  FROM (SELECT Field1,               
               ROW_NUMBER() OVER (ORDER BY field1 desc ) R
               FROM table 
               WHERE  date >= TO_DATE ('20110215', 'YYYYMMDD')
               AND date <  TO_DATE ('20110216', 'YYYYMMDD')                 
  ) 
 WHERE R = 1227 
--Note: 1227 = (count(field1)/100)-1
	
	View 5 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Oct 5, 2012
        is there a way to return the next 7 dates just using a query... for example, I need a query that returns:
select (I don't know that put here) from dual
Date
2012-10-05
2012-10-06
2012-10-07
2012-10-08
2012-10-09
2012-10-10
2012-10-11
If possible, I would like to know if there's a way to pass a date and based on it, the query returns the next 7 dates based on the passed date... for example:
select (I don't know that put here) from dual where date > '2012-10-15'
Date
2012-10-16
2012-10-17
2012-10-18
2012-10-19
2012-10-20
2012-10-21
2012-10-22
	View 13 Replies
    View Related
  
    
	
    	
    	
        Oct 1, 2013
        i need a query to get dates for last 7 days and each dates should be in one row... but select sysdate from dual..gives one row...
Expected Output Dates: 01-oct-201330-sep-201329-sep-201328-sep-201327-sep-201326-sep-2013
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 6, 2012
        I have a sql query as below :
select order_number,
(select decode(hcp.contact_point_purpose,'ABC',hcp.email_address,'CDE',hcp.email_address,null)
from hz_contact_points,
hz_parties hz
WHERE hz.party_id=hcp.owner_table_id) Email 
FROM oe_order_headers_all h
WHERE h.order_number='102'
....................
..............
Actually the problem i am facing is the inner select query is returning multiple row , so my main query is erroring out, i need to capture the multiple row.
In the above example the inner decode statement returning two mail address, I need to capture that, but while executing the whole query it is erroring out as saying single query returns multiple values. capture multiple values
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jun 12, 2013
        I have a source view where I have some invalid records and those should be found based on codes present in another table.
For eg. from source the records come like 
****************SIINNSFDFD****FDFDF2******8
**********TABLE****************FDFSFSSFASFAS********
and if my reference table has values
SIINNSFDFD
TABLE
then these values are present as substring in the particular column in the source view. So I need to flag those records. For every record, I need to check whether all the values present in the reference table matches or not. If it matches then it should be flagged.
I can use in operator as we are not checking for the exact match and we are checking whether that value is present anywhere in that column record.
Looping results in performance issue. We can use PL/SQL for this. As the source view is put into a ETL internal file.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 22, 2010
        Client managerCont. Start DateCont. End Date
abcman11-Jan-0830-Jun-08
abcman21-Jul-0831-Dec-08
abcman11-Jan-0930-Jun-09
abcman11-Jul-0931-Dec-09
abcman21-Jan-1031-Mar-10
abcman21-Apr-1031-Aug-10
I need to code a SQL statement (Not PL/SQL) to display following records:
Client managerCont. Start DateCont. End Date
abcman11-Jan-0830-Jun-08
abcman21-Jul-0831-Dec-08
abcman11-Jan-0931-Dec-09
abcman21-Jan-1031-Aug-10
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 30, 2010
        I need to return results for the following query only when there are two or more rows found by the following:
SELECT DISTINCT D.PUBLICATION, 
D.ADI, 
D.DISTRICT, 
D.ACCOUNT, 
D.ROUTE, 
[code]......                
Expected results would be:
1 145 CRF TUANR000 VM BILLETING 16-APR-10 5 5 23-APR-10   48623
1 145 CRF TUANR000 VM BILLETING 16-APR-10 5 4 23-APR-10   48629
	View 19 Replies
    View Related
  
    
	
    	
    	
        Jan 10, 2012
        how to calculate the difference between multiple dates at the same time..
Select      to_date('10/10/2011','mm/dd/yyyy')      
-  to_date('09/10/2011','mm/dd/yyyy')
-  to_date('08/10/2011','mm/dd/yyyy') from dual;
Giving me an error...
ORA 00932 : inconsisten data types:expected DATE Julkian got DATE..
	View 8 Replies
    View Related
  
    
	
    	
    	
        Aug 28, 2010
        I want multiple values from a function. I want to use this function in a SQL query. Here i'm giving my try.
SQL> CREATE TABLE TEMP
  2  (
  3    ID        NUMBER(1),
  4    SAMPTYPE  VARCHAR2(20 BYTE),
  5    SALARY    NUMBER(10)
  6  )
  7  /
Table created. 
SQL> INSERT INTO TEMP VALUES(1,'ABC',10000);
1 row created.
SQL> INSERT INTO TEMP VALUES(2,'PQR',20000);
1 row created.
SQL> INSERT INTO TEMP VALUES(3,'JPD',5000);
1 row created.
SQL> COMMIT;
Commit complete.
[code]...
Here i get result as ABC*10000, but i want two separate values as ABC,10000. how can i do this via function.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Jun 23, 2006
        can i have a pl/sql function that can return multiple rows
may be the syntax will be like
create or replace function multiple() returns ...
begin
   select candidateid from tbl_candidateinfo;
   
   ..code to return the result of above statement to calling program.. 
end;
and functions will be called as
select candidateid from .. where candidateid in( select multiple());
	View 13 Replies
    View Related
  
    
	
    	
    	
        Jun 6, 2013
        I need a function that should return output of this query
SELECT b.branding_code, c.name_desc 
FROM 
development.brandings b, godot.company c
WHERE b.company_id = c.company_id;
This above function return 30 rows and I am not giving any input
Function using cursor,pipeline
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jun 7, 2013
        If I return multiple rows says ex:100 rows then what will be data type for that return values.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 13, 2012
        I have a table second_table which has a username and code field. A username (not the primary key) may be entered multiple times with different codes, or a single code 'ALL', in which case, the codes have to be fetched from 'third_table'. I am unable to form a 'case' clause to handle the fact that a list has to returned when the 'code' field from the second_table returns 'ALL'. 
e.g.
Second_table
username code
A        ALL
B        23
B        56
B        33
Third_Table
code
67
78
So, when the user asks the codes for user A, he should get 67 and 78 and when he asks for the user B, he should get 23,56 and 33
	View 13 Replies
    View Related
  
    
	
    	
    	
        May 26, 2010
        How to return multiple rows from the stored procedure in ORACLE..
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 27, 2013
        EMP table
create table emp1 (empno number,deptname varchar2(30),deptno number,sal number);
insert into emp1 values (1,'Bank',10,1000);
insert into emp1 values (1,'Finance',20,400);
insert into emp1 values (2,'Finance',20,4000);
insert into emp1 values (3,'Account',30,3000);
commit;
select * from emp1;
actual output :
empno  deptname  deptno sal
1       Bank      10    1000
1       Finane    20    400
2       Finane    20    4000
3       Account   30    3000
Expected output :
empno  deptname  deptno sal
1       Bank      10    1000
2       Finane    20    4000
3       Account   30    3000
I am looking a output like above one. if any empno belongs to deptname Bank then give priority to that values else go to other dept like Finance but empno 1 should return only one row.i.e Bank dept only.
I have to return only one row based on dept values for one empno. how to do in sql or plsql?
	View 11 Replies
    View Related
  
    
	
    	
    	
        Dec 9, 2010
        Attempted to execute the Procs below with
Select OTMP_TCIS_RS.Get_UserInfo('EN') from dual; but i get the following error: 
ORA-14551: cannot perform a DML operation inside a query.
The intention of the code is to perform an insert into my table based on passing in values via an object into Stored Procedure Apply_Users_Update
Package Definition
create or replace
PACKAGE OTMP_TCIS_RS AS
   --1 PROCEDURE Get_UserInfo
PROCEDURE Get_UserInfo(
    o_OutCode OUT INT,
    i_language IN VARCHAR2);
FUNCTION Get_UserInfo(    
     i_language IN VARCHAR2)
      RETURN NUMBER;
 [code]....
	View 5 Replies
    View Related
  
    
	
    	
    	
        May 22, 2010
        The data in one of the temporary table has been compiled as below. Number of Days elapsed between two transaction dates is required to be computed and multiplied with the balance. There can be multiple number of same transaction dates. When previous date and the current transaction dates are same the resulting number of day difference should be 0. But when they are different the difference between them is to be computed. On the last day of the Financial Year i.e. '31/03' of any year the difference day should be shown as 1 so as to make 365 or 366 days in a year. Simply deducting d1 from d2 on 31st will not be suffice as the difference is one day less. 
 ----------------------------------------------------------------------------------------- -------
Transaction Narration                 DebitCreditBalanceNo of DaysProduct
DateDifference
 ----------------------------------------------------------------------------------------- --------
01/04/2009Opening Balance      45020450277346654
17/06/2009ByAmt5044521253424
29/06/2009By Amt1004352156678912
02/12/2009By Amt424310119476000
[code]....
improve the above code and get the desired output result.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jun 16, 2010
        I have a function declared as PRAGMA AUTONOMOUS_TRANSACTION.
If i execute this function everything is fine.
If I call this function from a remote database, I have this error message:
"ORA-14551: cannot perform a DML operation inside a query".
select function('parameter') from dual;
Result: "OK"
select function@dblink1('parameter') from dual;
Result: "ORA-14551: cannot perform a DML operation inside a query"
	View 14 Replies
    View Related
  
    
	
    	
    	
        Oct 8, 2013
        Am calling the Function Batch to insert an update statemtnt  into Batch_statement table  in the DOWNLOAD_FUNC .But its failing with the error 
SQL Error : ORA-14551: cannot perform a DML operation inside a query 
Below Is the 
FUNCTION BATCH(numTABLE_ID IN NUMBER, varSTMT IN VARCHAR2) RETURN NUMBER IS
BEGIN
INSERT INTO BATCH_STATEMENT(QUEUE_ID,TABLE_ID,STATEMENT,QUEUE_SEQUENCE_ID)
VALUES (numQUEUE_ID,numTABLE_ID,varSTMT,1);
RETURN 1;
[code].....
	View 27 Replies
    View Related
  
    
	
    	
    	
        Jan 31, 2012
        I'm looking for a way to make CRLFs show in a CLOB.I'm feeding the insert statement with a concatinated string like this:
insert into table(Data) values (MyConc)
(MyConc is a string put togheter by another application)
Because of this I can't use the "|| chr(13) || chr(10) ||" because I only have that one concatinated string.Is there a character I can set in my string that automatically translates to a CRLF?
My CLOB-data should look something like this:
1;blue;Woodstock;;
34;giant;squid;attack;
5;blue;squid;;
And in this case the "MyConc" would look like this "1;blue;Woodstock;;[X]34;giant;squid;attack;[X]5;blue;squid;;[X]
where [X]=the character I need for CRLF =)
	View 11 Replies
    View Related
  
    
	
    	
    	
        Aug 9, 2011
        Calling function
select PACK.MAIN('blah') from dual
generates:
ORA-14551: cannot perform a DML operation inside a query
ORA-06512: at "SYSADM.NEW_QUANTUM_PACK", line 756
ORA-06512: at "SYSADM.NEW_QUANTUM_PACK", line 245
Unfortunately the Body is not accessible to see.The spec of the function is:
FUNCTION MAIN (mvar IN varchar2) RETURN varchar2; I read somewhere that I can call it like:
var myVar VARCHAR2; call PACK.MAIN('blah') into :myVar
But this generates: ORA-01008: not all variables bound
	View 3 Replies
    View Related
  
    
	
    	
    	
        Apr 28, 2010
        When i had a interview last week they ask me to write a query to display the  next ten dates using sql query ( without using PL/SQL).
	View 11 Replies
    View Related
  
    
	
    	
    	
        Nov 28, 2012
        work_order     unitid       frommi      tomi     frompm     topm
2666054111     06-154       77.000      85.000   77.370     null 
2666054111     06-154       77.000      85.000   null       85.370
2666054111     06-154       77.000      85.000   null       null
I used select distinct(work_order) to come up with the three different possible scenarios the problem is that i need all this information on a single row
work_order     unitid       frommi      tomi     frompm     topm
2666054111     06-154       77.000      85.000   77.370     85.370
this is a conversion for distance. when i get this to work properly, it will generate reports on thousands of work orders with their converted distance markers.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 2, 2012
        I have the below query which is doing FTS and is very expensive causing load to timeout. 
I did my analysis and found that table is having large number of records and hence FTS is taking long time causing timeout from app side.
I proposed to have this table partitioned but this is still pending with business and they in meantime want some solution other solution to fix this issue.
below is the query and plan
SELECT TRANSACTION_LOG.ID, TRANSACTION_LOG.USER_IDENTIFIER, TRANSACTION_LOG.START_TIME, TRANSACTION_LOG.END_TIME, TRANSACTION_LOG.REQUEST, TRANSACTION_LOG.RESPONSE  ....
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 21, 2013
        i am trying to update below statement that has multiple rows but giving the error like :
update test t
set (t.org_id) = 
(select o.org_id
from organisation o inner join test t
on (o.name=t.full_name
or o.name=t.chart_name))
error:- single return sub query return more value.
how to write update join query base on multi[ple ow.
	View 8 Replies
    View Related
  
    
	
    	
    	
        Nov 26, 2012
        I've stucked with a query. I have a table that i store the IDs of logically equal records.
For example;
A = B
B = C
X = Y
Z = Y
My query must return all equivalent records. If you call the query with parameter 'A', the result set must contain B and C. And if you call the query with parameter 'Y', the result set will contain X AND Z. I have thought that i can write the query wity using start with connect by statement. But the query does not work as i expected. Here is my code and sample data:
create table temptable (ID1 number,ID2 number);/
insert into temptable values(11,12);/
insert into temptable values(12,13);/
insert into temptable values(13,14);/
insert into temptable values(13,15);/
SELECT distinct ID1 from
(
SELECT * FROM temptable
START WITH ID1 = 13 OR ID2 = 13
CONNECT BY NOCYCLE
(
(PRIOR ID1 = ID1) OR
(PRIOR ID1 = ID2) OR
(PRIOR ID2 = ID1) OR
(PRIOR ID2 = ID2))
) WHERE ID1 <> 13
union
[code]....
When i call the query with parameter 13, i'm expecting to get 11,12,14,15. But it returns only 12,14 and 15.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 3, 2013
        I have a view base on this query returned more rows returned.
select *
From ( 
Select c_code ,
from_date,
c_range ,
[code].........     
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 19, 2012
        I am Having below query which is having total 664 records and for WHERE Clause (accountno ='13987135') it is having 3 records but when i am taking count it is returning 3 at first time and again returning 4 every time from then onwords. 
SELECT Count(*) cnt FROM(SELECT rownum rnum,
secno,
positionname,
tradingsymbol,
cusipcum,
businessclientname,
businessclientid,
[code].....
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 10, 2012
        I have not found a solution for this, but it could be that I don't know what to search for.
I need to edit the following statement:
SELECT a.id||a.name||a.amount*2 as transaction
FROM a
WHERE a.amount IN (500, 1000)
To return:
TRANSACTION     
------------------------------------
123SMITH1000
123SMITHADJUSTED AMOUNT PER X
456JONES2000
456JONESADJUSTED AMOUNT PER X
The returned rows need to be in this format to be executed in another database.
Can this be done?
	View 8 Replies
    View Related
  
    
	
    	
    	
        Sep 26, 2012
        I need query to find the missing dates between two columns in given month.
CREATE TABLE emp_shift (
empno NUMBER(4),
fr_date DATE,
TO_DATE DATE,
shift VARCHAR2(1));
CREATE TABLE emp (
empno NUMBER(4)
);
[code].....
Required output is
MISSING_DATES               EMPNO
---------------------- ----------
09-SEP-12 TO 11-SEP-12       7499
23-SEP-12 TO 26-SEP-12       7499
01-sep-12 TO 30-SEP-12       7521
01-sep-12 TO 30-SEP-12       7788
	View 8 Replies
    View Related