SQL & PL/SQL :: Assigning ID (Fill SID Column)
			Feb 4, 2013
				I have a table with 200k entries, which has ~12k unique combination of columns that I wish to assign an ID to.  My real world problem is with addresses and street components (of which nulls are allowed); but this should be a reasonable example.
DROP TABLE tt;
CREATE TABLE tt AS
  SELECT       ROWNUM id,
               CASE
                 WHEN MOD(ROWNUM, 107) = 0 THEN NULL
                 ELSE MOD(ROWNUM, 101)
               END
                 c1,
               CASE
[Code]...
Now I have 3 ways to assigned an ID (fill the SID column).
The first is congruent with the method most commonly used, but seems especially slow in this case.  I think this is due to the COALESCE/TO_CHAR usage.  Can this be optimized?
DECLARE
  CURSOR c1 IS
    SELECT   a.*, sid_seq.NEXTVAL sid
    FROM     (SELECT DISTINCT c1, c2 FROM tt) a;
BEGIN
  FOR s IN c1 LOOP
    UPDATE   tt d
[Code]...
The second I've made relies on the usage of a temp table, which I really don't like, but it is faster; so that is something at least.
CREATE TABLE ttt AS
  SELECT   a.*, sid_seq.NEXTVAL sid
  FROM     (SELECT DISTINCT c1, c2 FROM tt) a;
         
[Code]...
The third discards the sequence, and uses dense_rank. This allows us to use the ID (which might have an index, whereas c1 and c2 will not).
MERGE INTO   tt d
USING        (SELECT id, (SELECT COALESCE(MAX(sid), 317) FROM tt) + DENSE_RANK() OVER (ORDER BY c1, c2) sid FROM tt) s
ON           (d.id = s.id)
WHEN MATCHED THEN
  UPDATE SET d.sid   = s.sid
The ideal solution would use the SEQUENCE, not use a temporary table and match/merge/update based on ID, and be 'fast'; but I cannot conceive of such a solution; does one exist?  What would you do?
	
	View 2 Replies
  
    
	ADVERTISEMENT
    	
    	
        Jun 14, 2011
        Can I assign the outcome of a select query to a defined variable
like  
var=select emp id from emp where empname='ddf'
	View 5 Replies
    View Related
  
    
	
    	
    	
        Apr 10, 2012
        acheive the below result.
Select * from result;
res
===
3
3
3
3
3
0
3
3
3
0
3
0
output: 
I would like to get res1 using SQL query. 
resres1
31
32
33
34
35
00
31
32
00
31
32
33
34
00
..       ....
	View 9 Replies
    View Related
  
    
	
    	
    	
        Dec 9, 2008
        How to right justify and zero fill in oracle ?
as example input data is '1' and i want to insert '0'  in front of the input data and the output will be 01 .
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 14, 2012
        if it is possible to assign a varchar2(14) index to a pl/sql table while fetching bulk data with bulk collect.my requirement is to assign varchar2(14) index to a pl/sql table so that i can directly reach to my record by index and process the record further.
further i need to run a loo on this ( for processing each record)my database version is 11.2.01.0.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 23, 2013
        in my procedure i am creating a sequence on the fly, i am preparing the name with some passed parameters like below 
v_seq_name := 'seq_'||loadid||v_table_name;
execute immediate 'CREATE SEQUENCE '||v_seq_name||' MINVALUE 1 MAXVALUE 999999999999999999999999999 START WITH 1 increment by 1 cache 20'; 
and now after doing some operations i need to assign the current value of sequence to a number variable i tried following but not working 
1) v_curr_value : = v_seq_name.currval ;
2) select v_seq_name||'.nextval' into v_curr_value from dual;
how i can get the value in plsql block.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 5, 2010
        I want to fill data from the above records in the same column. How to do that by use SQL command ?
from
Invoice_No.Line_Item
000011
2
3
000021
2
000031
000041
2
000051
to
Invoice_No.Line_Item
000011
000012
000013
000021
000022
000031
000041
000042
000051
	View 10 Replies
    View Related
  
    
	
    	
    	
        Sep 23, 2008
        I am writing a code in Proc as
<code>
#define SMSDUN_LANGID_LEN           10
-- other statements
EXEC SQL BEGIN DECLARE SECTION
char dbLanguageId[SMSDUN_LANGID_LEN + 1];
EXEC SQL END DECLARE SECTION
-- other statements
EXEC SQL EXECUTE
    BEGIN
    SELECT LANGUAGE_ID -- Length of this column is 10
    INTO :dbLanguageId
    FROM CUSTOMERATTRIBUTES
 
[code]...
While executing the above command, it is giving error as "ORA-01480: trailing null missing from STR bind value". Its working in some oracle versions but not in other. where exactly the problem is.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jul 17, 2011
        I need to use funtion optional parameters to construct an update statement in the funtion body. I have two scenarios, either both parameters are not null or the 2nd is null. Do I have to use
IF 
(param2 is null)
THEN 
udpate using param1 only
ELSE 
update using both param1 and param2
END IF;
or is there a shortcut to do this?
	View 15 Replies
    View Related
  
    
	
    	
    	
        Jun 13, 2011
        I am using arrays on this procedure but would like to use a WHILE LOOP to fill the array.  The first element uses a balance forward amount unlike the next 11 elements so I would think I have no other choice for the first element.  
jde_account_balances is the table name that stores the amounts.
Here is what I currently have coded:
X INTEGER;
Y INTEGER;
Z INTEGER;
[code]...
	View 7 Replies
    View Related
  
    
	
    	
    	
        Oct 10, 2010
        What happens when I enter date with missing parts ? for example if there is a field of type Date and I inserted the value To_Date ('12/3/2005', 'dd/mm /yyyy') what will the values of the missing date parts be ? hh and mi and ss .so how does Oracle completes the missing parts of the date.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 24, 2011
        I would like to fill items :P200_A and :P200_B and so on with the result of a SELECT which depends on the different values of many select lists.
E.G. :P200_list_alpha with the list of values
STATIC:less than 10;less,equal than 10;equal,above 10;above,indifferent;indiff
:P200_list_beta with the list of values
STATIC:active;active,passiv;passiv,excluded;excluded
How do I write the select statement ? I think it has to be executed in an anonymous PLSQL Procedure (after submit).
What is a convenient way to write the select statement ? I could imagine to use lots of IF , ELSIF, ELSE statements and in each branch (here 12 ) the whole/complet SELECT statement is written.
How to solve this problem in an elegant way ? In my opinion the CASE statement could be useful, but how to use it in the WHERE clause with this nested conditions ?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jan 3, 2013
        I am trying to set the intial value of "Select List" to APP_USER the only first time when the page loads and use it to filter the report, any other time once the page is loaded the user should select another value from the Select List then click the submit button to display the details in the report, i tried to achieve this by setting "select List" creating LOV for Select List then set default=APP_USER but now the problem any time you click the submit button it reset the "Select List" from selected value back to default so how can you achieve this to set the value of Select List only the first time the page loads?
	View 1 Replies
    View Related
  
    
	
    	
    	
        Jun 27, 2012
        I have a report that contains a name that I want to pass in to a field in a form on a different region on the same page. My button located on the report is has its own column called ADD_LINK. Here is the button. 
<button id="apexir_btn_ADD" class="apexir-button" type="button" value="Add" onclick=""><span>Add</span></button>
Once that button is clicked, I have the form region fade in. The region is called Add Tag to Employee, which has P4_ROWID, P4_EMPLOYEE_ID, and P4_TAG_ID. Once the region is displayed, I want the #NAME# to show in the P4_EMPLOYEE_ID. 
I did copy this form from another page, where I had it working before. It made more sense to move it to this page for interface purposes, so maybe that tidbit will work as well.
	View 15 Replies
    View Related
  
    
	
    	
    	
        Oct 15, 2013
        I have one hirarchical query which return the parent to child hirarch level data. it has 11 level child data. i want to create column based on number of child in hirarchy. though i know it is 11 but it can change also.Is there any way i can create the column dynamically
ORG_UNITCOST_CENTERORG_UNIT_NAMEPARENT_ORG_UNITLLSYS_CONNECT_BY_PATH(ORG_UNIT,'/')
500171960000022000Managing Director - LUL500169965/00000001/50000001/50017588/50016996/50017196
500018370000021241FSO500171966/00000001/50000001/50017588/50016996/50017196/50001837
502894940000021241Knowledge Management500018377/00000001/50000001/50017588/50016996/50017196/50001837/50289494
508014980000021241Finance500018377/00000001/50000001/50017588/50016996/50017196/50001837/50801498
	View 1 Replies
    View Related
  
    
	
    	
    	
        Apr 10, 2013
        On my APEX page i have region which has sql query as source and it displays as HTML table the query result to the user.
I want to display addinonal column with a hyperlink inside, and that hyperlink would have CGI/URL-parameters which contains the other values of the HTML row.
So, let's say my APEX region queryes columns as "select c1, c2, c3, c4 ..." and displays out values "V1, V2, V3, V4" then i want to have addional output column with such hyperlink:
a href="f?p=100:7:13467554876288::NO::c1,c2,c3,c4:v1,v2,v3,v4">My link column with CGI-parameters</aHow can i create such hyperlink?
The overall idea is that the link would forward to a page which loads those values "v1,v2,v3,v4" into form fields and user can proceed from there.
---
"Application Express 4.2.1.00.08"
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 13, 2010
        I receive the error,
REP-1241 Circular column dependency originating with column 'cenvat_opening'
I have the following return statement for a column total_credit;
function total_creditFormula return Number is
begin
Return (return nvl(:cf_cenvat_closing ,0) - nvl(:cf_duty_on_goods_ed,0);
end;
Now i am using this total_creditFormula for the error formula column 'cenvat_opening'
function cenvat_openingFormula return Number is
f_num_opn number(14,2);
begin
SELECT NVL(Amount,0) INTO F_NUM_OPN
[code]...
here the formula column 'total_credit' has the following return statements;
RETURN Nvl(:cenvat_opening,0) + Nvl(:cenvat_credit_manu,0)
so how can i use this formula column? is there any other option to return the value in the same column.
	View 6 Replies
    View Related
  
    
	
    	
    	
        Jul 22, 2009
        I'm trying to do a pivot query in oracle to get the years from a column and make a separate column for each. I found an example of the code to use on the internet and i changed it for my own tables but i'm getting errors. Namely a "FROM keyword not where expected" error at the beginning of the 'avg(...' statements.
I have copied the code used in 
select stud_id, 2006, 2007, 2008, 2009
from (
select stud_id, 
avg(case when year=2006 then ((present/poss)*100) else null end) 2006,
avg(case when year=2007 then ((present/poss)*100) else null end) 2007,
avg(case when year=2008 then ((present/poss)*100) else null end) 2008,
avg(case when year=2009 then ((present/poss)*100) else null end) 2009
from attendance.vw_all_attendance_perc
group by stud_id
);
	View 11 Replies
    View Related
  
    
	
    	
    	
        May 15, 2011
        i have two questions.
 (1) how can i fill some value in a table column based on some existing column value automatically without user intervention. my actual problem is i have 'expiry date' column and 'status'. the 'status' column should get filled automatically based on the current system date. ex: if expiry date is '25-Apr-2011' and current date is '14-May-2011', then status should be filled as 'EXPIRED'
(2)hOw can i build 'select' query in a report (report 6i) so that it will show me list of items 'EXPIRED' or 'NOT EXPIRED' or both expired and not expired separately in a single report based on user choice. 'EXPIRED' & 'NOT EXPIRED' can be taken from the above question no. 1.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Nov 21, 2010
        This is what i want to do:
I have a basic report looking like this:
<Column name>
value 1
value 2
value 3
.
.
.
value n
Since the column is small it can fit in a page more then one time. I know how to make it print more then once: i switch the repeating frame to print down and across and i modify the frame that contains it so the horizontal elasticity is variable.
After these changes my report looks like this:
<Column name>
value 1-----------------------value n+1-----------------------value m+1
value 2-----------------------value n+2-----------------------value m+2
value 3-----------------------value n+3-----------------------...
.------------------------------- .
.------------------------------- .
.------------------------------- .
value n-----------------------value m
What i want is my report to look like this:
<Column name>-------<Column name>------------<Column name>
value 1-----------------------value n+1-----------------------value m+1
value 2-----------------------value n+2-----------------------value m+2
value 3-----------------------value n+3-----------------------...
.------------------------------- .
.------------------------------- .
.------------------------------- .
value n-----------------------value m
	View 4 Replies
    View Related
  
    
	
    	
    	
        Sep 10, 2012
        I have written the code for sql loader, I have given termination of file is | , i have given five columns name in sequence...My Requirement is that i want to mapped 100th column from Csv file after 5th column how to do it.
OPTIONS (ERRORS=100000000)
LOAD DATA 
CHARACTERSET UTF8
INTO TABLE "TARGET_STG_AMC"
TRUNCATE
 [code]....
	View 10 Replies
    View Related
  
    
	
    	
    	
        Feb 11, 2013
        We are using Oracle 11g with Apex 3.2 on AIX. We are reporting data from customer satisfaction surveys. I'm using the following sql to create my report
<code>select * from(
select month,'Overall Satisfaction' as q_group, 1 as srt,Overall Satisfaction,site,
case when count(*) < 31 then '*' else 
round((sum(ttos)/count(*))*100,0)||'/'|round((sum(bfos)/count(*))*100,0)||'/'||count(*) end ospct 
from v_XXX_report a,(select distinct month_dt month from v_XXX_report) b 
where Overall_Satisfaction is not null and year_dt = 2012 
[Code]....
The problem is that site is not allways present and sometimes I have other variables in addition to site. This creates a situation where the month columns will not allways appear at the same column number. For example, When I run this query as is then the "JAN" column is Col3 (first column is a break, col2 is not shown). When I run this query without site then "JAN" is the second column. I would like to create column links for the "JAN" - "DEC" columns but not for any other columns.
Another issue - in the column link creation screen I can create up to 3 variables that I can pass to the next page. Since my query is a pivot I'm uncertain how to pass the column heading or the row value (for col2)
ie
Overall Satisfaction JAN FEB MAR APR MAY ...
Overall Satisfaction 12/12/200 12/12/210 12/12/220 12/12/230 12/12/240...
Recommend 12/12/200 12/12/210 12/12/220 12/12/230 12/12/240...
etc.
So if I clicked on the values at Recommend:FEB how can I get "Recommend" and "FEB" into variables that I can use on the next page? I've tried #column_name#, #month#, #q_name# and #APEX_APPLICATION.G_F10# but no luck.
	View 0 Replies
    View Related
  
    
	
    	
    	
        Jun 19, 2012
        I want to pass multiple column values of a row in an interactive report page to hidden items in another page through column link. And I did it successfully. However, I found I need to pass more than 3 columns of a row in this report, while a column link only permits me to pass 3 column value at most. Is there anyway that I can pass more column values to hidden items in another page?
	View 3 Replies
    View Related
  
    
	
    	
    	
        Jul 19, 2013
        CREATE TABLE TYPE
(
c1_type   VARCHAR2 (10),
c2_type   VARCHAR2 (10),
c3_type   VARCHAR2 (10),
c4_type   VARCHAR2 (10),
c5_type   VARCHAR2 (10),
c6_type   VARCHAR2 (10),
[code]......               
actual output of the below query, but i want to display in different way
select * from type;
C1_TYPE    C2_TYPE    C3_TYPE    C4_TYPE    C5_TYPE    C6_TYPE    C7_TYPE    C8_TYPE    C9_TYPE
Region_D   Region_E   Region_F   Region_D   Region_E   Region_D   Region_M   Region_D   Region_E
The expected output should be like this below, how to write a query or which built in function used to get the below result, 
Region_D
Region_D
Region_D
Region_D
Region_E
Region_E
Region_E
Region_F
Region_M
	View 4 Replies
    View Related
  
    
	
    	
    	
        Mar 21, 2013
        I have a table where i have description column which free text column, the data in description column is seperated and i want to corvert 1 row data in multiple rows dependeing on the number of words.
eg
id       description     
78664    Pumps Alarm from CAMS  RTU154 
In the above example this column has 5 word so i want data in 5 rows like below
78664    Pumps 
78664    Alarm 
78664    from 
78664    CAMS
78664    RTU154 
This column data can be varied from 1 to any number of words.
	View 11 Replies
    View Related
  
    
	
    	
    	
        Sep 10, 2010
        I am trying to create a trigger which changes the content of one column based on the information within another column.
For Example, if the 'ITEMQUANTITY' field drops below 1 then I want the STATUS column to say 'Out Of Stock'.
	View 23 Replies
    View Related
  
    
	
    	
    	
        Jul 23, 2013
        is there some performance/access difference between a bitmap index on a number column and char(1) column? Both columns are not null with a default value.My application has a querie like this:  
select ass.column20,  ass.column30from table_a pucinner join table_b asson ass.column1 = puc.column1where pc.column_char = 'S'and ass.column_char02 = 'P'    
If I create a bitmap index on column "column_char", the access plan is not changed. But changing the column datatype to number(1) and obviously the values, the index is accessed and the cost decreases.This table has 4.000.000 rows. Oracle 11.2.0.2SO
	View 7 Replies
    View Related
  
    
	
    	
    	
        Oct 4, 2011
        Is there a way to alter an existing virtual column to set as a real column without dropping it and recreate (i have index on it, and i don't want to recreate them).
	View 2 Replies
    View Related
  
    
	
    	
    	
        Dec 25, 2012
        I have a partitioned table with ~50 million rows that was setup with a number(10) instead of a date column. All the data in the table is ALWATS in this format YYYYMMDD
CREATE TABLE T1.monthly
(
SEQ_NUM                    NUMBER(10)         NOT NULL,
DAY_DK                     NUMBER(10)         NOT NULL
)
TABLESPACE USERS
PCTUSED    0
PCTFREE    10
[code]........
some sample data
 SEQ_NUM     DAY_DK
---------- ----------
       990   20121225
       991   20121225
       992   20121225
       993   20121225
       994   20121225
       995   20121225
       996   20121225
       997   20121225
       998   20121225
       999   20121225
When I use the exchange partition method the parition is able to move the data from "monthly" table to "mth" table.
desc  t1.mth;  ### my temorary table
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 SEQ_NUM                                            NUMBER(10)
 DAY_DK                                             NUMBER(10) 
Than when I try to alter my temp table "mth".  I get an error table must be empty to change column types.
alter table n546830.mth modify (DAY_DK date);
Next I tried making my temporary table "mth" a date column. When I an the exchange partition command I get the following error:
alter table t1.monthly exchange partition DEC_2012 
with table t1.mth without validation;
alter table n546830.monthly exchange partition DEC_2012 with table n546830.mth without validation
*
ERROR at line 1:
ORA-14097: column type or size mismatch in ALTER TABLE EXCHANGE PARTITION
Method I can use to convert a number(10) to date column and keep the information in a table. Note, I don't care about HH:MM:SS as I never had that information to begin with and would be happy to set that part of the date column to all zeroes "00:00:00"
	View 12 Replies
    View Related
  
    
	
    	
    	
        Oct 6, 2011
        if one of the columns is given as
ABC varchar2(10)
can we tell anything about the size of the data in bytes that this column going to hold.
	View 3 Replies
    View Related