PL/SQL :: Match Condition - Add Additional Column Indicator
			Jan 9, 2013
				I would like add an additional column to the data below:
create table test(
id number
cust_num varchar2(5));
[Code]....
Result:
001, AODER, 'Y'
001, BODER, 'Y'
001, CODER, 'Y'
001, DODER, 'Y'
001, 'NONE', 'Y'
001, 'NONE', 'Y'
[Code]...
I would like to add an additional column indicator (Y or N) to specify which ID's do not contain all records of 'NONE'. There can be an occurrence of 'NONE' as long as there is another cust_num different to 'NONE' These should be marked as 'Y' but in cases where all the ID's cust_num = 'NONE' only then these should be marked as 'N'.
	
	View 5 Replies
  
    
	ADVERTISEMENT
    	
    	
        Dec 28, 2011
        I have a problem with a query I'm trying to run. I need to match two columns containing names, first column (NAME1) contains only the surname and the second column (NAME2) contains a surname and initials, with the initials turning up on either side of the surname.
Example:
NAME1: 'Bush', 'Thomas', 'Cook', 'Smith'
NAME2: 'Bush, B.B.', 'Thomas,C.' 'Cook', 'A.A. Smith'
Basically the code I'm trying only turns up complete matches and not partials. what I'm doing wrong or how I can improve it?
CODEselect *
from TEST
where NAME1 like ('%'||NAME2||'%');
	View 4 Replies
    View Related
  
    
	
    	
    	
        Aug 25, 2011
        set the current record indicator for my tabular data block.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jun 1, 2010
        If doing an insert into DATE type fields like below... how do I employ null indicator values with the TO_DATE sql to cope with NULL values for the End Date?  I can test the NULLness of the pServiceRecord->itemTo value and set the indicator ind_dbToDate to -1 but I don't know how to incorporate this with the to_date syntax (if I can)?
EXEC SQL BEGIN DECLARE SECTION;
    char    dbFromDate[MAX_DATE_LEN];
    char    dbToDate[MAX_DATE_LEN];
    short   ind_dbToDate;
[code]...
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 8, 2012
        create table ptab(pid number);
create table ctab(aphone varchar2(20));
drop table ctable
create table xtab(pid number,phone varchar2(20), tel1 varchar2(20), tel2 varchar2(20), tel3 varchar2(20))
 
insert into ptab values(1);
insert into ptab values(2); 
insert into ptab values(3); 
insert into ptab values(4);
[code]..
i have 3 tables, xtab, ctab and ptab
join condition
ptab.pid = xtab.pid
and
--------------------------------------------------------------------------------
 
what I want the join between xtab and ctab is, aphone should match with phone, and then tel1, then tel2, and then tel3, (if phone, tel1, tel2, tel3 are not null in that order only), if aphone matches with any of these,then just print that particular pid, important point is, aphone should be checked against phone, tel1, tel2, tel3 that order only
so the results should simply print 
pid
1
2
3
4
5 should not be printed here because for pid 5 in xtab, none of the phone numbers match with aphone of ctab 
I tried this:
select 
DECODE (ctab.aphone,
                               xtab.phone, 1,
                               xtab.tel1, 1,
                               xtab.tel2, 1,
           
[code]...
but i cannot join ctab and ptab,  i dont want to use intersect etc, because we are looking at millions of rows here
	View 3 Replies
    View Related
  
    
	
    	
    	
        Oct 20, 2010
        I have a column transaction Number . It has the transaction number of goods sold.. Below is the sample.
1. PIT0120029015554492215851181828221018554492R06
2. XY1029201195J05
3. YJ1039201176J01
My Query :
I need to substr the transaction number which starts with PIT to susbst (trxno,1,12) .. and anything other than PIT i need full number without substr . But when i use the above code :" susbstr(trxno,1,12) ..": it will substr entire column,. Is there any way to substr only PIT and leave others,
DB:oracle 10g
	View 7 Replies
    View Related
  
    
	
    	
    	
        Oct 5, 2010
        Now am on a need to take sum of data from one table but three different condition with three column.I give example Lets consider I have a table called Sales in which it has three columns 
1.Dept
2.sales_amt
3.status
There are 3 different flag for status A,B & C.I want display data in  the following format in five columns.
Dept   Status_A   Status_B  Status_C 
1        30           50        20
1        10           60        30
       
 total   40           110       50  
But data is stored in the table in rows like
1    30      A
1    50      B
1    20      C like all rows.
For this I wrote union operation and sum.Am 
creating a view for this with there columns dept,Sales_A,Sales_B & Sales C for sum of data.My view is 
select dept,Sum(sales_amt),0,0 from sales where status='A' group by dept union
select dept,0,sum(sales_amt),0 from sales where status='B' group by dept union
select dept,0,0,sum(sales_amt) from sales where status='C' group by dept
Am assigning 0 for other two status of data because i want the data to be displayed on different columns based on row level condition.The view will return data like 
Dept Sales_A  Sales_B   Sales_C
1    30        0          0
1    10        0          0
1     0        50         0
1    0         60         0
1    0         0          20
1    0         0          30
So finally am using sum function again and selection total sum of value for each status from this view.So by using union operation how can i display data from different condition of data into seperate columns.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Aug 10, 2011
        I need to select the value of a column into different variables depending on the condition.
As in, I have 
FILE_TYPE_CODERETENTION_DAYS
CLR           5
SIZ           6
UOM           7
ADB           8
I need to get the Rention days into the 4 variables v_color_file_type_code, v_size_file_type_code, v_buyer_file_type_code AND  v_uom_file_type_code Depending whether the FILE_TYPE_CODE is 'CLR' or 'SIZ' or 'ADB' or 'UOM'
	View 3 Replies
    View Related
  
    
	
    	
    	
        Feb 5, 2013
        while replicating form mssql 2005 it is entering space for null in oracle clob col.so i wanted to know.
1)can check constaint modify the content of column on which it is defined?
like i want to enter null in a column , if entered date is greater than current date else the entered date.i do not want to use triggers or client side script.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Apr 18, 2012
        Recently I am facing a problem while working with Oracle reports 2.5.
My requirement is: 
there is a report in which there are 5 columns right now. Now what i want is, whenever a condition will satisfy , a new column should be also display in that report otherwise it must be stay as it is. 
Previously : a b c d 
Now if a=1 : a b z c d
else
a b c d
where a,b,c,d,z are columns.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 6, 2012
        I want to find role dependency on another role. 
1. If its a basic role (made of priviliges), what data dictionary view I should query?
2. If the role is made of some other role and additional priviliges, what query I should fire to find that?
3. Role is granted to which users?
	View 15 Replies
    View Related
  
    
	
    	
    	
        Oct 4, 2013
        I have an procedure with four in parameters in it. Now, I want to add an out parameter to it. The issue is the procedure is called from many other procedures and triggers. Since we can't set default value to out parameter as we can for in parameter, how we can achieve the  requirement without having to update all the places where this procedure is being called. 
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jan 11, 2013
        I'm trying to find a way to ADD new partitions to local indexes and at the same time specify their tablespaces without having to DROP and RECREATE.
Here´s an example table based on yearly partitioning:
CREATE TABLE "TABL_ANOM" 
(
ANOM_TS TIMESTAMP(6) NOT NULL 
, ANOM_TIPO NUMBER(2, 0) NOT NULL 
, ANOM_NIVEL NUMBER(2, 0) NOT NULL 
, ANOM_ID NUMBER(10, 0) NOT NULL 
[code]...
Here´s an index def for the table:
CREATE INDEX "TABL_ANOM_INDEX1" ON "TABL_ANOM" ("ANOM_NIVEL") LOCAL
(PARTITION DGSCOPSX_2011 TABLESPACE DGSCOPSX_2011
,PARTITION DGSCOPSX_2012 TABLESPACE DGSCOPSX_2012
)
OK. Now I want to add partitions for 2013 so for the table I use:
ALTER TABLE TABL_ANOM ADD
PARTITION DGSCOPS_2013 VALUES LESS THAN (TO_DATE('2014-01-01 00:00:00','YYYY-MM-DD HH24:MI:SS')) TABLESPACE DGSCOPS_2013;
and this works fine for the table but I can't find a similar command to simply add additional partitions to the indexes. I know that I can drop and recreate the indexes with the additional partition defs but on some of my tables, I'm dealing with hundreds of millions of rows and I think it would take way too long to drop and recreate all indexes on all partitions.
Also related is the PRIMARY KEY index partitions. Is there a way to add partitions (specifying the tablespaces) without having to DROP and re-ADD the CONSTRAINT with the additional partition for 2013?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Oct 11, 2013
        I need some functionality in current (4.2.2) APEX websheet which seems not possible out of the box.Therefore I'd like to ad a javascript to my websheet application.
	View 0 Replies
    View Related
  
    
	
    	
    	
        Aug 24, 2012
        I have successfully set up a (test) environment for single-instance Grid Infrastructure and Oracle database using job role separation. So I have the recommended grid and oracle users, and the oinstall, dba, oper, asmadmin, asmdba and asmoper groups. I have the following directory structure for my Oracle Bases and Oracle Homes:
/u01/app/11.2.0/grid - GI home
/u01/app/grid - GI base
/u01/app/oracle - DB base
/u01/app/oracle/product/11.2.0/db_1 - DB home
Platform is OEL5, 11.2.0.1 GI and DB.
This all works fine. 
What I now want to do (since what I'm trying to do is make this environment as secure as practical) is set up an additional sysoper operating system account, so that that user can connect to carry out sysoper tasks, amongst other things stopping and starting the instance.
So (as the oracle user) I do the following:
$ sqlplus / as sysdba
SQL> create user test identified by passwrod;
SQL> grant sysoper to test;
SQL> exit
As root I do the following:
$ useradd -g oper testoper
$ su - testoper
Now as testoper:
$ sqlplus 'test/password as sysoper'
SQL> shutdown immediate
Database closed.
Database dismounted.
ORACLE instance shut down.
[code].........
As you can see, shutdown works, but startup doesn't. I have registered an SR with Oracle on this, but they're not being useful. The suggestion was that I should give testoper the to install secondary group. But this is not a secure solution as this now gives testoper privileges to do things in OB / OH that it really shouldn't be able to do. No other suggestions have been forthcoming. The reason for the suggestion however is the ownership / permissions on the Grid OH oracle executable:
[root@db03 ~]# ls -la /u01/app/11.2.0/grid/bin/oracle
-rwsr-s--x 1 grid oinstall 184286237 Aug 22 11:15 /u01/app/11.2.0/grid/bin/oracle
As you can see, it has group oinstall, so you can see why giving the user oinstall group would work. But in my view this is not satisfactory. 
One thing that occurred to me is that in this environment I should arguably in fact be using srvctl to stop / start instances. But that means setting up a user with asmoper role (presumably) rather than oper. That user would then (again presumable) be able to stop and start other GI resources, which is not what I want.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 7, 2010
        I would like to create a trigger on a table which populates a log table. In addition to using the table where the trigger will exist, I would like to populate a couple more fields in the log table with with data from 2 other tables. 
e.g. 
NAME_TABLE
-reg_id
-name
ADDRESS_TABLE *trigger to be fired when a new record is created here.
-reg_id
-srv_id
PROCESS_TABLE
-srv_id
-start_time
-end_time
This is what I would like the logging table to look like:
LOGGING_TABLE
-address_table_reg_id
-address_table.srv_id
-name_table.name
-process_table.start_time
-process_table.end_time
How can I go about creating this type of trigger?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 22, 2012
        I am trying to migrate a table to a new table that has the field sequence changed and also has a new field added. My main question is if it is possible to have datapump add values to the new field in the target table.For example:
-original table has fields a, b, d, c
-new table has fields b, c, d, a, e
I want to load the new table and also include adding values for field e. In this case, field e is a year field, so it should be loaded with '2012'..Does datapump have the ability to do this? Is reorganizing the fields going to cause me any problems? We are on oracle version 11.2.0.3
	View 7 Replies
    View Related
  
    
	
    	
    	
        Oct 2, 2011
        I am new to sql..
I need to join 2 tables based on first match.. I cldnot use distinct on the result, as distinct work with entire row..
I cant use group by as well, since for group by hv to select all the columns which we need to display
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jan 20, 2012
        Suppose I have a table in which I have first_name, last_name, dob. Now I have to fetch on the basis of first_name=some_value, last_name=some_value and dob=some_date. I want to sort it on the basis of exactly fetched values. Let me take an example-
test table contains-
first_name  last_name  dob
----------  ---------  ----
Manu        Batham     02-Feb-1988
Manu        Sharma     01-Jul-1987
Avinash     Pandey     03-Feb-1988
Ankit       Gupta      02-Feb-1988
Manu        Aggrawal   02-Feb-1988
Manu        Batham     20-Jan-1985
Sikha       Batham     17-Apr-1988
Now if I give parameters-
first_name='Manu'
last_name='Batham'
dob='02-Feb-1988'
then my result should be like below-
result-
first_name  last_name  dob
----------  ---------  ----
Manu        Batham     02-Feb-1988
Manu        Aggrawal   02-Feb-1988
Manu        Batham     20-Jan-1985
Manu        Sharma     01-Jul-1987
Ankit       Gupta      02-Feb-1988
Sikha       Batham     17-Apr-1988
My result is based on the approach-
if matched first_name, last_name, dob --> 1st prefrence in order
if matched first_name, dob            --> 2nd prefrence in order
if matched first_name, last_name      --> 3rd prefrence in order
if matched last_name, dob             --> 4th prefrence in order
if matched first_name                 --> 5th prefrence in order
if matched last_name                  --> 6th prefrence in order
if matched dob                        --> 7th prefrence in order
I designed the following query for the same-
Select first_name,last_name,dob,1 "Order" from test Where
first_name='Manu' and
last_name='Batham' and
dob=to_date('02/02/1988','dd/mm/yyyy')
union
Select a,b,c,2 from test Where
[code]......
I know that this is not the best possible solution as the table is very big and doing so many hits on that table will certainly decrease the performance. 
	View 19 Replies
    View Related
  
    
	
    	
    	
        Aug 28, 2012
        I have some records as below would like to match and merge them
ID1    ID2
101    103
101    104
205    103
206    103
205    106
151    222
157    222
151    223
156    222
134    223
134    435
156    438
Output should be. All matching records should be grouped together and generate result by new seq
ID1    ID2    Result
101    103    1
101    104    1
205    103    1
206    103    1
205    106    1
151    222    2
157    222    2
151    223    2
156    222    2
134    223    2
134    435    2
156    438    2
	View 15 Replies
    View Related
  
    
	
    	
    	
        Jul 17, 2013
        Seemingly a very simple problem, but I can't seem to figure it out. Table below is a table that holds UserId' s and LinkId's.  
CREATE TABLE UserLink (UserId NUMBER, LinkId NUMBER );
ALTER TABLE UserLink ADD PRIMARY KEY (UserId, LinkId);
INSERT INTO UserLink VALUES (1, 1);
INSERT INTO UserLink VALUES (1, 2);
INSERT INTO UserLink VALUES (3, 1);
INSERT INTO UserLink VALUES (4, 1);
I'm looking for a query in which I can plug a List of LinkId's that outputs only users that have a relationship with ALL LinkId's provided. In this example you may assume that the List is equal to (1, 2), but you can't make any assumptions about the size of the list, other than size != 0. The query to find users that match ANY of the provided LinkId's is quite simple:  
SELECT UserId FROM UserLink
WHERE LinkId IN (1,2)
The correct query should output: 
USERID
------
1
And it should work for any size > 0 list of values.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Aug 2, 2012
        Below is a column 'ADDR' with the data (single column)
ADDR
--------
/shared/Folder_1 :^BIAdministrator:^BIAuthor:^BIConsumer:BISystemUser:OracleSystemUser:System:weblogic: :F
[Code]....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Aug 19, 2013
        find two words matching from two different tables.
Example:-
table1   ||                                 table2
john Dev  ||                                Kab Leva
Zaheer khan  ||                             mark dev
Cina maater ||                              jhon dev wood
kab leva Sumo ||                            Tony levis
output:-
john dev ||  john dev
kab leva ||  kab leva
	View 9 Replies
    View Related
  
    
	
    	
    	
        Apr 23, 2010
        I have table as follows:
create table sample1 (
i number , 
j date,
k number)
insert into sample1 values (1,'23-Apr-2010',11)
insert into sample1 values (2,'22-Apr-2010',12)
insert into sample1 values (3,'21-Apr-2010',13)
insert into sample1 values (4,'19-Apr-2010',14)
insert into sample1 values (5,'18-Apr-2010',15)
insert into sample1 values (6,'17-Apr-2010',16)
I would like to get nulls , if there is no data for a date. As we can see , here i am missing the data for '20-Apr-2010'.
I did it through "UNIX" , but it's not efficient. 
 The data might be missing for the complete week also. I need to test in this way only for the last 7 days. I tried something like this:
select i, j , sum(k)
from sample1
where j in (select to_date(sysdate - rownum)
from dual 
connect by rownum < = 7)
group by i, j
	View 3 Replies
    View Related
  
    
	
    	
    	
        Feb 28, 2011
        In query I have WHERE clause like this:
WHERE TO_DATE(TO_CHAR(RR.PEROFOPFROM,'DD-MON-YYYY')||RR.AIRCRAFTSTD,'DD-MON-YYYY:HH24MI')  >                         
TO_DATE(TO_CHAR(RR.PEROFOPFROM,'DD-MON-YYYY')||RR.AIRCRAFTSTA,'DD-MON-YYYY:HH24MI')
I have data like this:
PEROFOPFROMAIRCRAFTSTD
29/03/20102150
NULL            NULL
NULL            NULL
30/03/20102150
When I execute the query it always gives me the error "literal does not match format string".
	View 7 Replies
    View Related
  
    
	
    	
    	
        Dec 6, 2012
        I'm trying to do data mining on a web log which recorded one day web access information from a busy web server. I imported the data into Oracle Data miner, and created a table (WEBLOG). The idea is to create a new field, i.e. session, for the users so that each session could be thought as a representative of a user-intent (aka topic). Now based on this, data mining models would be used to cluster(group) the users based on their similarity. The first step is to prepare the data which involves using SQL queries. So first, all I did was to create a function for date and time. This is the following code I used,
create or replace function ssndate(p_date in varchar2 default '03-01-18',
p_time in varchar2)
return number
$if dbms_db_version.ver_le_10 $then
deterministic
$elsif dbms_db_version.ver_le_11 $then
result_cache
$end
as
begin
return trunc((to_date(p_date||' '||p_time, 'dd-mm-yy hh24:mi:ss')
- to_date('01-01-90','dd-mm-yy')) * (86400/2400));
end ssndate;
/
The function ssndate compiled successfully.The next step I took was to create a view through the following query,
create or replace view WEBLOG_VIEWS
as
select (select ssndate(LOG_DATE, LOG_TIME) from dual) as "SESSION_DT",
C_IP,
CS_USER_AGENT,
(CS_URI_STEM||'?'||CS_URI_QUERY) as WEB_LINK
from WEBLOG;
This was successful as well. The problem is in the next step where I try to do data grouping.
create table FINAL_WEBLOG as
select SESSION_DT, C_IP, CS_USER_AGENT,
listagg(WEB_LINK, ' ')
within group(order by C_IP, CS_USER_AGENT) "WEB_LINKS"
from WEBLOG_VIEWS
group by C_IP, CS_USER_AGENT, SESSION_DT
order by SESSION_DT
[code]....
the to_date function should be fine. In the data that I possess, the date and time are in no format. Example: 30118 and 0:00:09 respectively. 
	View 6 Replies
    View Related
  
    
	
    	
    	
        Sep 3, 2012
        I've created a table, i have to insert data into it. Herwith Create table statement:
CREATE TABLE IOSTAT_MAC ( 
IS_DATE DATE,
IS_RS NUMBER(4,2),
IS_WS NUMBER(2,2),
IS_KRS NUMBER(5,2),
IS_KWS NUMBER(5,2),
[code]....
herewith data I have to insert
insert into iostat_mac values(to_date('2012/03/28 08:00:00 AM'),'653.6','20.7','15392.0','451.8','0.0','5.5','0.0','8.2','0','64','/vol/sun_dc_u2');
Receive ora-01861 error when trying to insert.Suspected it had to do with the date format, I changed the nls parameter for my session to include the time format, but to no avail.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jul 27, 2012
        Here is the code :
CREATE OR REPLACE PROCEDURE SEND_MESSAGE_PRC (P_MESSAGE_CONTROL_id varchar2)
IS
BEGIN
DBMS_SCHEDULER.DROP_job(job_name        => 'ftp_job');
DBMS_SCHEDULER.drop_program (program_name => 'ftp_prg');
DBMS_SCHEDULER.create_program(program_name        => 'ftp_prg',
[code]...
When I execute this : I get an error saying that "too many declarations of set_job_argument_value match this call"..It worked before.
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 23, 2012
        TABLE 1 : COSTS
I have a table of Costs. We have Jobs that run and there will be a cost associated with a particular machine.So JobNo 1 may run on Machine A and have a cost of 50 dollars. Although its now shown below JobNO 1 could run on MachineB and so on.
JOBNO MACHINE COST
1   MachineA 50
2   MachineA 70
3   MachineA 100
TABLE 2: OPERATIONS
We have operators (PERSONCODE) run the jobs on the machines. So Job 1 may be run by PERSONCODE 8 (e.g. Tony) and it may run on MachineA or MachineB.Multipe people may run a particular job. The PERSONCODE will be unique to the Job and it is actually unique to the list. A person never works on more than one job.
JOBNO MACHINE PERSONCODE
1  MachineA8
1  MachineA7
1  MachineB6
2  MachineA3
2  MachineA2
2  MachineA1
3  MachineA4
DESIRED RESULT:
I need to assign the COSTs to the OPERATIONS table but only want it to show next to one person (next to the appropriate machine).
DESIRED RESULT:
JOBNO MACHINE PERSONCODE COST
1  MachineA8 50
1  MachineA7
1  MachineB6
2  MachineA3 70
2  MachineA2
2  MachineA1
3  MachineA4 100
[code]....
	View 5 Replies
    View Related
  
    
	
    	
    	
        Aug 11, 2010
        I've got a oracle install [non production, but devel] that is a tad screwed up. We moved the box and as a result changed the hostname to match the new naming scheme. Ever since then OracleEM has been somewhat confused. In anycase, I don't want OEM anyways now. Plan is to learn SQLplus.
That being said I've used emctl to shut down dbconsole, but it seems there is something somewhere that keeps restarting 2 processes that like to sit around and take up 100% cpu. I can kill them, they stay dead for a few hours then crop up again.I was able to find this out about them:
[jmacdonald@devoracle ~]$ ps auxwww|grep 2033
oracle   20334 84.1 12.3 994052 255824 ?       Rs   Aug10 1740:43 ora_j000_orcl
oracle   20336 80.9 14.1 998140 294288 ?       Ss   Aug10 1674:18 ora_j001_orcl
And then this, which caused me to conlucde its OracleEM:
SELECT sess.process, sess.status, sess.username, sess.schemaname, sql.sql_text
  FROM v$session sess,
       v$sql     sql
 WHERE sql.sql_id(+) = sess.sql_id
   AND sess.process in (20334,20336)
[code]...
	View 6 Replies
    View Related