SQL & PL/SQL :: Cumulative Some Last 5 Rows?
			Jun 25, 2013
				I need to get the sum of next 5 rows that are order by one specific column . 
Ex : 
DROP TABLE TEST_5;
 
CREATE TABLE TEST_5 AS  
SELECT TO_NUMBER(200 || ROWNUM) YEAR, ROWNUM TOT
  FROM ALL_OBJECTS
 WHERE ROWNUM < = 15 ;
SQL> select  *  from  test_5 order by year;
 
      YEAR        TOT
---------- ----------
      2001          1
      2002          2
      2003          3
      2004          4
      2005          5
      2006          6
      2007          7
      2008          8
      2009          9
     20010         10
     20011         11
     20012         12
     20013         13
     20014         14
     20015         15
 
15 rows selected
 
SQL> 
Now Expected Results  :
SQL> select  *  from  test_5;
 
      YEAR        TOT       Exp_res
---------- -----------------------
      2001          1      1+2+3+4+5 = 15
      2002          2      2+3+4+5+6 = 20
      2003          3      3+4+5+6+7 = 25
      2004          4
      2005          5
      2006          6
      2007          7
      2008          8
      2009          9
     20010         10      10+11+12+13+14
     20011         11      11+12+13+14+15 
     20012         12      12+13+14+15 
     20013         13      13+14+15 
     20014         14      14+15 
     20015         15      15
 
15 rows selected
 
SQL> 
	
	View 4 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Jul 3, 2010
        how to find cumulative total means i need total amount between april to sysdate.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jun 28, 2013
        Is it possible to get cumulative sum of the same column? I am trying to get a value for COL6... it is dependent on the values of previous row
COL6 Formula:
IF COL2 = 'A' THEN
IF 100 - [SUM_COL6] > COL5 THEN 
COL5 
ELSE 
(TRUNC(100 - [SUM_COL6] / COL4) )* COL4
END IF
[code]....
	View 6 Replies
    View Related
  
    
	
    	
    	
        Feb 24, 2011
        Is it possible to calculate cumulatively in oracle sql queries, i.e. using the results of the last row for calculating the values in the current row?For example I want my query to return the following:
Month      col1      _      col2      _      col3
jan      1      _      100      _      100 * 1
feb      2      _      200      _      100 * 2 + 200
mar      3      _      300      _      400 * 3 + 300
apr      4      _      400      _      1500 * 4 + 400
may      5      _      500      _      6400 * 5 + 500 
In col3 above, for feb I want to use the result returned for jan ((100 * 1)*2+200), for mar I am using the result returned for feb((100 * 2 + 200) * 3 + 300) and so on.
i.e. I want to use the previous value of column3 to derive the current value of column3. Like using the LAG function but on the analytically derived column itself.
	View 16 Replies
    View Related
  
    
	
    	
    	
        Mar 19, 2011
        I have one table where the item stock balance can be taken.What i want is like a ageing report based on the ending balance.If the ending balance is 10,000 for item a.It should bring all the Receipts which have qty lesser than 10,000.
I managed to write one function like below to get the receipts numbers but the format is 3778578-3778612-3790428 and i want to convert them into rows like 
3778578
3778612
3790428
The function used is as below.
                              
CREATE OR REPLACE FUNCTION l_get_rcpt (
   l_item   IN   VARCHAR2,
   l_date        DATE,
   l_bal    IN   NUMBER
)
[code]...
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 27, 2012
        i have a table empl which have three column (name,period,attendance)if we pass parameter which value is based on period column
like :January
then out should come sum of all attendence of january group by name like that
name    attendance
a60.00
b20.00
c20.00
w40.00
if we pass parameter value :February then attendance should come sum of (January and February) and if we pass parameter March then attendance should come sum of(January,February and march)
create table empl (name varchar2(10),period varchar2(10),attendance number)                                                    
insert into empl values('a','January',20)
insert into empl values('a','January',10)
insert into empl values('a','January',30)
insert into empl values('a','February',20)
insert into empl values('a','March',60)
insert into empl values('b','January',20)
insert into empl values('c','January',20)
insert into empl values('w','January',40)
	View 22 Replies
    View Related
  
    
	
    	
    	
        Mar 24, 2013
        Is there a way to find running balance for accounts, suppose i have two tables.one for transaction and one summary of balance.
i want to have the closing balance based on transactions subtracted or added based on credit and debit for example.it will add to the running total if its debit and subtract if its credit and final output is the balance.
create table acnt_trans ( acnt_code varchar2(12),trans_date date,debit_amt number,credit_amt number);
insert into acnt_trans values ('1001','02-FEB-2013',200,0);
insert into acnt_trans values ('1001','03-FEB-2013',0,100);
insert into acnt_trans values ('1001','04-FEB-2013',50,0);
[code]....
--I want the output as below.if i run the report as of '04-feb-2013'
trans_date  ,  acnt_code , debit_amt,credit_amt , balance
02-feb-2013    1001           200         0        3200
03-feb-2013    1001             0       100        3100
04-feb-2013    1001            50         0        3150  -- this is the closing balance.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 12, 2013
        The Table having 3 columns
col0col1 , col2 
P112
P112
P102
P113
P115
I want to retrieve the changes rows only.
Output like 
col0col1 , col2 
P112
P102
P113
P115
	View 5 Replies
    View Related
  
    
	
    	
    	
        May 27, 2013
        in my sql we can use limit to select first 4 rows in the table then next 4 rows ,can oracle do that ?
I have fifty rows inside the table 
select * from student where rownum between 0 and 4 order by stuid ->it work
select * from student where rownum between 5 and 9 order by stuid -> did not work
what is the correct way to do it ?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Apr 10, 2013
        drop table test
/
create table test
(
  lib   varchar2(100)
)
/
insert into test values ('111/aaa/bbb/ccc');
insert into test values ('222/aaa/bbb/ccc');
insert into test values ('333+444/aaa/bbb/ccc');
insert into test values ('333/aaa/bbb/ccc');
insert into test values ('222+333+444/aaa/bbb/ccc');
insert into test values ('222+333+444+555/aaa/bbb/ccc');
I want to get this :
lib             count
--------------- -----
111/aaa/bbb/ccc   1
222/aaa/bbb/ccc   3
333/aaa/bbb/ccc   4
444/aaa/bbb/ccc   3
555/aaa/bbb/ccc   1
	View 4 Replies
    View Related
  
    
	
    	
    	
        Dec 14, 2007
        I joined the forum just today, i need some tips on deleting the millions of rows from a huge table having 25 millions of rows. 
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 22, 2012
        what are the collections available in Oracle Plsql, what are concepts of collection.
How to Transpose a Table from rows to columns or columns into rows.
DDL and DML concepts.
What is the concepts of statistics in Oracle Plsql.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 6, 2010
        I need to transpose the following table columns to rows and rows to columns...Im not quite sure how to acheive this...I have the following table with fixed number of columns and dynamic number of rows based on date filter in query
MONTH_YEAR      RMS     RMS_OCC TTL_RMS
---------------------------------------
SEPTEMBER 200917790017790
OCTOBER 2009183831278818347
NOVEMBER 2009177901460517762
and I need to display this as
COL1       SEPTEMBER 2009      OCTOBER 2009      NOVEMBER 2009
--------------------------------------------------------------
RMS        17790               18383             17790  
RMS_OCC    0                   12788             14605
TTL_RMS    17790               18347             17762
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 14, 2013
        We are using PL/SQL Release 11.2.0.2 .I would like to pull a query with each student each day an attendance record.Our database setup an AM and PM Period for all elementary students. I will pull if they absent both periods(AM, PM), then count that as one day absent.The hard part is I need to put the AM absent code and PM absent code - which is basically to put two records for each student's AM and PM absent code into one row.
Below is the query I use, but it violates the key of database, for PK is studentid+ attendance date. My query result turns out for some students they have different attendance code in AM vs PM, there are two records returned.
SELECT DISTINCT TO_CHAR(S.Student_Number) ,
  TO_CHAR(Am.Schoolid) ,
  Sps_School_Year('C') ,
  TO_CHAR(Am.Att_Date,'MM/DD/YYYY') ,
  (
[code]....
	View 3 Replies
    View Related
  
    
	
    	
    	
        Nov 20, 2012
        We have large (millions of records) Slow changind dimension (SCD) type 2 (see "Creating another dimension record " URL>.....We need to get several rows from this SCD for each key (AGREEMENT_ID) in a SQL query - to join to facts table and get several data points of each agreement (on several different points in time) stored in SCD.Here is SCD table structure:
CREATE TABLE AGREEMENT
  (
    "AGREEMENT_ID" NUMBER(*,0) NOT NULL ENABLE,
    "ACTUAL_DATE" DATE NOT NULL ENABLE,
    "ACTUAL_END_DATE" DATE NOT NULL ENABLE,
    "OPEN_DATE" DATE NOT NULL ENABLE,
    "LIMIT" NUMBER(23,8)
--++ a lot of other fields not needed for this task ....
    CONSTRAINT "PK_MD_AGREEMENT" PRIMARY KEY ("AGREEMENT_ID", "ACTUAL_DATE") USING INDEX 
  )
The 1st simple approach would be to join facts to SCD as many (N) times as many different points of time you need - resulting in N Full Table Scans for SCD:
select ...
from fact,
AGREEMENT agr1,
AGREEMENT agr2,
AGREEMENT agr3
where 
    fact.AGREEMENT_ID = agr1.AGREEMENT_ID and agr1.open_date between actual_date and actual_end_date
 and fact.AGREEMENT_ID = agr2.AGREEMENT_ID and :dateBOP between actual_date and actual_end_date
  and fact.AGREEMENT_ID = agr3.AGREEMENT_ID and :dateEOP between actual_date and actual_end_date
2nd approach: 1 Full Table Scan for SCD + group by:
select ...
from fact,
(
 Select AGREEMENT_ID,
 max(case when open_date between actual_date and actual_end_date then LIMIT end) LIMIT_At_Open_DATE,
 max(case when :dateBOP between actual_date and actual_end_date then LIMIT end) LIMIT_At_BeginOfPeriod_DATE,
 max(case when :dateEOP between actual_date and actual_end_date then LIMIT end) LIMIT_At_EndOfPeriod_DATE
 from agreement
 -- ++optionally WHERE for those 3 dates, but possibly with no effect on non-partitioned table? Or WHERE to put less data on MAX() input (3 row for each agreement instead of 4...1000 without WHERE?)
 group by AGREEMENT_ID
) agr
where fact.AGREEMENT_ID = agr.AGREEMENT_ID
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jun 5, 2013
        Simple question, Why comparison operator ANY returns FALSE if no rows returned, and why operator ALL return TRUE if no rows returned? I dont know is this some kind of language or math assumption or is this just oracle rule?
	View 18 Replies
    View Related
  
    
	
    	
    	
        Aug 16, 2007
        i have 2 tables 
A             B                
id            a.id                           
  name             
              type             
There are at most 2 entries of a in b.  Depending on the value of the type column in B, this determines whether the entry should be male or female.  I want to have a select statement that will retrieve 2 rows into one row essentially like below, how is this done:
id         male_name   female_name     
1          paul        paula
the column names will appear as such, if its a 0 its a male name if its 1 its a female name, there will generally be 2 entries in B for 1 value of a.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 7, 2012
        I would want to know how can we predict how many rows are fetched per second for a particular query. What are the factors which are responsible for this.hoe does this whole process of fetching records from Source happens. Like when a query is fired how does it try to access the table and fetch records and how what are the factors whichc are responsible for this and how can we predict how many rows can be fetched per sec
	View 8 Replies
    View Related
  
    
	
    	
    	
        Jul 12, 2011
        There are many reduplicate rows in a big table,what is the best way to get the reduplicate rows?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 18, 2011
        I have following table.
CREATE TABLE ORAFAQ
(
  DPT  NUMBER,
  EMP  NUMBER,
  SAL  NUMBER
)
[Code]....
DPTEMPSAL
1110
12100
131000
241500
25100
26500
27100
but i need data like 
Dept 
  1    
      1   2    3     --3 columns show each employee
      10 100 1000    --3 columns show salary below each employee
  2    
      4    5   6    7
     1500  100  500 100
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jul 10, 2010
        How can we commit for every 500 rows in pl/sql block.
begin
for i in 1 to  10000
loop
Insert into t1 values(i);
commit;
end loop;
end;
Here I am commiting after all the rows are inserted ,but i want to commit for every 500 rows are inserted .
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jul 15, 2011
        i want to all rows value into single rows.
for example;
Input data:
Sec_SSC_ID Column_nameAs of dateOld valu   New Value
IBM  Mat_dt 10/10/20101/1/2001   1/1/2002
IBM  Bid Market 10/10/201075      85
IBM  asset_nm 1/1/2011International IBM
MSFT   asset_nm 1/2/2011Microsoft     Intel
MSFT   Bid Market price 1/1/201189       90
Output data
I have attached sample output file with it.
how to get this via sql?
	View 8 Replies
    View Related
  
    
	
    	
    	
        May 5, 2011
        Scenario like this , I have a dB which contain 100 tables, i want to find out each table contain how many rows excluding 
system tables ..
how can i write query for this.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 10, 2011
        tried searching google and this site too, found postings on WM_CONCAT, STRAGG, concat_all, LISTAGG functions by Michel and have experimented with these, but either the syntax is giving me a hard time or i just have not got the concept down.
Trying to get 2 rows into one. Have provided the create statements and insert of data. Also below will show what is returned with a Select i have and what is ideally required.
CREATE TABLE Person_Lang
(
    Person_ID            NUMBER        NOT NULL,
    Language_ID          NUMBER        NOT NULL,
    Contact_Name         VARCHAR2(255 CHAR),
    Main_Phone           VARCHAR2(255 CHAR),
    Secondary_Phone      VARCHAR2(255 CHAR),
[Code]...
Data Returned from Select is:
1 46 905-231-3319 22 Street11 Apt402 Brantford
1 46 905-231-3319 23 Street12 Apt315 MainTown
Ideally what is required back is:
1 46 905-231-3319 22 Street11 Apt402 Brantford 23 Street12 Apt315 MainTown
	View 7 Replies
    View Related
  
    
	
    	
    	
        Mar 10, 2012
        i want to sum different rows and want get wum in nest column.
for example i have fee column and there is some different student fee in specific month for example(jan).i want to sum this fee against the month of Jan.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Dec 29, 2010
        How to get the previous value of row with calling function to add value in SELECT statement for the row value.
Consider the example Table A1 having column a with values 1,NULL,NULL,NULL
SELECT CASE WHEN a IS NULL THEN (prev_row_value+function_return_Value) ELSE a END as A from A1
And my result-set should be like 
a
----------------------
1
1+(Return Value Of Function)
Prev_Row_Value+(Return Value Of Function)
Prev_Row_Value+(Return Value Of Function)
Below is sample code but doesn't fulfill my criteria
[code]....
Output is
A A2
---------------------------
1  1
   3
   3
   3
	View 8 Replies
    View Related
  
    
	
    	
    	
        Sep 17, 2012
        I use Oracle 11g and a Middleware which sends the SQL Statements to the database. That's why I can't send you loggings.
However, I' got this SQL:
With CTE
AS
(
select * from 
data A2 
WHERE
A2.ID ='536031'
AND
A2.AttrID = '6'  
)
That code gives me the following result:
ID.........Version....AttrID.......group
536031......3.........6..............test5
536031......3.........6..............test6
What I try to do. I want to get all groups. The Groups should be in one column...the the result must be the following:
ID.........group
536031...test5, test6
In SQL server I always used 
SELECT ID,
STUFF((SELECT ',' + [group] FROM CTE WHERE ID = c.ID ORDER BY [Version] FOR XML PATH('')),1,1,'')
FROM (SELECT DISTINCT ID FROM CTE)c
to achieve that. Is there a similar function in oracle like XML PATH? Or another way the get the result? 
	View 12 Replies
    View Related
  
    
	
    	
    	
        Aug 28, 2011
        I want to update salary column of emp table in a way that every value of salary column be increased by 1000, is this possible I can  do this one statement only??
(Just FYI-
SQL> desc emp;
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 EMPNO                                     NOT NULL NUMBER(4)
 ENAME                                              VARCHAR2(10)
 JOB                                                VARCHAR2(9)
 MGR                                                NUMBER(4)
 HIREDATE                                           DATE
 SAL                                                NUMBER(7,2)
 COMM                                               NUMBER(7,2)
 DEPTNO                                             NUMBER(2)
)
[Code].....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 17, 2011
        there are 2 different types of bar-code which get store in single table
table_structure
item_id
group
bar_code
values are like
item_id group bar_code
1        FG    09878
1        FG    81011
i want output like 
item_id  group  bar_code1  bar_code2
1          FG      09878     81011
What should i need to do...?
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 21, 2013
        drop table test;
create table test
(
  my_env  varchar2(8)   ,
  id      int         
)
/
alter table test add constraint pk_test primary key (my_env, id);
insert into test values ('A', 1);
insert into test values ('A', 2);
[Code]...
These rows are valued :
drop table valued_test;
create table valued_test
(
  my_env  varchar2(8)   ,
  id      int           ,    
  val     int     
)
/
[Code].....
Now the rows of the table test can move from one situation to another. To model the movement from one situation to another, there is another table test_history
drop table test_history;
create table test_history
(
  my_env      varchar2(8)   ,
  id          int           ,
  my_env_new  varchar2(8)   ,
  id_new      int         
)
/
[Code]...
So the row (A,1) moved to (A1,1). What I want to do is to replicate the valued rows with(A,1) to (A1,1).
if we issue select * from <some_query> we will get this :
MY_ENV           ID        VAL
-------- ---------- ----------
A                 1        100
A                 3        200
B                 1        100
A1                1        100
We can issue this query to get it :
select my_env, id, val
from valued_test
union
select my_env_new my_env, id_new, val
from valued_test, test_history
[Code]...
MY_ENV           ID        VAL
-------- ---------- ----------
A                 1        100
A                 3        200
A1                1        100
B                 1        100
It works fine, but when we have lot of data in test and valued_test, these query becomes very slow. I think it is because of the union. So here are my questions :
1) could we remove the union
2) What columns in test, valued_test, test_history should we index to make the result be returned faster.
	View 4 Replies
    View Related