PL/SQL :: Select Case When With More Than One Return Value? 
			Nov 6, 2012
				I would like to know, if there is a solution under 10g for something like this
select case when "C" = 1 
then 
(select 1,2,3,4,5 from dual)
else
(select 6,7,8,9,0 from dual)
end
from dual,
(select 1 "C" from dual) 
What I really need is the full result of (select 1,2,3,4,5 from dual) or (select 6,7,8,9,0 from dual) if a condition as a result of a different sql-statement is true or false. It doesn't matter if the solution uses "case when" or anything else.
	
	View 6 Replies
  
    
		
ADVERTISEMENT
    	
    	
        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
  
    
	
    	
    	
        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
  
    
	
    	
    	
        Feb 11, 2011
        I have the following tables:
create table lookups (code varchar2(20), amount number);
    
insert into lookups values ('Rent' , 500);
insert into lookups values ('Breakpoint' , 10);
        
create table products (id number, cost number, year varchar2(4));
    
insert into products values (1, 1000, '2011');
insert into products values (1, 2000, '2011');
insert into products values (2, 100, '2011');
insert into products values (3, 50, '2011');
    
commit;
I want to write a query which lists the IDs and the sum(cost), and a Y/N indicator which is set to 'Y' IF sum(cost) > ( (lookups.rent value) * (100 - lookups.breakpoint value))/100
I have written this query:
SELECT id,
sum(cost)cost,
year,
CASE
WHEN cost > 
((SELECT amount
[code].......           ORDER BY id;
This returns
       ID       COST YEAR YN
--------- ---------- ---- -
        1       1000 2011 Y
        1       2000 2011 Y
        2        100 2011 N
        3         50 2011 N
The YN is correct, but it needs to sum the amounts. So there should only be one row for id1 = 3000.e.g.
       ID       COST YEAR YN
--------- ---------- ---- -
        1       3000 2011 Y
        2        100 2011 N
        3         50 2011 N
I am not sure how to do this. Or is there a better way of doing this than using CASE.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 24, 2011
        select GAM.FORACID,
    SOL.SOL_DESC,
    GAM.ACCT_NAME,
    LHT.LIM_SANCT_DATE,
    LHT.SANCT_LIM,
   to_char( GAM.CLR_BAL_AMT,'9,99,999.99'),
[code]...
i am getting error like this
ERROR at line 9:
ORA-00911: invalid character
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 11, 2010
        We have and Upper and a Lower function.Is there any function or way in which I can issue a select while ignoring the case(like IgNoReCaSe) in a where clause? I don't want to use like
select * from emp where upper(job)= upper('dba');
or
select * from emp where lower(job)= lower('dba');
I just want to know if there is any way in which I could do it without using upper and lower.
	View 2 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
  
    
	
    	
    	
        Apr 1, 2012
        I need to get the super set(parent) record from a relational table. Following is the structure of the table,
create table relation (data_field1 number(20),data_field2 number(20),data_field3 number(20),
    primary key (data_field1,data_field2,data_field3) );
    insert into relation (data_field1, data_field2, data_field3) values (-10,123,334);
    insert into relation (data_field1, data_field2, data_field3) values (200,123,334);
    insert into relation (data_field1, data_field2, data_field3) values (300,123,334);
    insert into relation (data_field1, data_field2, data_field3) values (400,123,334);
[code].....
Here '-10' will be considered as parent(super set) for all other values. If i have records like below,
    -10   200  300
    100   200  300
    123   200  300
    521  201  300
Output should only contain two rows. A super set row and other distinct row(second column value is not equivalent to super set).
	View 14 Replies
    View Related
  
    
	
    	
    	
        Jan 4, 2013
        nex lines showing SELECT  DISTINCT return different rows when used with ORDER BY.
CREATE TABLE M1( ID_ NUMBER, A NUMBER, B NUMBER);
CREATE TABLE V1 ( A NUMBER, B2 NUMBER);
DELETE FROM M1;
DELETE FROM V1;
INSERT INTO M1 (ID_, A,B) VALUES (107, 5,1);
INSERT INTO M1 (ID_, A,B) VALUES (108, 11,1);
INSERT INTO M1 (ID_, A,B) VALUES (109, 17,1);
[code]....
	View 11 Replies
    View Related
  
    
	
    	
    	
        Jun 25, 2013
        I have a select query select userid from user_tbl where name='hhh';    
 I want to return 0 when no records are fetched and I want to handle both teh cases in a single query other than proc or function.
	View 12 Replies
    View Related
  
    
	
    	
    	
        Jun 30, 2012
        I have created domain indexes on text columns of a materialised view to use "contains" clause when searching for data. The select query with "contains" clause does not return any records, however I was able to retrive data using via regular query using a like search. 
-> will exec ctx_ddl.sync_index('index_name')'resolve my problem?
-> since the view is a materialized view, how can i make sure that the latest data added are also picked up?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 3, 2012
        How to call a function with a row type return in an Oracle select statement.
For e.g. :
If I had this function with a rowtype return:
------------------------------
create function abc
return xyz%rowtype
is
rec xyz%rowtype;
begin
select * into rec from xyz where col1 = n;
return rec;
end;
--------------------------------
How could I use this in a select clause, as there is a multi column return by the function ?
	View 5 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
  
    
	
    	
    	
        Oct 17, 2012
        In Apex 4.2, the item validation of "Function Returning Boolean" and "Function Returning Error Text"; They seam to be backwards. 
Is there a simple statement that can be used to fix this in the apex dictionary?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jan 12, 2011
        If i inserted the values in table it gets inserting very few rows only.I dont know y it is?
	View 15 Replies
    View Related
  
    
	
    	
    	
        Jun 3, 2010
        differs on below SQLs and where I need to use "MAX" and "CASE" together?  
        
         select trunc(sysdate),max(case  when trunc(sysdate)='03jun2010' then 'correctdate'  end) dates
          from dual
          output        dates
          -------------------------------
          6/3/2010     6/3/2010
[code]....
	View 6 Replies
    View Related
  
    
	
    	
    	
        Sep 22, 2010
         I'm starting to Oracle and am having a doubt, need to check if a variable is null if I need to make an appointment if you do not need to make another appointment. I thought I was doing fine, but Oracle is pointing this error: "ORA-00900: invalid SQL statement."
- Case
CASE
WHEN 1 = 1
THEN
select *
from BANANA
WHEN 1 = 2
[code]...
	View 8 Replies
    View Related
  
    
	
    	
    	
        Feb 13, 2011
        How to use decode and case in "where" and "from" clause of a select statement.
   I know the decode can't be used in where clause. In that case how we can use decode and case in from clasue that is: table definition
	View 7 Replies
    View Related
  
    
	
    	
    	
        Nov 21, 2010
        i have small requirement
case when type=1 then max(col2) else end 
case when type=2 then max(col2) else end
i wanted to have difference 2 timestamp
type(datatype- numeric)
col2(datatype-timestamp)
all it should be in one select condition
	View 17 Replies
    View Related
  
    
	
    	
    	
        Feb 7, 2007
        Im trying to make a query to get the grades of students, I already figured out how to get the average from the exams.  Now I would like to make like a select case or if statements to get the actual grade.
Something like this:
average > 89 then grade = 'A'
average > 79 then grade = 'B'
average > 69 then grade = 'C'
average > 59 then grade = 'D'
else grade = 'F'
	View 2 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
  
    
	
    	
    	
        Feb 1, 2012
        Depending on which month the user is running this select the TAG_YEAR needs to be calculated differently.  I have a feeling that I'm over thinking it.  
SELECT DOG_MASTER.DOG_MASTER_ID,
DOG_NAME,
TAG_YEAR,
TAG_NUMBER AS PREVIOUSTAGNUMBER,
ISSUE_DATE
FROM DOG_OWNER
[code].......
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jul 21, 2010
        I would like to know does oracle_sid is case sensitive or not on Linux platform?also let me know on windows platform also?
	View 14 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2011
        select empno,ename,deptno,employee_status from emp,dept where emp.deptno=dept.deptno and 
( employee_status in(Case employee_status when {?Status}=1 then 'A'
when {?Status}= 2 then 'T'
When {?Status}= 3 then 'A'||','||'T'))
OR ( end_date >= {?START_DATE}
AND end_date <= {?END_DATE}
)
)
Since when i pass employee_status as input 1 it have given me 4 records. When I pass employee_status as input 2 it have given me 3 records. When I pass employee_status as input 3 it should give me 4 records + 3 records=7 records.
4 records for employee_status 'A'
3 RECORDS for employee_status 'T'
7 records for employee_status 'A' AND 'T'
How I should write a query to get 7 records.
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 24, 2011
        I am trying to create a query that displays the given error message if the result of my COUNT(*) is smaller than 1, but displays the result of my first query (data) if the total count is bigger than 1 (read: the query found data, so it needs to display the rows according to the search).
What do I need to do to display 'data' if 'data2' contains rows?
WITH data 
AS (SELECT a.order_id, a.session_id, a.log_id, b.date_of_order, a.operation,
b.funct_prod_code, b.sts_status_code, b.ost_order_situation_code, c.order_situation_oms, 
[Code]....
	View 11 Replies
    View Related
  
    
	
    	
    	
        May 7, 2010
        I am facing a problem while retrieving data from table using DECODE/CASE.
Table: PARAM_MSTR
 
MIN_VALMAX_VALPARAM_CODE DESCRIPTION       DATATYPE   
AB1000   HARD PARAMETERTEXT   
CN1000   SOFT PARAMETERTEXT   
0501001   CRYSTAL PARAMETERNUMBER   
512001001   STONE PARAMETERNUMBER 
Now I want to get the parameter description based upon the PARAM_CODE and a value passed which should be in range of MIN_VAL and MAX_VAL. Means when I pass PARAM_CODE=1000 and :parameter=A, then it should check the DATATYPE of the PARAM_CODE, in our case it is 'TEXT' so it should check the passed value between MIN_VAL and MAX_VAL like 
:parameter BETWEEN MIN_VAL AND MAX_VAL and should return 'HARD PARAMETER'.
If I pass PARAM_CODE=1001, then the DATA_TYPE is 'NUMBER', so it will check the :parameter value as Number.
Like :parameter BETWEEN to_number(MIN_VAL) AND to_number(MAX_VAL)
For example:
PARAM_CODE :parametr Result
1000           A      HARD PARAMETER
1000           C      SOFT PARAMETER
1000           P      NULL
1001           25     CRYSTAL PARAMETER
1001           99     STONE PARAMETER
1001           201    NULL
I have written a query using DECODE and CASE statement but it is not working properly. 
SELECT * FROM param_mstr WHERE PARAM_CODE=1000 AND :parameter BETWEEN DECODE(DATATYPE,'NUMBER',CAST(MIN_VAL as NUMBER),MIN_VAL)AND DECODE(DATATYPE,'NUMBER',CAST(MAX_VAL as NUMBER),MAX_VAL)
	View 3 Replies
    View Related
  
    
	
    	
    	
        Oct 11, 2011
        Can we use the sequence.nextval,sequence.currval inside case block.
CREATE TABLE EQUALITY_TEST(NUM1 NUMBER, NUM2 NUMBER, SEQ NUMBER);
INSERT INTO  EQUALITY_TEST  VALUES (  2 ,0 , NULL);
INSERT INTO  EQUALITY_TEST  VALUES (  2 ,2 , NULL);
INSERT INTO  EQUALITY_TEST  VALUES (  2 ,2 , NULL);
INSERT INTO  EQUALITY_TEST  VALUES (  12 ,2 , NULL);
INSERT INTO  EQUALITY_TEST  VALUES (  12 ,12 , NULL);
INSERT INTO  EQUALITY_TEST  VALUES (  12 ,12 , NULL);
CREATE  SEQUENCE SEQ_TEMP START WITH 100 INCREMENT BY 1;
Now i need  to update SEQ  column with SEQ_TEMP  sequence. When NUM1,NUM2 values are unequal sequence should be incremented otherwise need  to use the same sequence number(CURRVAL)
I  have tried   like this 
UPDATE  EQUALITY_TEST 
SET    SEQ= 
CASE WHEN NUM1=NUM2 
THEN  SEQ_TEMP.NEXTVAL 
ELSE 
SEQ_TEMP.CURRVAL 
END  ;
SELECT *  FROM   EQUALITY_TEST;
Output 
NUM1NUM2SEQ
120100
222101
322102
4122103
51212104
61212105
But Required Output 
NUM1NUM2SEQ
120100
222100
322100
4122101
51212101
61212101
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 30, 2011
        is there a possible to use a case statement in insert clause?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 19, 2010
        I am having some records in the table. If the record num is 
                     1--It should show the month as "Apr"
                     2--"May"
                     3--"Jun"
                     4--"July"
                     5--"Aug"
                     6--"Sept"
if it is having other than these 6 should show "0" for the remaining months.
	View 10 Replies
    View Related
  
    
	
    	
    	
        May 16, 2013
        How to use CASE stmt in WHERE clause?
	View 3 Replies
    View Related