PL/SQL :: Multiple Values In Condition
			Aug 30, 2012
				I am trying to do something like this
SELECT clave_grupo FROM SS_TTABLAS
WHERE CLAVE_GRUPO IN 
(
CASE WHEN (condition) THEN 'v1'
ELSE ('v1','v2',v3') 
end
)
This is the error msg:
ORA-00907: missing right parenthesis
just before ,'v2',v3') 
	
	View 2 Replies
  
    
	ADVERTISEMENT
    	
    	
        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
  
    
	
    	
    	
        Jun 3, 2011
        I  have a result of Query like this:
Col1 Col2 Col3
T1     15    20  
T1      18   19
T1       5    20
T2     15    20
T2     18    19
And I just need to display only the T's that would meet the condition Col2 in (15,18) and Col3 in (20,19).
I try with a condition where col2 in (15,18) and col3 in (20,19) and that works, but I don't need to display T1, because T1 has a Col2=5 and Col3=20, I just have to display T2 that just satisfies all my conditions, Col2 in (15,18) and Col3 in (20,19). It's something like a vertical search.
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 4, 2011
        Suppose I have a table. 
SQL> select * from emp;
 
EMPNO ENAME          DEPTNO        SAL
---------- ---------- ---------- ----------
1 RN                 10         10
3 C                  20         40
4 A                  10         20
5 B                  20        100
6 D                  10         11
7 S                  30        300
6 rows selected
Now I need to update the table as for all employees will get sal 100 for depetno=10 and employees of deptno=20 will get sal=200. I need to update this with a single query.
	View 12 Replies
    View Related
  
    
	
    	
    	
        Aug 23, 2010
        How can I use OR condition in sql to check whether if the 6 col values in a row is NULL, I need something like below, but idk the syntax of checking if either of the mentioned cols is null using an or condition.
select a.mid
FROM table_a a
JOIN table_b b
ON a.dept = b.dept
JOIN table_c c
ON b.eid = c.eid
WHERE a.tid = :tid
AND (a.i1 or a.i2 or a.i3 or a.n1 or a.n2 or a.n3 or a.t1 or a.t2 or a.t3 ) IS NULL
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 10, 2012
        CREATE TABLE test1 
(strt_num   NUMBER , 
end_num    NUMBER , 
des        VARCHAR2(5),
CONSTRAINT pk_strt_num PRIMARY KEY (strt_num)
);
INSERT INTO test1 VALUES (5,   8, 'GC');
INSERT INTO test1 VALUES (10, 25, 'AB');
INSERT INTO test1 VALUES (12, 35, 'PC');
INSERT INTO test1 VALUES (22, 65, 'LJ');
SELECT * FROM test1
STRT_NUM       END_NUM       DES
-------------- ------------ -------------
             5            8         GC
            10           25         AB
            12           35         PC
            22           65         LJ
The requirement is the records should be split based on below conditions
1. Split only those records WHERE (end_num - strt_num) > 10
2. If TRUNC((end_num - strt_num)/10) = n, then n + 1 number of rows should be created for that record
3. While splitting the records, 
   -> For first record , START_NUM = Original STRT_NUM and END_NUM = START_NUM + 10
   -> Second record , STRT_NUM = previous END_NUM + 1 and END_NUM = previous END_NUM + 10
   And this should continue for all records except the last record
   -> For last record, STRT_NUM = previous END_NUM + 1 AND END_NUM = Original END_NUM
This table has 5 million records. Only for 2000 records (end_num - strt_num) > 10.
Expected Output.
 STRT_NUM         END_NUM     DES
-------------        --------    ---------
             5            8         GC -- No chage, END_NUM - STRT_NUM < 10
            10           20         AB
            21           25         AB
            12           22         PC
            23           32         PC
            33           35         PC
            22           32         LJ  -- STRT_NUM = Original STRT_NUm, END_NUM = STRT_NUM + 10
            33           42         LJ  -- STRT_NUM = Previous END_NUM + 1, END_NUM = previous END_NUM + 10  
            43           52         LJ  -- STRT_NUM = Previous END_NUM + 1, END_NUM = previous END_NUM + 10
            53           62         LJ  -- STRT_NUM = Previous END_NUM + 1, END_NUM = previous END_NUM + 10
            63           65         LJ  -- STRT_NUM = Previous END_NUM + 1, END_NUM = Original END_NUM
	View 7 Replies
    View Related
  
    
	
    	
    	
        Aug 27, 2013
        I have more than 100 records in CSV format. I have to import these records to a particular table which already contains data. I have to do a multiple update at a time, based on the condition . ie., if field1 is '1' then update field2 as 'A0001' and if field1 is '5' then update field2 as 'A0007' . The values are not in an order. Is it possible. 
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 10, 2012
        can we delete multiples table through the single query?
suppose we have 2 table first one is emp and second is client
i want delete all data from emp and client through the single line query
	View 1 Replies
    View Related
  
    
	
    	
    	
        Feb 20, 2012
        I have two tables as
Table LEAVE
Column Type Null Description
APP_NO Number(6,0) Not Null PK Leave Application Number
ECN Number(6,0) Not Null FK Employee Code Number
APP_Date Date Not Null Date of Application
From_Date Date Not Null Date from which the leave starts
TO_Date Date Not Null Date upto which the current application leave remains i.e. end of leave applied for date
NO_OF_Days Number(2,0) Not Null Difference between TO_Date and From_date
LEAVE_TYPE VARCHAR2(3) Not Null Can be one of SL, CL, LWP or LTA
Status VARCHAR2(25) Not Null Can be one of Saved, Rejected or Approved
Remark VARCHAR2(100) Nullable Reason to be put if status is rejected
[code]....
What I really want to do is that when a record is inserted in the LEAVES table (an application for leave is submitted by any employee and if it is approved) then I want to update the _USED values of the corresponding LEAVE_TYPE in the LEAVEENTITLE table which holds values of types of leaves entitled to employee.
For example if 3 rows are inserted in the LEAVES table as 
INSERT INTO LEAVES (APP_NO,ECN,FROM_DATE,TO_DATE,APP_DATE,NO_OF_DAYS,LEAVE_TYPE,STATUS,REMARK) 
(1,1234,'2012-01-01','2012-01-05','2012- 01-01',5,'SL','APPROVED',null); 
INSERT INTO LEAVES (APP_NO,ECN,FROM_DATE,TO_DATE,APP_DATE,NO_OF_DAYS,LEAVE_TYPE,STATUS,REMARK) 
(2,1235,'2012-01-01','2012-01-05','2012- 01-01',5,'CL','SAVED',null); 
INSERT INTO LEAVES (APP_NO,ECN,FROM_DATE,TO_DATE,APP_DATE,NO_OF_DAYS,LEAVE_TYPE,STATUS,REMARK) 
(3,1236,'2012-01-01','2012-01-05','2012- 01-01',5,'LTA','REJECTED','Clash with the annual meet, revise dates'); 
Then the value of SL_USED in the LEAVEENTITLE table of record corresponding to the ECN = 1234 should be updated with +5 and naturally the SL_ UNUSED value of the record should be updated as SL_ENTITLED - SL_USED. For the APP_NO 2 and 3 none of the values in LEAVEENTITLE should be updated as the STATUS is not 'APPROVED'
I tried with the following trigger, but is compiling with a warning (not showing what the warning is)
CREATE OR REPLACE TRIGGER leaveentitle 
AFTER INSERT ON LEAVES 
FOR EACH ROW
BEGIN
UPDATE LEAVEENTITLE LVE
SET LVE.SL_USED = SL_USED+(CASE
WHEN :NEW.LEAVE_TYPE = 'SL'&& NEW.STATUS='APPROVED'
THEN :NEW.NO_OF_DAYS
SL_UNUSED=SL_ENTITLED - SL_USED
ELSE 0
END),
[code]....
	View 9 Replies
    View Related
  
    
	
    	
    	
        Jan 27, 2012
        I have made a travel booking system which comprises of 3 forms
1)Travel Booking form
2)Reservation Form
3)Cancellation Form
Under one booking number i can add multiple users in which they can have there multiple travels. 
Users can cancel there individual travels under a prescribe booking number which on doing the Cancel flag turns to 'Y'.
What i want is, If a user is cancelling his/her travel under any booking number then while retriving the records in Travel Booking form, the travels which are cancelled should not be in enable mode.
For one user there can be 4 travels out of which 2 are cancelled, how can i track only those records whoes cancel flag is set to Y. some logic to find it out. Else can i use :system.cursor_record. If yes, How to use it for this system.
	View 9 Replies
    View Related
  
    
	
    	
    	
        Sep 3, 2012
        export a subset of the data only from one database to another. Both on AIX.
Source/testdatabase 11.2.0.3 (non-partitioned tables)
Target productiion database 11.2.0.3 (partioned tables)
Tables same column names but diffrenet index structures and traget one to be partitioned hence only want to import the content Each table on source datbaase hascolumn seq number and only want to extract the last few months of data.
TABLES:table1,table2...
DUMPFILE=dump_dir
CONTENT=data_only
QUERY= table1:"WHERE seq_num >100 "want to use expdp but not sure about how to ensure all tables have the WHERE seq_num >100 condition, if leave table1: out and just have
QUERY= "WHERE seq_num >100 " will this condition be applied to all tables which is what we want.
I'm assuming also can use impdp CONTENT=data_only?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Dec 1, 2009
        I have a field that may look like this:
AS01 AB CD EF
I want to check to see if that string contains any of the values in:
select code from codes_table;
For example, if 
select code from codes_table;
returns:
code
-----
AB
LM
NO
PQ
then the query should return 'True'.  Using the string above it would return 'True' because 'AB' from the string exists in the table codes_table. Pseudocode would look something like this I guess:
if the input string
contains any of the codes
in the field 'code' from table 'codes_table'
then
'OK'
otherwise
'No good!'
	View 3 Replies
    View Related
  
    
	
    	
    	
        Nov 20, 2010
        i'm trying to put more than one value in one column (by putting value '26','63' in column), so i have next problem:
1. Query select cr_pjid from acc_users where username='ACCBTPS121' give result 
CR_PJID  
---------
'26','63'
2. Query select * from acc_accbtp_nova_view where ed_id=2 and to_char(pj_id) in ('26','63'); return 186 rows. 
3. Query:  select * from acc_accbtp_nova_view where ed_id=2 and 
to_char(pj_id) in (select cr_pjid 
from acc_users 
where username='ACCBTPS121'); doesn't return any row... 
	View 8 Replies
    View Related
  
    
	
    	
    	
        Jan 10, 2013
        Most of the code is working properly except when it come to a person with more than one email type in the table:
Below is the 
select emal_pidm, emal_email_address, emal_emal_code,
case 
when emal_emal_code = 'PER'
and lag(emal_emal_code,1,'?') over (partition by emal_pidm order by emal_email_code) = 'EMPL'
then emal_email_address
[code]......         
Below is Sample data for testing 
INSERT INTO emal (emal_pidm, emal_email_address, emal_emal_code)
VALUES (1024069, 'emmaus.ferdinand@xxxx.edu','EMPL');
INSERT INTO emal (emal_pidm, emal_email_address, emal_emal_code)
VALUES (1024069, 'emfer1@xxxx.edu','PER');
[code].......
The attachment is what the output should look like.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jun 10, 2010
        I am trying to do something like this..
declare 
 a constant variable (1,2,3);
 b number;
begin
 select x
 into b
 from y
if b in a then...
What is the correct way of declaring multiple values in a constant and then using the IN clause.
	View 9 Replies
    View Related
  
    
	
    	
    	
        Jan 23, 2013
        i am using the following within queries:
decode(qt_flag,'KT','Y',decode(qt_flag,'IT','Y','N'))
It works fine but when i use in ETL tool it is not working. Is there a way to use decode just once with multiple values like above.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Oct 30, 2012
        Here is my requirement..... I am pretty new to PL/SQL.
This is the procedure
CREATE OR REPLACE PROCEDURE ABCPROC.SP_ABC
(
XML IN CLOB,
P_refcursor OUT SYS_REFCURSOR
)
AS
BEGIN
[code]........           
    
For each account number (I_AC), we have multiple rows in ABC_SVC table. I want to return these values in the refcursor.  The issue with above SQL program, the row is returning only when the account(I_AC) have values for all the products 100,101,102. If the row does not exist for one account, then the account row is returned with other products.
I want my output should be in the below format
 
ACCOUNT_NUMBER   COMMISSION  CONSUL  CONTRA
1YYN
2NN
3N
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 13, 2011
        I have used sql for my school projects and work projects. not too extensively though. I came across this issue and read a lot of blogs but still not luck. 
hopefully my issue can be solved here.
Data:
Sub_grp_nbr     Prodt_ctgy_cd     Extra_column
ABC123          05                1
ABC123          02                2
ABC012          05                3
ABC456          02                4 
ABC456          05                5
ABC789          05                6
I need to obtain all the sub_grp_nbr's that have a prodt_ctgy_cd of 05 but not 02. so according to the data above, i should only get the results of where extra_column = 3 and 6
	View 7 Replies
    View Related
  
    
	
    	
    	
        Jun 12, 2013
        I have a source view where I have some invalid records and those should be found based on codes present in another table.
For eg. from source the records come like 
****************SIINNSFDFD****FDFDF2******8
**********TABLE****************FDFSFSSFASFAS********
and if my reference table has values
SIINNSFDFD
TABLE
then these values are present as substring in the particular column in the source view. So I need to flag those records. For every record, I need to check whether all the values present in the reference table matches or not. If it matches then it should be flagged.
I can use in operator as we are not checking for the exact match and we are checking whether that value is present anywhere in that column record.
Looping results in performance issue. We can use PL/SQL for this. As the source view is put into a ETL internal file.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 21, 2012
        For the below query:
SELECT  id, pob,exp
FROM emp
where exp= (:exp)or @exp is null
O/P:
id       pob      exp
_____________________
1        CT        2
2        NJ        3
3        NY        2
It takes only one value of :exp but, I would like to give multiple values separated by ','. My problem is the parameter can be either single value or Blank or multiple values. My code do work for single value and Blank, Now how to implement multiple values .
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 16, 2011
        I have a table as follows
create table teststr (indname varchar2(20),
counter1 number,counter2 number,counter3 number,counter4 number);
insert into teststr values('a',10,20,30,30);
insert into teststr values('b',10,20,5,3);
insert into teststr values('c',2,4,5,2);
insert into teststr values('d',1,2,3,4);
insert into teststr values('e',4,5,4,4);
Now i need the output if any of the column values are same.
output should be
select indname from teststr where counter1=counter2 
or counter1=counter3 or counter1=counter4 
or counter2=counter3 or counter2=counter4 
or counter3=counter4
a
c
e
Is ther any other way to write the query instead of the numerous or conditions if i want to compare the column values in a table.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 28, 2010
        I want multiple values from a function. I want to use this function in a SQL query. Here i'm giving my try.
SQL> CREATE TABLE TEMP
  2  (
  3    ID        NUMBER(1),
  4    SAMPTYPE  VARCHAR2(20 BYTE),
  5    SALARY    NUMBER(10)
  6  )
  7  /
Table created. 
SQL> INSERT INTO TEMP VALUES(1,'ABC',10000);
1 row created.
SQL> INSERT INTO TEMP VALUES(2,'PQR',20000);
1 row created.
SQL> INSERT INTO TEMP VALUES(3,'JPD',5000);
1 row created.
SQL> COMMIT;
Commit complete.
[code]...
Here i get result as ABC*10000, but i want two separate values as ABC,10000. how can i do this via function.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 24, 2010
        with t as
( select 1 id, 101 book_id, 'MICROBIOLOGY' book_type, 1 category, 'sCIENCE AND TECH' category_name
   from dual
   union all
  select 1 , 101 , 'MICROBIOLOGY', 2 , 'HEALTHCARE' from dual
   union all
[Code]....
id     book_id      BOOK_TYPE        category   category_name
         
1       101        MICROBIOLOGY         1      SCIENCE AND TECH
1       101        MICROBIOLOGY         2      HEALTHCARE
1       102        CHEMISTRY            5      CHEMICAL ENGINEERING                         
2       105        COMP SC              1      SCIENCE AND TECH 
The above is the output for a query after joining multiple tables. I have just put here the output I am getting after joining the tables.Now I want to achieve the below result.
Expected output: it should be | delimited
1|101|MICROBIOLOGY|102|CHEMISTRY|1|sCIENCE AND TECH|2|HEALTHCARE
2|105|COMP SC|1|SCIENCE AND TECH  
Is there any alternative way other than SYS_CONNECT_BY_PATH? I also tried to use CONCAT_ALL but its not working.
	View 13 Replies
    View Related
  
    
	
    	
    	
        Aug 26, 2011
        I have a problem with some tables in database.
Table has three columns: userid, pname, pvalue.
Userid has unique values, for example: 234, 123, 587, etc.
In the field pname, there is three possible values: MAC, IP, S/N.
So if I go like this:
select pvalue
from table
where pname = 'MAC';
i get the values of MAC.
If I go like this:
select pvalue
from table
where pname = 'IP';
i get the values of IP.How can I join MAC with IP that is matching this MAC? I need an SQL statement for this. 
	View 11 Replies
    View Related
  
    
	
    	
    	
        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
  
    
	
    	
    	
        Jun 1, 2010
        How to hold the multiple rows values using array? And I have to pass this values to some other procedure.
Ex: SQL> select ename from emp;
   
ENAME
 ----------------------
Vetrivel
Dr.Venkat
Vinoth
Sudhakar
Sivaganesh
Senthil           
	View 7 Replies
    View Related
  
    
	
    	
    	
        Apr 6, 2011
        Using pl/sql block , i tried to have a certain input values from Sql prompt but it doesn't work when i invoke it.
Here the simplest 
declare
a number(4);
begin
for i in 1..10 loop
a := &a;
end loop;
end;
/
	View 9 Replies
    View Related
  
    
	
    	
    	
        Nov 21, 2011
        I'm trying to select id's in a table that have 2 certain values for another column. Example below explains:
idCoupon Type
123Amount
123Percent
456Amount
789Percent
I would like to write a sql statement that would select all rows where id=123, because id 123 has both coupon types "Amount" and "Percent". So the result set of the sql statement would look like:
idCoupon Type
123Amount
123Percent
	View 6 Replies
    View Related
  
    
	
    	
    	
        Jun 22, 2010
        I have a function that returns the total sum of an account. From reports I call the function passing the account code. The function sums the values for that specific account code and returns the value. In my function I have the following code :  
where account_code = P_CODE.  
Eg. The value of :P_CODE is 'CS'.
 
I now want to pass multiple account codes ('CS','TV',LJ') to the function. How do I change the IN clause in the function to accommodate multiple values. 
I have tried using the instr function, but it does not work. eg. AND instr(o.ACCOUNT_CODES,','||P_CODE||',') > 0 
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 31, 2012
        assigning values to a particular variable that i need for my button trigger. I Understand that you can assign multiple values to a variable that has a varchar or char data type....is there a way  to assign multiple values to a variable that has a 'number' data type?? I need this for my 'where' clause
declare
usergrade varchar(4) := 'pass';
user_unitcode number(6) := ;--needs three unit codes to equal pass
	View 1 Replies
    View Related