How To Do Multiple Loops Through A Cursor
			Nov 21, 2011
				I have a table where each record has a numerical x-coordinate value as one of its fields.  I want to loop through a group of the records that have another field in common in a given order. In a nested loop, I would like to subtract the coordinate of the outer loop from the coordinate of the inner loop for all records in the inner loop that appear later in the sequence.  The result is a list of the distances between all coordinates.
Example:
x-coordinate
3
4
6
7
It would look like this:
4-3, 6-3, 7-3,
6-4, 7-4,
7-6
I can do this using two nested cursors that select the same thing basically. But the table being selected from is pretty large and it takes forever to keep selecting from the huge table when the inner cursor could just copy the results of the other cursor and repeatedly iterate through them.
Is it possible to copy a cursor's results into another cursor or reset the cursor index back to the beginning so that it doesn't have to do the select statement every time?
	
	View 1 Replies
  
    
	ADVERTISEMENT
    	
    	
        Oct 22, 2011
        I need to write a script which copies 4 col data from one table to another table. there are three tables 
cwat_curr_mst and cwat_assigned_customer  and cwat_assignment_mst.
Cwat curr mst has PK curr_id and cwat_assigned_customer has PK assignment_id.
Also cwat_assigned_customer has customer_id.
In cwat_assignment_mst has Curr_id and Assignment_ID.
cwat_curr_mst and cwat_assigned_customer   tables has 4 cols in common 
they are 
ASRT_SNM_NO, SNM_NO, FLORIDA_NO, CBRN_NO. 
So from curr_mst all these 4 cols data needs to come/copy  into  cwat_assigned_customer.
	View 20 Replies
    View Related
  
    
	
    	
    	
        Jun 1, 2010
        is there any query using which i can fetch the data from multiple table in a cursor. i dont want to use separate cursor.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Apr 8, 2010
        i have two tables test1 and test2. i want to update the column(DEPT_DSCR) of both the tables TEST1 and TEST2 using select for update and current of...using cursor.
I have a code written as follows :
DECLARE
v_mydept1 TEST1.DEPT_CD%TYPE;
v_mydept2 TEST2.DEPT_CD%TYPE;
CURSOR C1 IS SELECT TEST1.DEPT_CD,TEST2.DEPT_CD FROM TEST1,TEST2 WHERE TEST1.DEPT_CD = TEST2.DEPT_CD AND TEST1.DEPT_CD = 'AA' FOR UPDATE OF TEST1.DEPT_DSCR,TEST2.DEPT_DSCR;
[code].......
The above code when run says that it runs successfully. But it does not updates the desired columns[DEPT_DSCR].
It only works when we want to update single or multiple columns of same table...i.e. by providing these columns after "FOR UPDATE OF"
I am not sure what is the exact problem when we want to update multiple columns of different tables.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 16, 2011
        What is the difference between Hash join and Nested Loops in pl / sql?
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 31, 2011
        homework assignment using pl/sql based on 2 tables I have created below? I am not sure of how to use cursors, loops and proper syntax. 
ASSIGNMENT:
1. Create a PL/SQL Procedure (cursor to loop through the records, check the LastName, then update the grade table
where id=id on grade table)
Rule:
A 
‐ LastName ends with a character between A‐F 
B 
‐ LastName ends with a character between G‐K 
C 
‐ LastName ends with a character between L‐P 
D 
‐ LastName ends with a character between Q‐T 
E 
‐ LastName ends with a character between U‐Z 
Create TABLE Registration (RegistrationID number(10), SectionID number(10), CourseID number(10), 
SectionNumber varchar2(10), 
StudentID number(10), FirstName varchar2(20), 
LastName varchar2(20), CourseNumber varchar2(20), CourseName varchar(20));
[code].....
	View 20 Replies
    View Related
  
    
	
    	
    	
        Feb 25, 2012
        I'm attempting to write a plsql for finding missing archived logs for streams.
requirement is to run a select statement and print
1. 'NOT FOUND' if name column is null
2. '<name of the files>' if rows are returned
3. 'NOT FOUND' if no rows are selected. (here is were i'm having trouble)
code i developed so for: 
for cr in (select decode(name, NULL, 'NOT FOUND', name) from v$archived_log where deleted='YES'
and status!='A') 
loop
if (cr.name = 'NOT FOUND')
[code]...
	View 6 Replies
    View Related
  
    
	
    	
    	
        Apr 10, 2013
        I have a select query that was working with no problems. The results are used to insert data into a temp table.
Recently, it would not complete executing. The explain plan shows a cartesian. But, there could be problems with using nested loops on the outer join. 
Interestingly, when I copy production code and rename the temp table and rename the view, it works. 
CREATE TABLE "CT" 
( "TN" VARCHAR2(30) NOT NULL ENABLE, 
"COL_NAME" VARCHAR2(30) NOT NULL ENABLE, 
"CDE" VARCHAR2(5) NOT NULL ENABLE, 
"CDE_DESC" VARCHAR2(80) NOT NULL ENABLE, 
[Code]....
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 14, 2010
        10.2.0.1
I am trying to understand the concept of nested loops.
--------
|   0 | SELECT STATEMENT             |         |    14 |   364 |     4   (0)| 00
:00:01 |
|   1 |  NESTED LOOPS                |         |    14 |   364 |     4   (0)| 00
:00:01 |
[Code]....
Predicate Information (identified by operation id):
---------------------------------------------------
   4 - access("A"."DEPTNO"="B"."DEPTNO")
Nested loop by defintion means,for every row returned by the outer query,the inner query is executed that many times.
In the above example,oracle does a full table scan and returned 14 rows.Now for dept table,it does a index unique scan and applies the predicate a.deptno=b.deptno and returns 1 row.
My question is why it is returning only 1 row? That measn for every 14 rows,this one row is fetched 14 times.
	View 10 Replies
    View Related
  
    
	
    	
    	
        Jan 12, 2013
        i am trying to use loops to retrieve the ename of emp table of scott schema , then under they are retrieved , all "sal" values appear under them , i do not want employee's salary under each employee , i need retrieve the 14 record of enames , then under them the 14 record of sal column appears , so i used this code :
declare 
cursor emp_cur is 
select ename from emp; 
emp_rec emp_cur%rowtype ; 
[code]....
	View 16 Replies
    View Related
  
    
	
    	
    	
        Mar 10, 2012
        Main Aim : To find all those id's who have taken all the tests within a rolling window of 45 days.
I have a table "MBS_FIRST_DATE" with the following data :This table has the patients who have the test along with the first date..This table is derived such that it has only one record with the first date of the test irrespective of the test.
create table MBS_FIRST_DATE
(
  medical_record_number VARCHAR2(600),
  requested_test_name   VARCHAR2(39),
  result_date           DATE
[code]..
Process :will be explaining with a patient id :
1) Consider the patient 1001274 from mbs_first_date table.
2) This patient has an date of July 08th 2008 & test SBP from first table. (keep this test an an anchor).
3) For the patient above loop through the all_recs table with test & result date ordered for the patient. (excluding SBP)
4) The first record we have is CHL with 08/05/2009 (May 8th 2009)..
5) Since this record is not within 45 days from SBP date for the patient..we go to the next record of SBP for the patient.
6) The next record for SBP is  11/05/2009 (May 11th 2009) .
7) Consider the CHL date again which is with 08/05/2009 (May 8th 2009)..
 Since both are within 45 days ..store both the values keeping SBP date as an anchor date as it's the test that's having minimum date from table 1. Even though there is one more CHL date which is within 45 days from SBP we don't care about it.
9) Go to the next test for the same patient which is DBP..
10) The DBP first date is  July 08th 2008..
11) Since it's not within 45 days from previously stored SBP date (11/05/2009) ignore the record.
12) GO to the next record which is 10/05/2009..as this is within 45 days from SBP & already CHL (stored date) is within 45 days..Grab all the 3 dates as all are within 45 days from anchor date (SBP date).
SO the o/p will be
1001274 SBP 11/05/2009
1001274 CHL 08/05/2009
1001274 DBP 10/05/2009
Code which I wrote :I know some where I am missing the loop 
declare
  V_ID1        VARCHAR2(200) := '';
  V_TEST1      VARCHAR2(200) := '';
  V_DATE1      DATE := NULL;
[code]...
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 30, 2012
          I want to make sure I am describing correctly what happens in a query where there is distributed database access and it is participating in a NESTED LOOPS JOIN.  Below is an example query, the query plan output, and the remote SQL information for such a case.  Of particular note are line#4 (NESTED LOOPS) and line#11 (REMOTE TABLE_0002).
What I want to know is more detail on how this NESTED LOOPS JOIN handles the remote operation.  For example, for each row that comes out of line#5 and is thus going into the NESTED LOOPS JOIN operation @line#4, does the database jump across the network to do the remote loopkup?  Thus if there are 1 million rows, does that mean 1 million network hops?  Does batchsize play a role?  For example, if the database batches in groups of 100 then does that mean 10 thousand network hops?
I think each row that comes out of line#5 means a network hop to the remote database.  But I do not know for a fact.I have done some abbreviating in the plan in an attempt to make it fit on the page (line#7 TA = TABLE ACCESS).
SELECT                     A.POLICY , 
                           F.MIN_MEMBER_ID, 
                           MIN(A.EFF_DATE) EFF_DATE, 
                           A.EXP_DATE , 
                           G.DESCRIPTION PROGRAM_NAME, 
                        
[code]...
	View 5 Replies
    View Related
  
    
	
    	
    	
        Sep 7, 2007
        I'm dealing with an ORA-1000 error in a Pro*C application where all the cursors are correctly closed (or so it seems to me).
Here is the code for a simple program which reproduces the problem:
Each cursor is opened in a PL/SQL package:
CREATE OR REPLACE PACKAGE emp_demo_pkg AS
TYPE emp_cur_type IS REF CURSOR;
PROCEDURE open_cur(curs IN OUT emp_cur_type, dept_num IN NUMBER);
END emp_demo_pkg;
[Code]....
While testing the initialization parameter open_cursors is set to 50.
It's my understanding that Oracle doesn't close the cursors until it needs the space for another cursor, which in my test case seems to happen when I enter a value of 50 or bigger for "number of loops". To see how oracle is reusing the cursors, while the test program is running I run SQL*Plus and query v$sesstat for the session that's running the test with the following sentence:
select name, value 
from v$sesstat s, v$statname n
where s.statistic# = n.statistic#
and sid = 7
and name like '%cursor%';
Even before I enter a value for number of loops I can see that the session opened 4 cursors and closed 2 of them:
NAME                                                                  VALUE
---------------------------------------------------------------- ----------
opened cursors cumulative                                                 4
opened cursors current                                                    2
Entering a value of 5 for number of loops yields
NAME                                                                  VALUE
---------------------------------------------------------------- ----------
opened cursors cumulative                                                11 <----- 7+
opened cursors current                                                    8 <----- 6+
With a value of 30
NAME                                                                  VALUE
---------------------------------------------------------------- ----------
opened cursors cumulative                                                36 <----- 25+ (apparently, Oracle reused at least 5 cursors)
opened cursors current                                                   33 <----- 25+
With a value of 47
NAME                                                                  VALUE
---------------------------------------------------------------- ----------
opened cursors cumulative                                                53 <----- 17+
opened cursors current                                                   50 <----- 17+
Now I reached the upper limit set by the initialization parameter open_cursors.
Entering a value of 48, I get the ORA-1000 error.
ORA-01000: maximum open cursors exceeded
ORA-06512: at "SCOTT.EMP_DEMO
Since I open and close the cursor in the same loop iteration, I expect to find in every iterarion 1 explicit cursor and a number of implicit cursors (the PL/SQL call along with the so-called recursive cursors), but I don't expect the sum of all of them to be greater than 50. If my understanding is correct Oracle should be reusing the 50 cursors previously marked as "closeable", not raising the ORA-1000 error.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Feb 25, 2011
        Is it possible to: 
-define a cursor with bind variables
-get a cursor record from these cursor
-and pass the bind variable in the OPEN clause
Did'nt succeed as shown in the example.
SET SERVEROUTPUT ON SIZE 900000;
DECLARE
   --works fine
   CURSOR c1 IS SELECT * FROM USER_TABLES WHERE rownum<3;
   --doesn't work
   --CURSOR c1 IS SELECT * FROM USER_TABLES WHERE rownum<:1;
   crec c1%rowtype;
BEGIN
   --works fine
   OPEN c1;
   --isn't possible ?
   --OPEN c1 USING 3;
[Code]....
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 11, 2011
        just looking around to use the new feature available in oracle 11g to convert the dbms_sql numeric cursor to reference cursor, how to do it? 
parse and execute the sql string first with dbms_sql and then convert it to ref cursor?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Nov 23, 2011
        I want to return ref cursor based on explicit cursors
create table jumbo(id number, name varchar2(20));
insert into jumbo values(1,'jumbo');
create table mumbo(id number, name varchar2(20));
insert into mumbo values(1,'mumbo');
commit;
[Code].....
The above procedure has compilation errors when I am trying to open ref cursor
LINE/COL ERROR
-------- --------------------------------------------------------
20/24    PL/SQL: SQL Statement ignored
20/38    PL/SQL: ORA-00942: table or view does not exist
32/24    PL/SQL: SQL Statement ignored
32/38    PL/SQL: ORA-00942: table or view does not exist
SQL>
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 7, 2013
        Can i user exist when cursor will using For Cursor .
	View 15 Replies
    View Related
  
    
	
    	
    	
        Jul 9, 2012
        NGFID;RECTYPE;RECNAME
25;7;POLES
PARENT
CHILD;1401;9845075;2020
817;8;SUPPORT
PARENT
CHILD
Required output:-
AREA_SRNO = 1 
AREA_NAME = '3rivieres.export.ngf'
File :-mauri.export.ngf 
NGFID;RECTYPE;RECNAME
257;7;POLES
PARENT
CHILD;1401;9845075;2020
8174;8;SUPPORT
PARENT
CHILD
Required output:-
AREA_SRNO = 2 
AREA_NAME = 'mauri.export.ngf'....etc
CREATE TABLE NGF_REC_LINK
(
AREA_SRNO  NUMBER(2),
AREA_NAME  VARCHAR2(40),
NGFID NUMBER(20),
TABLENAME  VARCHAR2(40),
PARENT VARCHAR2(200),
[code]....... 
find the ctl file (ngf_test.ctl) and modify the ctl file as per my requirement.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Mar 16, 2011
        can we have multiple database version running in a single machine with multiple instances provided there are enough resources.Can we do in RAC only?
	View 15 Replies
    View Related
  
    
	
    	
    	
        Jan 2, 2013
        how to insert the data in multiple bases( Same table structure in different bases) using the multiple database links? 
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 17, 2012
        How to merge multiple rows into single row (but multiple columns) efficiently.
For example
IDVal IDDesc IdNum Id_Information_Type Attribute_1 Attribute_2 Attribute_3 Attribute_4 Attribute_5
23 asdc 1 Location USA NM ABQ Four Seasons 87106
23 asdc 1 Stats 2300 91.7 8.2 85432 
23 asdc 1 Audit 1996 June 17 1200
65 affc 2 Location USA TX AUS Hilton 92305
65 affc 2 Stats 5510 42.7 46 9999
65 affc 2 Audit 1996 July 172 1100
where different attributes mean different thing for each Information_type. For example for Information_Type=Location
Attribute_1 means Country
Attribute_2 means State and so on.
For example for Information_Type=Stats
Attribute_1 means Population
Attribute_2 means American Ethnicity percentage and so on.
I want to create a view that shows like below:
IDVal IDDesc IDNum Country State City Hotel ZipCode Population American% Other% Area Audit Year AuditMonth Audit Type AuditTime
23 asdc 1 USA NM ABQ FourSeasons 87106 2300 91.7 46 85432 1996 June 17 1200
65 affc 2 USA TX AUS Hilton 92305 5510 42.7 46 9999 1996 July 172 1100
	View 1 Replies
    View Related
  
    
	
    	
    	
        Nov 26, 2010
        I am attempting to select back multiple values for a specific key on one row. See the example below. I have been able to use the sys_connect_by_path to combine the fields into one field but I am unable to assign them to fields of their own. See the example below
TABLE DETAILS:
Policy id plan name
111 A Plan
111 B Plan
111 Z Plan
112 A Plan
112 Z Plan
My desired result is to be able to show the output as follows
Policy ID Plan_1 Plan_2 Plan_3
111 A Plan B Plan Z PLan
112 A Plan Z PLan
	View 6 Replies
    View Related
  
    
	
    	
    	
        May 6, 2013
        I have a table TableA containing 2 columns ( Name and Value). Here I know what are the values for column Name
TABLEA
=======
Name Parameter
-------------------------
Nexus 11
GPlay 21
Demo 31
I need a query which provides the below output
Desired Output:
======
First Second Third
11 21 31
I have tried the below query
SELECT 
DECODE (name,'Nexus', parameter) First,
DECODE (name, 'GPlay', parameter) Second,
DECODE (name, 'Demo', parameter) Third
FROM (SELECT name, parameter FROM TableA where name in ('Nexus','GPlay','Demo'));
This gives me the output
First Second Third
11 <Empty> <empty>
<empty> 21 <empty?>
<empty?> <empty?> 31
Is there any way to get the output in single line.
	View 3 Replies
    View Related
  
    
	
    	
    	
        May 4, 2010
        find the Test Case below.
--Creation of Table
create table tb1
(ID number(4),
event varchar2(20),
vdate date);
--Inserting Values into the Table.
INSERT ALL INTO tb1 (ID, event, vdate) VALUES (01, 'V1', '01-JAN-2009')
   INTO tb1 (ID, event, vdate) VALUES (01, 'V2', '02-FEB-2009')
   INTO tb1 (ID, event, vdate) VALUES (01, 'V3', '04-MAR-2009')
   INTO tb1 (ID, event, vdate) VALUES (01, 'V4', '03-APR-2009')
   INTO tb1 (ID, event, vdate) VALUES (01, 'V5', '05-MAY-2009')
[Code]...
--Selecting data from Table.
SELECT * FROM TB1;
        ID EVENT                VDATE
---------- -------------------- ---------
         1 V1                   01-JAN-09
         1 V2                   02-FEB-09
         1 V3                   04-MAR-09
         1 V4                   03-APR-09
         1 V5                   05-MAY-09
         2 V1                   01-JAN-10
         2 V2                   02-FEB-10
         2 V3                   04-MAR-10
         2 V4                   03-APR-10
         2 V5                   05-MAY-10
10 rows selected.
how can i display the data as below format using Oracle 9i SQL.
IDV1          V2           V3            V4           V5
---  ----------------  ------------  ---------------  -------------- ------------
11-Jan-092-Feb-094-Mar-093-Apr-095-May-09
21-Jan-102-Feb-104-Mar-103-Apr-105-May-10
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 31, 2012
        i have a program like this
DECLARE
V_VARIABLE1 VARCHAR2(10);
CURSOR_ABC IS select...............;
BEGIN
OPEN CURSOR_ABC;
LOOP
FETCH CURSOR_ABC INTO V_VARIABLE1;
EXIT WHEN CURSOR_ABC%NOTFOUND;
WHAT IF I WANT TO INSERT ANOTHER SAME KINDA CURSOR LOOP HERE LIKE*
CURSOR_XYZ IS select...............;
BEGIN
OPEN CURSOR_XYZ;
LOOP
FETCH CURSOR_XYZ INTO V_VARIABLE2;
EXIT WHEN CURSOR_XYZ%NOTFOUND;
END LOOP;
CLOSE CURSOR_XYZ;
END LOOP;
CLOSE CURSOR_ABC;
	View 3 Replies
    View Related
  
    
	
    	
    	
        Oct 14, 2010
        We receive hand punches (clock data) every day.  Normally a person badges in(hand punch) which creates a row in the clock_tran_processed table.  The information from that hand punch is the employee id (emp_id) the date hand punch occurred and a work_summary id (wrks_id).  At the end of the day, the employee badges out (hand punch out) and another entry in the clock_tran_processed table is created.  The new row will have the emp_id (employee name), date the hand punch occurred  and the same work summary id from the morning.
Normally hand punches should occur in pairs.  One in, one out... or one in, out for lunch, in for lunch, out for day.  I am seeing intervals of three and five.  Meaning the employee clocked in twice and out once, or in once and out twice.  This shouldn't happen.
I am writing a report that will show number of clocks per for all employees that have three(3) or five(5) clock entries.I wrote a ref cursor that gives all the employees that have a count of 3 or 5 and the employee id (emp_id).  I need to pass that employee id to another query that will then get me the dates of the clocks.Here is the ref cursor thus far (I am printing those with a count of 3 and 5).
CODEDECLARE
TYPE ClockTran_Refcur IS REF CURSOR;
ClockTran_cur ClockTran_Refcur;
NumClock_num number :=0;
NumClock_name clock_tran_processed.emp_id%TYPE;
[code]...
How do I pass that variable to the get the clktranpro_time's? I am using "Easy Oracle PL/SQL Programming" but I am not seeing this type of example(pgs 140-148).
	View 5 Replies
    View Related
  
    
	
    	
    	
        Apr 17, 2013
        In our environment we have db link to fetch data from other database. Whenever we try to fetch data using the dblink we receive the wait event "cursor: pin S wait on X" and we do not get any result. The db link works fine. what could be the issue.
DB Version : 11.1.0.7 OS: AIX
	View 1 Replies
    View Related
  
    
	
    	
    	
        Nov 14, 2006
        i am using the Oracle 10 g 10.2 with the windows 2003 3 sessions from a single User shows the currenncy on the top activity graph of the enterprice manager  they are not getting so much resources of system....when i go in the detail of the session i get  
cursor: pin S wait on X 
i am unable to kill these sessions how could i get rid of these sessions 
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 10, 2013
        My task has more lines of code,so i tried to present here only few lines of code where i am getting the error.The following cursor needs to select data from two tables with some conditions that are included in cursor and place those in other table.I used BULK collect.
CURSOR c_arch_trk (p_run_date       DATE,
                      p_nbr_days_arch1  NUMBER,
                      p_nbr_days_arch2 NUMBER )
   IS
       SELECT a.SIS_PGM_START_DATE,a.SIS_PGM_END_DATE,a.PGM_MSTR_NBR,a.PGM_TRK_NBR,a.CNTL_LOCN,a.CMPNY_VNDR_NBR,a.AGRMNT_MSTR_NBR,
                a.SLS_CONT_NBR,b.PGM_NAME,b.PGM_BASIS,b.AGRMNT_CNTL_LOCN
 [code]....      
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jun 30, 2010
        What is the advantage of collections over CURSOR? What is the use for collections and when collections is used?
	View 1 Replies
    View Related