SQL & PL/SQL :: Splitting One Row To Multiple?
			Oct 9, 2012
				I have a table Product as;
desc product
Name                    Null              Type                             
-------------------------------------------------------------- 
PRODUCT_ID            NOT NULL            NUMBER                             
INGREDIENT                              VARCHAR2(20)
The data in Ingredient is separated by ','.
PRODUCT_ID             INGREDIENT           
---------------------- -------------------- 
1                      A,B,C                
2                      A,D                  
3                      E,F                  
I need to write a sql statement which will retrieve a pair of product and ingredient in each row as;
PRODUCT_ID             INGREDIENT           
---------------------- -------------------- 
1                      A                
1                      B
1                      B
2                      A  
2                      D                
3                      E  
3                      F
 write this sql ?
	
	View 1 Replies
  
    
	ADVERTISEMENT
    	
    	
        Feb 18, 2013
        I need  to split the given string into muliple sub strings based  on one special character  
Ex :  Speace  is Special character 
with  data as (
select 'ab cd ef gh ' from dual )  
select  *  from  data 
Required Output  : 
ab
cd
ef
gh 
	View 3 Replies
    View Related
  
    
	
    	
    	
        May 8, 2010
        Table Name : Trans
chitta_enn        number(10,0)
varavu_patti      varchar2(100)
pattru_patti      varchar2(100)
Thogai            number(10,2)
where in the data's are as follows
chitta_enn    varavu_patti  pattru_patti     Thogai
101           panam         null             101.00
101           null          sambalam         51.00
101           null          kamishan         50.00
I need to create the view as follows
View Name : Pattiyal
vivaram       varchar2(2000)
varavu        number(10,2)
pattru        number(10,2)
The view data should get display as follows
vivaram               varavu        pattru        
sambalam kamishan      null         101.00      
panam kamishan         51.00         null
panam sambalam         50.00         null
Logic:
Each table row will have only one value either in varavu_patti or in pattru_patti. On selecting the row, thogai must be posted in varavu when varavu_patti is not null or should be posted in pattru when pattru_patti is not posted.on selecting the table row, vivaram should contain all other rows varavu_patti and pattru_patti on equating chitta_enn
 
Is it possible to create a view as above
	View 1 Replies
    View Related
  
    
	
    	
    	
        Oct 20, 2010
        I have a table which has a column that stored concatenated data. 
Sample test case is as below:
SQL> create table tst (
  2   col1 varchar2(20));
SQL> insert into tst values  ('one,two,three');
1 row created.
SQL> commit;
Commit complete.
Is there any way i could write a sql to split the text of this column into rows? Sample output im expecting is as below
col1
-------
one
two
three
	View 13 Replies
    View Related
  
    
	
    	
    	
        Sep 14, 2012
        I need to join ISSUED_REMOVED Table with ITL Table. having each quantity each row. 
Eg. If a unit Serial no '354879019900009' has a part (1015268) issued 8 times and then unissued 4 times so finally the part was issued 4 times. so I need 4 rows to show for each qty 1 for that part and unit serial number. 
-- ITL Table
Create table ITL_TEST (
ITEM_SERIAL_NO, ITEM_BCN, ITEM_ID, ITEM_PART_NO, OPER_ID, 
ISSUED_REMOVED_PARTNO, ISSUED_REMOVED_QUANTITY, QUANTITY, SHIPMENT_ID)
[code]....
-- Issued Removed table
create table ISSUED_REMOVED_ITEM
(REPAIRED_ITEM_ID, ISSUED_REMOVED_ITEM_ID, ISSUED_PART_ID, OPER_ID, ISSUED_REMOVED_QUANTITY)
as select 
122013187, 1323938, 1015268, 308, 2 from dual union all select
122013187, 1323939, 1015269, 308, 2 from dual union all select
122013187, 1323940, 1015268, 308, 2 from dual union all select
[code]....
-- The way I need to join the Issued_Removed Table
select * from ITL_TEST ITL 
left join 
issued_removed_item iri
on iri.REPAIRED_ITEM_ID = ITL.ITEM_ID --ITL.ITEM_ID --rlsn2.item_id --126357561 
and iri.oper_id = 308 --in ( 308, 309)
[code]....
	View 1 Replies
    View Related
  
    
	
    	
    	
        Apr 22, 2013
        I see that I can use SDO_LRS.SPLIT_GEOM_SEGMENT to split a line at a single point (and get 2 resulting lines).
However, how I could split a line, at multiple points, into multiple segments? I need to do this for many rows, therefore a function or procedure would be good if any exists.
	View 13 Replies
    View Related
  
    
	
    	
    	
        Jul 31, 2012
        I need to split a column into multiple columns. The data in my column is separated by a Comma (,). But the data is dynamic and I could have any number of data separated by (,).
Quote:FOR Ex:
If COL1 contains 
CRITERIA_ITEM_TYPE_ID, CRITERIA_ITEM_TYPE, DESCRIPTION, ITEM_DATA_TYPE
RESULT: should be 4 columns contains the values
CRITERIA_ITEM_TYPE_ID and CRITERIA_ITEM_TYPE and DESCRIPTION and ITEM_DATA_TYPE
Is COL1 contains
CRITERIA_ITEM_TYPE_ID, CRITERIA_ITEM_TYPE, DESCRIPTION
RESULT:
should be 3 columns contains the values
CRITERIA_ITEM_TYPE_ID and CRITERIA_ITEM_TYPE and DESCRIPTION
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 24, 2012
        How block splitting will happen in oracle block.
Suppose, I am having Oracle BLOCK_SIZE of 16k and my Linux OS level BLOCK SIZE is 4k. then How 16k oracle block will store in OS level? and 
What will be the internal block splitting process?
	View 10 Replies
    View Related
  
    
	
    	
    	
        Feb 19, 2008
        I was wondering if there is an Oracle function available to split a string based on a delimiter character.  For example, if I have a table consisting of:
HOST
-----
emerald.test.com
ruby.test.com
diamond.test.com
I would like to only return ('emerald', 'ruby', 'diamond') by getting all data leading up to the first '.' character.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Sep 20, 2012
        I need to dump the contents of a very large table into text files for archiving as we retire this old DB.  The table has about 16 million rows, and a few of the columns are up to 4000 characters wide (varchar2(40000)).  I've got 2 problems:
1) How can I select records that occur in a certain month of a year (there is a date column) and put the selected records into a file?
2) I don't have access to the server OS, so UTL_FILE is not possible.  The output is also so large that I'm having trouble with the DBMS_OUTPUT.PUT_LINE.  
 I'm trying to get the first block of the IF working first, so the rest is just placeholders.  
DECLARE
  v_mm number (2);
  v_yyyy number (4);
  min_mm number (2);
  min_yyyy number (4);
  max_mm number (2);
  max_yyyy number (4);
  min_date date;
[code]....  
	View 12 Replies
    View Related
  
    
	
    	
    	
        Mar 26, 2010
        Aim: Architecture change in existing application
Domain: Health Care
Background: There are 2 application ( Front end: one in oracle forms - deals with accounts module and another in some legacy application - deals with patient, clinical and diagnose module) using and sharing the same Oracle 9i database.
Patient related modules are moved into another database ( java as a front end, oracle 10g as backend ) which is normalized - eliminating duplicate tables and column, also its tables and columns names are not matching with existing (patient)system.
Now the requirement is making the existing application related only to Accounts module ( having complicated business logic written in packages )  to work as it is without changing the code, design drastically.
Questions:
1. Now how best this task can be completed without affecting existing Accounts system drastically ( with minimal changes )?
2. what are the possible best approach to achieve this ?
3. what are the best way for communicating the 2 DB in this scenario ( may be creating synonym, views etc ) ?
4. What are challenges that needs to be addressed ?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Feb 28, 2013
        I have string like 'PRASAD,ALLEN,STEWART,SMITH'.
LIKE
COL1    COL2    COL3      COL4
-------------------------------
PRASAD ALLEN    STEWART   SMITH
I want to store the data into columns using SELECT statement only 
	View 7 Replies
    View Related
  
    
	
    	
    	
        May 14, 2013
        11.2.0.3...just trying to learn the syntax. I have not worked with IOTs and I am exploring a feature I have not really used to try to learn something new. I know about intervals.This exact split syntax below, works on a heap table without errors. When I run the following split against a regular heap table it works. 
CREATE TABLE MYTABLE (
INSERT_DATE date,
myfield1 varchar2(50),
myfield2 varchar2(50),
myfield3 varchar2(50),
[code]....
alter table MYTABLE split partition "FUTURE" at ( to_date('09_MAY_2013_13','DD_MON_YYYY_HH24' ) ) into ( partition "B4_09_MAY_2013_13", partition "FUTURE" ) update global indexes
               *
ERROR at line 1: ORA-00932: inconsistent datatypes: expected BINARY got NUMBER
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 8, 2013
        splitting a table partition without making its primary key index ar any other indexes unusable.
I think it is possible to do so 10g onwards.
DB Details:
Oracle RDBMS 11.2.0.3, HP-Ux B.11.31, OLTP
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 25, 2013
        Currently I have a requirement where I need to create 2 more output rows using each result row.
In my requirement I am populating charges table with types of charges, on each line item of charges, I need to apply 2 types of taxes and populate it along with the charge line item. I will be storing charges in table charges and the 2 taxes to be applied in taxes table respectively. For each row of charges, i need to apply these 2 taxes present in taxes table resulting in 3 rows output.
--Create tables charges 
create table charges
(
charge_type varchar2(10) ,
charge number
);
[Code]....
My expected output should be like below:
 
Item_type            amount          
-------------------- ---------- 
charge1               100       
Charge1_tax1          10        
Charge1_tax2          20        
charge2               200       
Charge2_tax1          20        
Charge2_tax2          40        
how I can achieve the expected output using a single sql query
	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 16, 2011
        can we have multiple database version running in a single machine with multiple instances provided there are enough resources.Can we do in RAC only?
	View 15 Replies
    View Related
  
    
	
    	
    	
        Jan 2, 2013
        how to insert the data in multiple bases( Same table structure in different bases) using the multiple database links? 
	View 4 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
  
    
	
    	
    	
        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
  
    
	
    	
    	
        May 6, 2013
        I have a table TableA containing 2 columns ( Name and Value). Here I know what are the values for column Name
TABLEA
=======
Name Parameter
-------------------------
Nexus 11
GPlay 21
Demo 31
I need a query which provides the below output
Desired Output:
======
First Second Third
11 21 31
I have tried the below query
SELECT 
DECODE (name,'Nexus', parameter) First,
DECODE (name, 'GPlay', parameter) Second,
DECODE (name, 'Demo', parameter) Third
FROM (SELECT name, parameter FROM TableA where name in ('Nexus','GPlay','Demo'));
This gives me the output
First Second Third
11 <Empty> <empty>
<empty> 21 <empty?>
<empty?> <empty?> 31
Is there any way to get the output in single line.
	View 3 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
  
    
	
    	
    	
        Jun 5, 2010
        I have a database which shows the amount of labor done on a part and the columns I am retrieving from the database are as follows:
PART....... WORK_ORDER..... STEP.... OPERATION...... GOOD_PARTS
There are multiple parts in the database, each with multiple work orders, with multiple steps but each step only has 1 operation but each operation has multiple good_part entries.
What I need from this is to sum the sum of all good_parts for the last step of each work order but only if it is a certain operation for each part.
So say i have this data:
PART..... WORK_ORDER..... STEP..... OPERATION.... GOOD_PARTS
XYZ... .... .... 1.. ... .. ... ... 1.. .. .. .. GRIND.. .. . .. . . 50
XYZ... .... .... 1.. ... .. ... ... 1.. .. .. .. POLISH.. .. . .. .. 45
XYZ.. . ... ... .. 2 . . . .. .... .. .1.. .. ... ...GRIND. .. ... ... .. 40
XYZ. . .. .... ... 2 . .. . .. . ... . 2. . .. . ... POLISH .... .... ....45
XYZ... .. .... ... 2. ..... .... ... . 2... .... .... POLISH .. ... ... ... 5
XYZ . ..... ... .. 3.. ... .. .... ... .1. .. .... ... GRIND. .... ... .. . 40
XYZ. ... ... .. .. 3. .. .. .. .. ... . 2. .. ... ... POLISH. .. ... ... .. 45
XYZ. ... .... .. .. 3. .. .. ..... ... 3 . .. .. .. . SHIP. . .. .. .. .. .. 45
(This is the result of a bunch of joins and filters but it is essentially a SELECT * with the clause "ORDER BY PART, WORK_ORDER, STEP" to sort it correctly.)
And I want only the parts for "POLISH" i want to have the final sum of 95 because work order 1 has the last entry of "POLISH" with 45 parts; work order 2 has 2 entries of "POLISH" (which is the last step done) with a sum of 50; but work order 3 has the last operation "SHIP" so I don't include it at all.
I have previously pulled all this data into excel and ran a macro to calculate it but now I find that I need it to be calculated by the server. This database is Oracle, so I can use any functions it supports. I saw the function LAST_VALUE that might be useful.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 9, 2013
        We have Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bit  RAC in Linux and syslog server also in Linux.
syslog server is a centralize server to monitor all the system and database log.
is there any way to create a multiple alert log file. so that  we can keep one alert log file in default location and another alert log file in centralize syslog server for monitoring purpose.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Nov 23, 2010
        We are getting a consultant to upgrade an Oracle 9i installation to 11g R2.  The current installation has 6 different databases installed on the same server.  Each database is a different customer so for reasons of security we have requested that this be split into 6 virtual machines with one database per machine.
The consultant suggested that they could install the 11g database once and then just make copies (which would all have the same instance name.  We are told that the TNS names can be configured  so clients are directed to the right database.  
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 10, 2013
        Is there any function which return the next multiples of 10 value directly  ?
Ex  : input  - 11 then it should return 20 
               156          -           160 
               299          -            300
               43           -            50 
	View 18 Replies
    View Related
  
    
	
    	
    	
        Feb 21, 2010
        I'm trying to do a sum over 2 different tables but can't get it to work...This is the idea:I have a table A with client ID, time-id (per day), purchase amount and segment code. 
In another table (let call it B) I have a lot of client ID's and also their purchase amount, time-id and segment code. I want to sum the purchase amount for every client from table A and B for clients with certain segment code from table B. 
This is what I have now:
select client_id, purchase_amountA+ purchase_amountB from tableA, tableB where
A.client_id = B.client_id
and time_id between 20090101 and 20091001
and B.segment_code = 'A'
This does the job, but it selects only client_id's which are in both tables. I want to select all client_id from table B with segment_code 'A' and add the purchase_amount from table A to their purchase amount from table B, at least, if they have any purchase amount in table A.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Apr 10, 2011
        tried searching google and this site too, found postings on WM_CONCAT, STRAGG, concat_all, LISTAGG functions by Michel and have experimented with these, but either the syntax is giving me a hard time or i just have not got the concept down.
Trying to get 2 rows into one. Have provided the create statements and insert of data. Also below will show what is returned with a Select i have and what is ideally required.
CREATE TABLE Person_Lang
(
    Person_ID            NUMBER        NOT NULL,
    Language_ID          NUMBER        NOT NULL,
    Contact_Name         VARCHAR2(255 CHAR),
    Main_Phone           VARCHAR2(255 CHAR),
    Secondary_Phone      VARCHAR2(255 CHAR),
[Code]...
Data Returned from Select is:
1 46 905-231-3319 22 Street11 Apt402 Brantford
1 46 905-231-3319 23 Street12 Apt315 MainTown
Ideally what is required back is:
1 46 905-231-3319 22 Street11 Apt402 Brantford 23 Street12 Apt315 MainTown
	View 7 Replies
    View Related
  
    
	
    	
    	
        Sep 30, 2010
        Video Rental Shop 
Each customer has a video card , When Customer rent a CD , Shopkeeper register an issue date and a Return Date . If customer return CD  after Return Date Then There will be a fine of 2 Dollor . 
After every 6 Months The shop Keeper review each customer Account , and Send Gifts to those customer whose Total Amount is More than 50 Dollar .and also send letters to those whose Fines Are More than 20 Dollor  .
Now I am unable to understand that how many table i need to create for this  .
What i have created so far is given below , 
When Customer Rent a CD then Shopkeeper will submit Following Information .
Customer_id 101
Issue DateDATE  
Expected_return_dateDATE
Original_return_date-
Fine  -
Total_Amount -
And at the time of return , he will Put these information . 
Customer_id 101
Issue DateDATE  
Expected_return_dateDATE
Original_return_date            DATE
Fine  2
Total_Amount5 
But Do i need to create another table for each customer also ?  That will store customer total amount , total Fines ,and shopkeeper will view it after every six months. Which type oo table i need to create ?
	View 18 Replies
    View Related
  
    
	
    	
    	
        Apr 22, 2010
        Client managerCont. Start DateCont. End Date
abcman11-Jan-0830-Jun-08
abcman21-Jul-0831-Dec-08
abcman11-Jan-0930-Jun-09
abcman11-Jul-0931-Dec-09
abcman21-Jan-1031-Mar-10
abcman21-Apr-1031-Aug-10
I need to code a SQL statement (Not PL/SQL) to display following records:
Client managerCont. Start DateCont. End Date
abcman11-Jan-0830-Jun-08
abcman21-Jul-0831-Dec-08
abcman11-Jan-0931-Dec-09
abcman21-Jan-1031-Aug-10
	View 4 Replies
    View Related