SQL & PL/SQL :: Separated Result With Multiple Values
			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
  
    
	ADVERTISEMENT
    	
    	
        Oct 19, 2012
        Create table a ( Objectid number, Value varchar2(2000);
/
Insert into a values (12, '2,3,4');
Insert into a values (13, '8,7,4');
Insert into a values (14, '3,8,9');
Insert into a values (15, '6,3,11');
I should get the output as:
 ID     Value
------  ------
12       2
12       3
12       4
13       8
13       7
13       4    
14       3
14       8
14       9
15       6
15       3
15       11
	View 6 Replies
    View Related
  
    
	
    	
    	
        Jul 2, 2008
        Here is what i have in ms-sql, how to convert this into t-sql ?
@MortgagePurposeID is parameter with comma seperated values ('1,2,3,4')
if(substring(@MortgagePurposeID, LEN(@MortgagePurposeID)-1,1)<>'','')
Set @MortgagePurposeID = @MortgagePurposeID + '','' 
Set @pos=0
[Code].....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 1, 2012
        I have input like below
ID | Name 
-------------- 
1 | ABC, BCA, AAA, BBB (all in one column)
2 | ABC,DBA
and I want to get concatenated values separated
ID | Name 
-------------- 
1 | ABC 
1 | BCA 
1 | AAA 
1 | BBB 
2 | ABC
2 | DBA 
	View 17 Replies
    View Related
  
    
	
    	
    	
        Jun 22, 2010
        I am posting the table and data, i just want to display the columns values separated by ','.
SQL> create table t(c1 varchar2(10),
  2  c2 varchar2(10),
  3  c3 varchar2(10),
  4  c4 varchar2(10));
Table created.
SQL> insert into t values ('A','B','C',null);
1 row created.
SQL> insert into t values ('A','B',null,'D');
1 row created.
SQL> insert into t values ('A',null,'C','D');
1 row created.
[code]....
But it giving extra comma in 1,5,8 rows.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Oct 30, 2012
        I would like get rows into comma separated values expected output
rowvalue1,<space>rowvalue2,<space>rowvalue3,<space>rowvalue4,.....Example:
create table test1 (name1 varchar2(10));
insert into test1 values ('JOHN');
insert into test1 values ('YING');
insert into test1 values ('KAREN');
insert into test1 values ('PEDRO');
commit;
SQL> select * from test1;
NAME1
----------
JOHN
YING
KAREN
PEDROHow can I get this to printed as 
JOHN, YING, KAREN, PEDRO
	View 3 Replies
    View Related
  
    
	
    	
    	
        Dec 12, 2011
        I am building a search for use in one of our major applications. I have written a PL/SQL package that deals with it.  I would like to present the requirement list to the group and see what, if anything, you may have done differently than I have. 
 
1.) The search interface must have a single box, like google. 
2.) Multiple search terms will be separated by a comma.
3.) The table has the following columns: 
-- Name
-- Title
-- addr
-- addr2
-- city
-- state
-- zip
-- phone
-- email
4.) Number of Search Terms per query will be unlimited.  (for now, as practicality dictates)
5.) Each search term will be checked against various columns.
6.) Search terms must not have a preference in order.  Name, Address = Address, Name 
7.) Records will be returned only for the rows where all search terms are found.
	View 3 Replies
    View Related
  
    
	
    	
    	
        May 21, 2012
        I have a requirement wherein I need to enforce certain column to have only comma as a delimiter, where multiple values exists.
Example:
Create table:
create table test_oz ( slot number, server_name varchar2(50), used_by varchar2(50), 
constraint test_oz_pk primary key (slot, server_name)  );
Insert Test Data:
insert into test_oz values ( 1,'SRV1','SAMMY' );
insert into test_oz values ( 2,'SRV1','SAMMY,TOM' );
commit;
Data:
SQL> select * from test_oz;
SLOT SERVER_NAM USED_BY
---------- ---------- ----------
1 SRV1       SAMMY
2 SRV1       SAMMY,TOM
From above, the USED_BY column data need to be only comma separated. Is there a way to enforce that?
When user tries to insert data using any other delimiter, it should fail.
I was trying to see if a CHECK CONSTRAINT could be of use, but could not find it to work.
	View 3 Replies
    View Related
  
    
	
    	
    	
        May 23, 2012
        I need to write a function which will take table name as input and should return all the columns separated by coma (,).
For example I have a table product as 
PROD_ID PROD_NAME        FAMILY_ID
------------------------------------
100006Acetaminophen100005
100013Simvastatin100007
100014Ezetimibe100008
100015Simvastatin+Ezetimibe Oral Family100009
100003Abacavir100003
100007Amlodipine100006
100001Cetirizine HCl Oral Solution100001
My function should return the output as
100006,Acetaminophen,100005
100013,Simvastatin,100007
100014,Ezetimibe,100008
100015,Simvastatin+Ezetimibe Oral Family,100009
100003,Abacavir,100003
100007,Amlodipine,100006
100001,Cetirizine HCl Oral Solution,100001
Is there any inbuilt function available?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Apr 24, 2013
        I have the following query : for :P_LEG_NUM Parameter when i am passing values like 1,2,5 as string type i am getting invalid number error... I have defined in clause for it but still it does not work.. For individual values like 2, etc it works... how can i pass comma separated values for this bind variable
select trip_number as prl_trip_number,
flight_number as prl_f_number,
trip_leg_id as prl_trip_leg_id,
leg_number as prl_leg_num,
dicao as prl_dicao,
[code]........      
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 12, 2010
        I have a string like this .
'ABC-XYZ-MNO'
and i want the data in the below format
'ABC','XYZ','MNO'
	View 14 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
  
    
	
    	
    	
        Nov 7, 2011
        I have a table with 4 columns. The data is stored in an hierarchical format where L1 being the parent and L4 being the lowest child.
L1  L2   L3   L4
1   11  111  1111
2   21  211  2111
2   22  222  2222
[code]...
So each Level(L1 ..L4) has zero or many child levels which further has more levels.With out using PL/SQL how can we write a Select query to give me a distinct of all children, all the way to the lowest level (L4).Example: give me all the children where L1 = 3.Result: 31, 32, 33, 311, 322, 333, 3111, 3222, 3333Is it possible to write such a query or am I asking too much logic out of a select and should go with PL/SQL.
	View 12 Replies
    View Related
  
    
	
    	
    	
        Nov 8, 2012
        I have two tables A and B.
A
--
variable      value
--------     ------
a              10
b              20
B
--
Exp
---
b-a
b*a
b/a
How can the variables be replaced with values(10,20) using a single query...?
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 6, 2010
        i am doing a data transformation using the following function
FLOOR(ONSET_TPQ-VAX_DATE)
Where ONSET_TPQ and VAX_DATE are both dates. Now in a situation where the ONSET_TPQ precedes VAX_DATE I want the result to be null for those records. As an example if ONSET_TPQ= 2000 and VAX_DATE=2010
I want the result to be NULL as I dont want negative values. Any exact SQl syntax on how to do that. DO i write a case statement?
	View 6 Replies
    View Related
  
    
	
    	
    	
        Mar 26, 2013
        OK, Now that the syntax has been corrected with  "Chanchal Wankhade" I have an entirely new issue. I am sure this issue has to do with my case statement logic. I am getting multiple rows, when I am only looking for one. Here is my code:
SELECT 
  CASE
    WHEN EP.PHYSICAL_DATE IS NULL
    THEN
      CASE
        WHEN EC.ORIGINAL_CONTRACT_START < ((SYSDATE) - 365)
        THEN 'NEEDS PHYSICAL'
 [code].....     
However, only one of these rows should be the output, which is "No". How do you get a nested case statement to evaluate to one result, instead of multiple? I'm quite sure it is in the logic. To spell it out, this is what I am trying to accomplish with the above code: If the "EP.PHYSICAL_DATE" is null, then use these sets of formula's to evaluate the output, BUT if the "EP.PHYSICAL_DATE" is not null, then use these set's of formula's to evaluate the output.
As it stands now, it appears as if my nested case statement is doing exactly what I told it to do, which is to evaluate both conditions, and output both. 
	View 0 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
  
    
	
    	
    	
        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
    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 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