SQL & PL/SQL :: Cursor Select For Update / Multiple Columns Of Different Tables
			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
  
    
	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
  
    
	
    	
    	
        Sep 6, 2013
        I am trying to update multiple columns from one table based on the results of another table So I have 3 tables as follows 
HISTORYSUMM_SNAPADM_CHOICE 
My SQL code is loosely SELECT SUM(H.HIS1), 
SS.SNAP1,
AC.ADM1FROMHISTORY H, 
SUMM_SNAP SS,ADM_CHOICE ACWHERE H.HIS2=SS.SNAP2AND SS.SNAP3=AC.ADM2GROUP BY SS.SNAP1, 
AC.ADM1
 This works, and I am able to SUM the column as I need with the right numbers.  I altered the SUMM_SNAP table and now I want this summarized column to be in the table I tried using UPDATE, but there is no FROM clause to let me do the table join/group by 
UPDATE SUMM_SNAPSET SUMM_SNAP.SNAP3=SUM(H.HIS1)FROMHISTORY H,
 SUMM_SNAP SS,ADM_CHOICE AC
WHERE H.HIS2=SS.SNAP2AND SS.SNAP3=AC.ADM2
GROUP BY SS.SNAP1, AC.ADM1 
The above is obviously wrong - but just trying to show whatI was thinking What would be the best method to get the numbers from the SUM into a table?
	View 5 Replies
    View Related
  
    
	
    	
    	
        May 30, 2013
        i am reading the columns value from different table but i want to update it with single update statement. such as how to update multiple columns (50 columns) of table with single update statement .. is there any sql statement available i know it how to do with pl/sql.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Dec 12, 2011
        how to over come this error, because i need to update only 3 columns in the table and iam getting error when iam updating like this
 
update country1 set cname='japan','usa'
where cid=100,101
ERROR:ORA-01747,INVALID  USER.TABLE.COLUMN,TABLE.COLUMN,OR COLUMN
SPECIFICATION
	View 6 Replies
    View Related
  
    
	
    	
    	
        Sep 17, 2010
        I've read so many different pages on this topic but I can't seem to get my query the way it needs to be.  Here's the query:
select admitnbr, lastname||', '||firstname||' '||finitial, hphone, mobile, wphone, med_rec, dob 
from patients join schedule using (key_patien)
join adtmirro using (key_patien) 
where appt_state = 'ON HOLD'
Because patients in my database can have multiple appointments "on hold" there are duplicates in the results.  I only need 1 record per patient in order to forward this information into an automated dialer to contact that patient.  I do NOT want to call the patient over and over again.  Once will suffice.  I'm trying to make a distinction on the column 'med_rec'.  One row per 'med_rec' will be awesome but I can't find a way to create a distinct on that column.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jan 25, 2013
        I am trying to update a table column values if any change occurs using bulk collect and for all update not able to get idea. below is the proc working out.it is for insert and update using the cursors.
CREATE OR REPLACE PROCEDURE PRC_INS(P_ID IN NUMBER,P_STAT OUT NUMBER) IS
  TYPE T_TEST_TAB IS TABLE OF T_DTLS%ROWTYPE;
  V_PARAM  T_TEST_TAB;
  V_STATUS   NUMBER;
  V_BUS     VARCHAR2(20); 
  V_UP          VARCHAR2(1);
  V_Q        VARCHAR2(50); 
[Code]....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jan 25, 2013
        im trying to select columns from different tables dynamically in a function . The parameter for the function will be table name and column id's, In this number of columns may vary . Is it possible to have dynamic %rowtype to store the cursor value in it.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 29, 2011
        I have two tables containing dates:
A
From____________To________
01.01.2009  ||  01.01.2010
01.01.2013  ||  01.10.2014
B
From____________To________
01.01.2007  ||  01.01.2008
01.01.2011  ||  01.10.2012
01.01.2009  ||  01.01.2010
01.01.2015  ||  01.01.2016
I need to get list of all entries from Table A and entries from B where dates are before min begin date from A or somewhere between any entry from A.
In this Example result:
From____________To________
01.01.2007  ||  01.01.2008
01.01.2009  ||  01.01.2010
01.01.2011  ||  01.10.2012
01.01.2013  ||  01.10.2014
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 26, 2010
        I am issuing an update statement in which I am using multiple tables it is giving me an error " set keyword missing"
update E_CONT_DETAIL_NUMB_VALUE ecdnv, y_obj_category yoc, t_contact tc 
set ecdnv.ContTPRecCount = 1000
where tc.default_category_id = (select primary_key from y_ojb_category where tree_position = 'CONT')
and ecdnv.detail_field_id=tc.default_category_id; 
update E_CONT_DETAIL_NUMB_VALUE ecdnv, y_obj_category yoc, t_contact tc
                                     *
ERROR at line 1:
ORA-00971: missing SET keyword
	View 4 Replies
    View Related
  
    
	
    	
    	
        Nov 21, 2012
        I have to write a "after update trigger". Here, i have to update the stock table by other inventory tables (by complex query).
I have written trigger below. how to make it correct? 
create or replace trigger trg_stk_upd_pur
after update on O_STOCK_EFFECTS
REFERENCING NEW AS new OLD AS old
  FOR EACH ROW
[Code]....
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 25, 2011
        I am working on the following SQL select and I am having a mental block on how to get it fixed. I have two tables that I need to match on the codes in each table. If there is a just one record in Table1 with the same code as one record in table2 and both the date and name match then dont output those two records. Output all records if there are more than 1 record with the same code in each table. Below is some example data that is representive of a sample in the two tables and how the output should look based on that data:
Table1
code   date           name
aaaa   1/1/2003   billy bob
bbbb   2/2/2004   louis lewis
cccc   3/3/2005   joe crab
dddd   4/4/2006   mary little
eeee   5/5/2007   joe black
Table2
code    date         name
aaaa   2/2/2004  larry cole
aaaa   3/3/2005  nat king
bbbb   2/2/2004  louis lewis
cccc   3/3/2005   joe crab
cccc   6/6/2008  dennis jackson
dddd   7/7/2009  missy muffet
dddd   5/5/2007  joe black
eeee   8/8/2010  elton rocket
desired output results from select
aaaa   1/1/2003   billy bob     aaaa   2/2/2004  larry cole
aaaa   1/1/2003   billy bob     aaaa   3/3/2005  nat king
cccc   3/3/2005   joe crab     cccc   3/3/2005   joe crab
cccc   3/3/2005   joe crab     cccc   6/6/2008  dennis jackson
dddd   4/4/2006   mary little   dddd   7/7/2009  missy muffet
dddd   4/4/2006   mary little   dddd   7/7/2009  missy muffet
eeee   5/5/2007   joe black    eeee   8/8/2010  elton rocket
Here is the select that I have so far:
select table1.rowid, table1_code, table1_date, table1_name,  
        table2.rowid, table2_code, table2_date, table2_name from table1, table2 
        where table1_code= table2_code
        order by table1_code;
The above select gives me all records just fine, but does not eliminate single records that match. I tried using the Count(table1_code) > 1 and table2 code but I get a message about inproper grouping. 
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 25, 2011
          I have had a google around and can't seem to find an answer as to how do do the following Select statement. i am wanting to Select the following fields from across multiple tables. 
(field.table) 
CustName.CUST
SalesNo.SALE  
SalesDate.SALE
ItemDes.ITEM
Qty.SALEITEM
OrderComplete.SALEITEM
with 2 types of WHERE criteria:
WHERE SalesDate is between 'dateX' AND 'dateY' 
and also WHERE OrderComplete = 'Y'
i understand this will require some sort of join in the statement so the keys for the different tables are as follows: 
CUST 
CustNo - PK
SALE
SalesNo - PK
CustNo - fk
ITEM
ItemNo - PK
SALEITEM
SalesNo -fk
ItemNo - fk (compound PK)
i have had a play around with using some joins & embedded statements
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 16, 2011
        i want to select columns of 3 tables in such a way that period column should be in the group by function.
create view allocated_budgets_detail as 
select ba.ba_fin_year, ba.ba_start_date, ba.ba_end_date, ba.ba_rev_no,
bh.bh_budget_code, 
bd.bd_period, 
bb.bb_entered_amount
from budget_header bh, budget_allocation ba, budget_distribution bd, budget_balance bb
where bh.bh_budget_id = ba.ba_budget_id
and ba.ba_line_id = bd.bd_budget_line_id
and ba.ba_line_id = bb.bb_budget_line_id
group by bd.bd_period
	View 13 Replies
    View Related
  
    
	
    	
    	
        Nov 22, 2010
        i am trying to left join a selection of two or more tables. what i have found, and solved part of my problem, is that oracle left joins only the last table in the select statement ...
i.e : select * from A, B left join C on C.id = A.id wouldn't work because left join applies to B and not A.
but as my queries grow i need to make something as follows :
select * from A, B
left join C on (C.ID_A = A.ID and C.ID_B = B.ID)
[... evantually more left joins as the preceding one may go here]
this query works for DB2 but Oracle claims that "A"."ID" is an invalid identifier, while the B.ID is recognized since it's the last table stated before the "LEFT JOIN" keyword.
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 9, 2011
        I'm writing a Procedure which Updates or Inserts data in Multiple tables. Selected fields of 10 tables need to be updated or Inserted. For this I created a table which comprises of fields related to all 10 tables. Then I write Procedure. Under this I create a Cursor which uploads the data from the newly created table which contains different fields of 10 tables. Then I write Update and Insert statements one by one for all 10 tables.
Sample Procedure below.
-------------------------------------------
Create or replace procedure p_proc as 
spidm spriden.spriden_pidm%type; 
cursor mycur is select * from mytable;  
begin
for rec in mycur
[code]......  
----------
Note: I created table on my server because data is coming from different server. They will upload the data in the table from there I pick and update the tables. Is updating or Inserting data in different tables one by one is correct?
	View 15 Replies
    View Related
  
    
	
    	
    	
        Dec 17, 2010
        How to get all the name of tables that a user can select, insert, update or delete?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 7, 2010
        I have to update 20 and 60 million records of a table. The update statement are
1> 20 million recs
update mycustomer set update_time=add_months(sysdate,240) where seq_num = 1;
commit;
2> 60 million recs
update mycustomer set update_time=sysdate-seq_num where seq_num <> 1;
commit;
Q1> Is there any way to improve performance 
Q2> Will parallel dml improve performance
Q2> Would a pl/sql cursor make any difference in speed.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jan 21, 2011
        I have a two question.
Question 1:How to select all columns from table except those columns which i type in query 
Question 2:How to select all columns from table where all columns are not null without type each column name which is in empty data
	View 5 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
  
    
	
    	
    	
        Mar 3, 2011
        I have a table with around 80 columns. All i need is to select first 40 columns. 
Is there any way to select first 40 columns without giving all the 40 Column Names in select clause.
	View 2 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
  
    
	
    	
    	
        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 21, 2011
        I have one doubt about update command in sql. How to update the multiple rows with different values using update statment. 
Eg:-
SQL> set linesize 500;
SQL> set pagesize 500;
SQL> select * from emp;
SQL> select empno,ename,sal from emp;
SQL> select empno,ename,sal from emp;
     EMPNO ENAME             SAL
---------- ---------- ----------
      7839 KING             5000
      7698 BLAKE            2850
      7782 CLARK            2450
      7566 JONES            2975
      7654 MARTIN           1250
[Code]....
The above table contains 14 records. Now i would like to update the salary column with different values like
EMPNO  SAL
===========
7839 18000
7698 20000
7782 5000
...
...
...
7934  25000
How to update above values with single update query. 
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jul 19, 2011
        I have a column "empno" in EMP table and "deptno" in DEPT table . I want to update both the columns with single UPDATE statement. With out a creation of stored procedure or view(updating it through view).
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 21, 2010
        in retrieve column data in the cursor.My requirement is I created a table dynamically as I don't know how many fields will be there.And the table structure would be like this 
Filed1 varchar2(10)
Filed2 varchar2(10)
-----------
-----------
Filedn-1 varchar2(10)
Filedn varchar2(10)
[code]...
As in the cur.filed value.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jul 12, 2012
        I have 8 columns. Some of them might be null.I want to display all 8 columns in my result. Not null columns will be first and null at the end.Here is a sample data :
Employee table  :
 Employee_id   Emp_fname  emp_lname  emp_mname  dept salary emp_height  emp_weight
   1               aaa        ddd                d1   100      6           180
   2               bbb                ccc             120                 169
   3               dfe                           d2            5.9         223
The expected result is :
result1 result2   result3 result4  result5  result6 result7 result8
1        aaa        ddd     d1       100     6        180
2        bbb        ccc     120      169
3        dfe        d2      5.9      223
	View 8 Replies
    View Related
  
    
	
    	
    	
        Feb 18, 2010
        I have come across a code where i need to know exact logic for the use of FOR UPDATE and COMMIT used in a cursor.The code is like :
Declare
       Cursor c1 is select * from emp FOR UPDATE;
       Z c1%rowtype;
Begin
     Open C1;
     Fetch c1 into Z;
     dbms_output.put_line(z.ename);
     Commit;
  Fetch c1 into Z;
  dbms_output.put_line(z.ename);
end;
When i run above code, i get error as below, but first value from table emp i.e. emp.ename is displayed :
Error at line 1
ORA-01002: fetch out of sequence
ORA-06512: at line 9
But when i run by removing FOR UPDATE, i get first 2 values displayed without any error message:
Declare
       Cursor c1 is select * from emp;
       Z c1%rowtype;
Begin
     Open C1;
     Fetch c1 into Z;
     dbms_output.put_line(z.ename);
     Commit;
  Fetch c1 into Z;
  dbms_output.put_line(z.ename);
end;
	View 2 Replies
    View Related
  
    
	
    	
    	
        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
    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