SQL & PL/SQL :: Update Query Using Case When Exists?
			Jan 4, 2013
				I am trying to use the below query
update t_emp set TTL_FLG = 
CASE 
WHEN EXISTS
(SELECT 1 from Schema1.T_STG_LW_EMP E
WHERE  E.Employee = Schema2.T_emp.EMPLOYEE_NUMBER
AND E.JB_CODE like '%TP%' or E.JB_CODE like '%DGD%' or E.JB_CODE like '%PDD%'
 or E.JB_CODE like '%YND%'
)
THEN 'Y'
ELSE 'N'
END;
	
	View 1 Replies
  
    
	ADVERTISEMENT
    	
    	
        Aug 14, 2012
        I have been trying to use case statements with oracle table type by really not sure how to go about it. I know it might be simple but it been giving me hard time. 
Here is my Cursor:
CURSOR c_chk_style IS
      SELECT DISTINCT 1
        FROM TABLE(CAST(I_message.ExtOfXOrderDesc_TBL(1).ExtOfXOrderSkuDesc_TBL AS "RIB_ExtOfXOrderSkuDesc_TBL")) item_diff,
   
[code]...
Now i know that the table type "RIB_ExtOfXOrderSkuDesc_TBL" will be always populated but the table type "RIB_ExtOfXOrderPackDesc_TBL" may not be populate and can be null. So i want to run the exists against the "RIB_ExtOfXOrderPackDesc_TBL" aliased pack_diff only if it is populated. If its null i dont want to run the exists clause. 
	View 15 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2007
        I have a single table with a TOTAL_TIME column which I want to increment by a certain amount every time I get a request from a specific user. If the row for that user does not exist, it should be created and the TOTAL_TIME column should be set to the value that just came in. Otherwise, if it does exist, it should be incremented by the value passed in.
How can I accomplish this in oracle? I don't want to just first do a select, then insert, because that can cause race conditions. I want something that'll do the check and insert/update in one statement (locked).
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 30, 2013
        Can we use select statement in case statment for an update?
Example
UPDATE x SET field = CASE WHEN
    (SELECT field1
    FROM Y
    WHERE field3 = x.field3
    IS NOT NULL
    THEN 'B'
    ELSE 'C'
where cny# = 112160
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jul 12, 2012
        How to rewrite this query using NOT EXISTS instead of NOT IN
SELECT   STUD_ID,
         join_date,
         stud_nme
  FROM   code_balance
[code]...
	View 1 Replies
    View Related
  
    
	
    	
    	
        Nov 26, 2012
         i tried the following update on one table:
update siebel.s_contact
set marital_stat_cd = 
  case
    when (marital_stat_cd = 'Casado') then 'Married'
    when (marital_stat_cd = 'Solteiro') then 'Single'
    when (marital_stat_cd = 'Divorciado') then 'Divorced'
  end
As you can see i forgot the else, so my update is wrong.
I thought i could rollback the update issuing the rollback statement, but when i have issue the rollback, the i query the table to confirm that the update was rollbacked and for my suprise the update is commited.
I didn�t issue  the commit statement after the update and i confirmed that the auto-commit feature to worksheets is disabled, so i don�t understand whit the update was commited.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Feb 3, 2012
        SQL> select count(*) from emp where empno not in ( select mgr from emp );
  COUNT(*)
----------
         0
SQL> select count(*) from emp T1
  2  where not exists ( select null from emp T2 where t2.mgr = t1.empno );
  COUNT(*)
----------
         9
I fired above query and I totally confused that  why both are giving different output.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 25, 2011
        How to re-write sql with NOT EXISTS using analytic functions?I have the following sql:
SELECT f1, f2
FROM t1 A2
WHERE NOT EXISTS (SELECT 1 FROM t1 A3 WHERE A3.f1=A2f1 AND A3.f2=A2.f2
AND A3.f3=A2.f3 AND A3.f4 = 0
)
	View 6 Replies
    View Related
  
    
	
    	
    	
        Mar 23, 2009
        I have a query that will either return one record or zero records.  When it returns zero records I want to replace my attributes with a sentinel, like 'N/A'.  I tried the CASE statement but couldn't get anything to work
Sample (does not work):
select 
(case when exists (select product from tbl_product where productid = '123') then product else 'N/A' end) product
from tbl_product
where productid= '123';
If one record exists it should produce:  'My Widget' (or whatever)
If zero records exist it should produce: 'N/A'
	View 3 Replies
    View Related
  
    
	
    	
    	
        May 14, 2012
         The query has a case statement in the where clause so that results can be filtered.  If I pass "ut" for sso_id then the query returns 21 rows.  If I remove the case statement and hard code "a.sso_id like lower('ut'||'%')" then the query returns 41 rows.  The query should be returning 41 rows all the time.
Problem:
When passing "ut" as an SSOID parameter to the Procedure the query returns 21 rows.Taking the query and hard coding "a.sso_id like lower('ut'||'%')" the query returns 41 rows.
Result:
query should be returning 41 rows when "ut" is passed an an SSOID parameter.
Returns 21 rows
procedure SSO (SSOID      in  varchar2 default null,
               Name       in  varchar2 default null,
               Campus     in  varchar2 default null,
               Department in  varchar2 default null,
              
[code]...
Returns 41 rows
          open Results for
            select a.sso_id, 
                   (a.name_last||', '||a.name_first) as name, 
                   b.site,
                 
[code]...
Test Data
CREATE TABLE ID
(
  SSO_ID           VARCHAR2(60 BYTE),
  NAME_FIRST       VARCHAR2(100 BYTE),
  NAME_LAST        VARCHAR2(100 BYTE),
[code]...
Test Data
CREATE TABLE NT
(
  LOWER_NT_ID  VARCHAR2(60 BYTE),
  DEPARTMENT   VARCHAR2(100 BYTE),
 
[code]....
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 3, 2013
        I am using oracle 11G database,I have to check length of name column value from employee table and if length(name) > 39 then value should be substr(name,0,39) else value should be name only. i tried below code 
 
select CASE when length(name) > 39,substr(name,0,39)
else name
END
from employee but its not working ..can I do this using decode too ? ,,which one would be better or this is not a right way ?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Oct 1, 2013
        I am using oracle database 11g.My use case is I do have a table with following valuesTable name -test
product id     productsortdescription
H58098        ACETAMIDOHYDROXYPHENYLTHIAZOLE
043994         Alloy .MM.INTHICK  My query is  
select * from test order by productsortdescription;  this query gives result as is like
product id     productsortdescription
H58098        ACETA
product id     productsortdescription
H58098        ACETAMIDOHYDROXYPHENYLTHIAZOLE
043994         Alloy .MM.INTHICK
MIDOHYDROXYPHENYLTHIAZOLE
043994         Alloy .MM.INTHICK
but Expected output/result should be like below: 
product id     productsortdescription
043994     Alloy .MM.INTHICKH58098      ACETAMIDOHYDROXYPHENYLTHIAZOLE as All and ACE 
in productsortdescriptionl is in small case than C. NLS Session parameters are as following
SELECT * from NLS_SESSION_PARAMETERS;
 NLS_LANGUAGE    AMERICANNLS_TERRITORY    AMERICANLS_CURRENCY    $NLS_ISO_CURRENCY    AMERICANLS_NUMERIC_CHARACTERS    .,
NLS_CALENDAR    GREGORIANNLS_DATE_FORMAT    DD-MON-RRNLS_DATE_LANGUAGE    AMERICANNLS_SORT    BINARYNLS_TIME_FORMAT    HH.MI.SSXFF AMNLS_TIMESTAMP_FORMAT    DD-MON-RR HH.MI.SSXFF AMNLS_TIME_TZ_FORMAT    HH.MI.SSXFF AM TZRNLS_TIMESTAMP_TZ_FORMAT    DD-MON-RR HH.MI.SSXFF AM TZRNLS_DUAL_CURRENCY    $NLS_COMP    BINARYNLS_LENGTH_SEMANTICS    BYTENLS_NCHAR_CONV_EXCP    FALSE 
	View 5 Replies
    View Related
  
    
	
    	
    	
        Oct 15, 2012
        I am using Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production version
I am having the data in following table -
drop table stud_fact;
create table stud_fact(stud_NM, LVL_CD,ST_DT_DIM_KEY,OVRNK) as select
'ABG Sundal','H','20110630','175' from dual union all select
[Code].....
	View 8 Replies
    View Related
  
    
	
    	
    	
        Oct 13, 2012
        I want to count the batch records using BATCH_ID with CASE statement ,for that i am using below query but its not working ,
SELECT COUNT(*) FROM <TABLENAME> WHERE VNBATCH_ID=CASE WHEN #SDC <10 AND #PERIOD >=10 THEN
0||#SDC||#PERIOD||#BATCH_ID
WHEN #SDC <10 AND #PERIOD <10 THEN
0||#SDC||0||#PERIOD||#BATCH_ID
WHEN #SDC >=10 AND #PERIOD <10 THEN
#SDC||0||#PERIOD||#BATCH_ID
ELSE
#SDC||#PERIOD||#BATCH_ID
END
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jun 2, 2011
        below query is returning two rows.The thing now happening is the query is returning the output for both the case statements.But what is need only when the first case staement is NULL then it should go for second case.
SELECT DISTINCT CASE
WHEN esc.x1 = Substr(inp.y, 0, 3)
AND esc.x2 = Substr(inp.y, 4, 2)THEN esc.cc
WHEN esc.mcc = Substr(inp.y, 0, 3)
AND esc.mnc = Substr(inp.y, 4, 3)THEN esc.cc
[code]....
I tried using rownum=1 but it filters out valid records.correcting the above query so that if the first case is null then only it should go for second case.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 31, 2012
        Below Query I understand is improper wrt syntax. Need to modify query to fetch correct result for me.
select * from tableA order by 
case when a is not null then
a DESC
else 
b DESC, c DESC END
Note: DESC or ASC is dynamic coming from java-code.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jun 13, 2013
        Can I use CASE statement Inside a Oracle Report Query. I'm using Oracle Reports Builder 10g.
My Report Query looks like this,
select invh_code, invh_number, invh_date, invh_cm_code, im_description
from invoice_head, invoice_det, unit_of_measurement, item_master
where invd_invh_code = invh_code and im_code = invd_item_code
AND 
(case :p_flag when 1 then (substr(invd_item_number,0,(length(invd_item_number)-4)) BETWEEN :P_V_ITM_FRM AND :P_V_ITM_TO)
else 1
end)
order by invh_number
:p_flag is a parameter that i pass from oracle form and based on that value (:p_flag=1) i need to include this specific condition
else omit that condition.
But the CASE statement is throwing Error
ORA-00907 :Missing Right Paranthesis
(case :p_flag when 1 then (substr(invd_item_number,0,(length(invd_item_number)-4))
==> BETWEEN :P_V_ITM_FRM AND :P_V_ITM_TO)
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 16, 2013
        My DB version is
BANNER                                                        
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - 64bi
PL/SQL Release 10.2.0.1.0 - Production                          
CORE 10.2.0.1.0 Production                                        
TNS for Linux: Version 10.2.0.1.0 - Production                  
NLSRTL Version 10.2.0.1.0 - Production       
I'm getting this error while executing a package.But this is unpredictable because sometimes it's coming and sometimes it's not. Everytime I'm passing the value as 'ALERT' for the transaction name. Sometimes it's successful and sometimes it's throwing ORA-06592 
CASE UPPER(IC_TRANSACTION_NAME)
WHEN 'ALERT' THEN
SELECT A.FACILITY_ID INTO VN_FACILITY_ID FROM ALERT A
WHERE A.ALERT_ID = IN_PARENT_NODE_ID;
INSERT INTO TRANSACTION_HISTORY (TXN_HISTORY_ID,
[code]....
	View 23 Replies
    View Related
  
    
	
    	
    	
        Jun 26, 2012
        How to update single table column using join query
Example:
Update table1 t1,table2 t2
set t1.column2 = 'Y'
where t1.column1 = t2.column1
	View 8 Replies
    View Related
  
    
	
    	
    	
        Jun 12, 2013
        I have 2 tables with 3 common columns (Col1, col2,Primary). One common column name is primary (oracle key word).Around 2 lakhs rows to be updated and No indexes are used on these tables. I need to write an update query as shown below. 
 
Emp table 
Col1col2primay
100101y
103104n
201105y
100101y
Dept table 
Col1col2primay
100101null
103104null
000656null
Update query Result 
Col1col2primary
100101y
103104n
	View 16 Replies
    View Related
  
    
	
    	
    	
        Aug 5, 2010
        I have this SQL select to give me all the nodes of a tree starting at a particular node:
SELECT tree.node_id, LEVEL depth_level
FROM tree_of_nodes nodes
START WITH nodes.node_id = 1000
CONNECT BY PRIOR nodes.node_id = nodes.parent_id
I need to update a column called dept_level, which is essentially the same as Oracle's LEVEL. Something like this statement is what I need, but obviously this statement doesn't work:
update tree_of_nodes
set depth_level = LEVEL
START WITH nodes.node_id = 1000
CONNECT BY PRIOR nodes.node_id = nodes.parent_id
 I've tried inline views and other approaches and have not found a method that works. 
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 9, 2009
        I've just started with the Oracle SQL and come from a heavy MS SQL background and I understand that here are some natural differences in the syntax but I'm stumped as to why the following sql represents a problem:
update MASTERMICODES t1
set t1.TEMPTA = ( select t2.TAFCODE
from TA_FEATURES t2
where t2.FCODE = t1.FCODE
)
It returns Error report:
SQL Error: ORA-01427: single-row subquery returns more than one row
01427. 00000 -  "single-row subquery returns more than one row"
*Cause:    
*Action:
I want it to return more than one row...in fact I want it to make on all rows that have the same fcode between tables.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 18, 2012
        I am looking to build a query to update a current value in a DBA view to a new one.i.e. updating directories based on the current value: 
CREATE OR REPLACE DIRECTORY 'DIRECTORY_NAME' AS 'DIRECTORY_PATH'(substr(directory_path, 1,5) + '/&dbname' {i.e. this is different for every database name }+  'DIRECTORY_PATH'(string after /xyz/)
WHERE DIRECTORY_NAME in
      (       select DIRECTORY_NAME
              from   DBA_DIRECTORIES
              WHERE DIRECTORY_PATH 
              like '/xyz/%'
       )
i.e. resulting output should be: 
CREATE OR REPLACE DIRECTORY 'ABC' AS '/xyz/DBNAME/abc/def/';
(when the directory previously was 'xyz/abc/def/') i.e. basically inserting the db name into the directory.where DBNAME is a variable more directories are added frequently so therefore this needs to be a dynamic procedure to change the directories in the db.
	View 26 Replies
    View Related
  
    
	
    	
    	
        Sep 20, 2011
        The requirement is I have a table (TAB1), wherein I have 3 columns, ID, LID and STATUS. 
The value in ID column = ID_SEQ.NEXTVAL,and LID will be either 0 or 1 and the possible values for STATUS are 'ED','CP', NULL. The ID column is not suppose to have duplicate values, but there is no check on the table for the same.
Someone has updated the existing data and ID column is containing duplicate values. Wherever LID = 0 and STATUS = NULL and if only if ID is duplicated then the ID_SEQ.NEXTVAL has to be assigned to ID field, so that there are no more duplicate values.
CREATE TABLE tab1 (id NUMBER , lid NUMBER, status VARCHAR2(10));
Existing Data
------------------
INSERT INTO tab1 VALUES (1,0, 'ED');
INSERT INTO tab1 VALUES (1,0, 'CP');
INSERT INTO tab1 VALUES (1,0, NULL);
INSERT INTO tab1 VALUES (1,0, NULL);
INSERT INTO tab1 VALUES (1,0, NULL);
INSERT INTO tab1 VALUES (1,0, NULL);
[code]....
get the result using a single update statement.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 22, 2011
        How to update two tables in single set or single query ?
	View 8 Replies
    View Related
  
    
	
    	
    	
        Nov 19, 2010
        We have a form which contain the multiple record. 
I require to disable the record during the query, if the certain flag (Y) is activiate. And their as allow to display the next record without the flag (N) is editable.
how to done it.
	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
  
    
	
    	
    	
        Mar 21, 2011
        There is a table copper_terminal with columns 
small_world_id,address_number,street_name.
I need to update small_world_id with address_number,street_name I am trying to write as
SQL> update COPPER_TERMINAL set smallworld_id=ADDRESS_NUMBER||_||STREET_NAME whe
re copper_terminal_id='45';
update COPPER_TERMINAL set smallworld_id=ADDRESS_NUMBER||,||STREET_NAME where co
pper_terminal_id='45'
                                                         *
ERROR at line 1: ORA-00911: invalid character
How to correct this??
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 15, 2012
        is it possible to update a same column name in two tables.
I have two tables in same schema
(1)table name
pem.igp_parent
column name
igp_no.
igp_type
(2)table name
pem.igp_child
column name
igp_no.
igp_type
i want to update igp_no column in one query, how it would be possible.
	View 2 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