Range Partitioning With Number Column
			Apr 21, 2011
				 i have a requirement To partition a Table byRange partition with a Number column. but the issue is the range Must be in a Date datatype , 
For example
partition by range (date_key)
     ( PARTITION DEF VALUES LESS THAN ('01-SEP-10'))
the date_key column has values of date in  number format. like "20101014"
	
	View 2 Replies
  
    
	ADVERTISEMENT
    	
    	
        Nov 15, 2013
        Database Version : DB : Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit ProductionOS : HP-UX nduhi18 B.11.31 U ia64 1022072414 unlimited-user licenseAPP : SAP - ERP I have to RANGE partition on UPDATED_ON  or PROFILE  either one table which is having below 
structure :   Name                Null?    Type
 -------------------- -------- -------------------------------- 
MANDT                NOT NULL VARCHAR2(9) MR_ID                NOT NULL VARCHAR2(60) PROFILE              NOT NULL VARCHAR2(54) REGISTER_ID          NOT NULL VARCHAR2(30) INTERVAL_DATE        NOT NULL VARCHAR2(24) AGGR_CONSUMPTION     NOT NULL NUMBER(21,6) MDM_VERS_NO          NOT NULL VARCHAR2(9) MDP_UPDATE_DATE      NOT NULL VARCHAR2(24) MDP_UPDATE_TIME      NOT NULL VARCHAR2(18) NMI_CONFIG           NOT NULL VARCHAR2(120) NMI_CONFIG_FLAG      NOT NULL VARCHAR2(3) MDM_DATA_STRM_ID     NOT NULL VARCHAR2(6) NSRD                 NOT NULL VARCHAR2
[Code]....
 As per my knowledge, RANGE is better suited for DATE or NUMBER. and INTERVAL partition is possible on DATE or NUMBEr . Column PROFILEIts is of VARCHAR2 datatype. I know still I can partition as Oracle internally convert varchar2 to number while inserting data. But INTERVAL is not possible.  How to RANGE partition on PROFILE ? Column CREATED_ON :It is of NUMBER with decimal
	View 0 Replies
    View Related
  
    
	
    	
    	
        Sep 19, 2013
        11gr2, We need to do partition a existing table of size 20g, But partition key column is NUMBER type and data stored in unix date format.I would like to create a monthly partition table as below. But not able to create. 
create table student (  ENTRY_ID number(5,1),  NAME varchar2(30 BYTE) )  partition by range ( fun_unix_to_date (ENTRY_ID) ) --> fun_unix_to_date is a customized function to convert unix time stamp to date format.    
INTERVAL (100)   ( PARTITION CATCH_ALL values LESS THAN (to_date('01-MAR-12','DD-MON-YY'))); 
ERROR at line 5:ORA-00907: missing right parenthesis
	View 5 Replies
    View Related
  
    
	
    	
    	
        Dec 16, 2010
        Other than the obvious to me, where interval partitioning creates partitions as needed. Is there any performance benefit from using interval partitions vs date range partitions.
One draw back for me is that developers do access the partition name in some of their queries, so if I use date range partitioning this will not break their code. I could not find a way to assign a name to a partition when using intervals, is this always system generated or can this be over-ridden.
I am running Oracle 11.1.0.7 soon to be running on 11.2.0.0
	View 6 Replies
    View Related
  
    
	
    	
    	
        May 2, 2013
        I am trying to create a partitioned table so that a number (which date converted to number ) partition is created on inserting a new row for release_date column. 
 note that release_date column is having number data type (as per design) and people want to create an interval based partition on this. 
They want data type NOT to be altered. 
create table product( 
prod_id number, 
prod_code varchar2(3), 
release_date number) 
partition by range(release_date)
interval(NUMTOYMINTERVAL (1,'MONTH')) 
(partition p0 values less than (20120101)) 
	View 11 Replies
    View Related
  
    
	
    	
    	
        Sep 13, 2010
        Environment
I have a database 10.2.0.4 running on 64bit Solaris 5.10 SPARC.
Question: 
CREATE TABLE SYSTEM.BIG_TABLE1
(
ID         NUMBER(10),
LOOKUP_ID  NUMBER(10),
DATA       VARCHAR2(50 BYTE)
)
[code].......
When I query dba_tab_partitions. I get this result
select table_name, partition_name, high_value, high_value_length from dba_tab_partitions where table_name = 'BIG_TABLE1' ;
table_name    partition_name high_value HIGH_VALUE_LENGTH
------------- -------------- ---------- -----------------
BIG_TABLE1    BIG_TABLE_2003 1000000000                10
BIG_TABLE1    BIG_TABLE_2004 5000000000                10
BIG_TABLE1    BIG_TABLE_2005 MAXVALUE                   8
3 rows selected.
Now my question is why do I see max_value_lengh=8 when my column value is 10. I don't get any error. But I do like to understand it.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Apr 12, 2013
        At moment we use range-hash partitioning of a large dimension table (dimension model warehouse) table with 2 levels - range partitioned on columns only available at bottom level of hierarchy - date and issue_id.
Result is a partition with null value - assume would get a null partition in large fact table if was partitioned with reference to the large dimension.Large fact table similarly partitioned date range-hash local bitmap indexes 
Suggested to use would get automatic partition-wise joins if used reference partitioningWould have thought would get that with range-hash on both dimension.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 12, 2010
        Our organization is attempting to learn more about the partitioning features of Oracle 11g. I've been reading the partitioning manuals, and I have not found a clear answer on this topic, but I suspect I know the answer.
If you create a range partitioned table; using interval partitioning, say something like this:
CREATE table range_parti (
CODE NUMBER(5),
DESCRIPTION VARCHAR2(50),
CREATED_DATE DATE)
PARTITION BY RANGE (created_date)
INTERVAL (NUMTOYMINTERVAL(1,'MONTH'))
(
PARTITION my_parti VALUES LESS THAN (TO_DATE('01-NOV-2007','DD-MON-YYYY'))
);
but you try to insert a null value as the partition key, you get the following error:
SQL> INSERT INTO range_parti VALUES (1,'one',NULL);
INSERT INTO range_parti VALUES (1,'one',NULL)
            *
ERROR at line 1:
ORA-14400: inserted partition key does not map to any partition
Elapsed: 00:00:00.07
Is there no way to tell it to use a default partition for NULL values? Or specifically designate a partition for NULL values WITHOUT having to manually list out each partition? It seems it works if you don't use the INTERVAL keyword, list out your partitions, and use MAXVALUE. However, our hope to avoid having that as it creates monstrously huge DDL statements for tables that have lots of date ranges, and we will be forced to manually add new partitions each month as data is added/time passes.
 
It appears from my experience so far, if your column can allow nulls, you cannot use interval range partitioning on that column. 
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jul 12, 2012
        I have a table with two columns Column1 and column2 
Like such
create table testTable (column1 number(15), column2 number(15));
 
 insert into testTable values (1,5);I need to find the numbers between column 1 and column 2 including the column 1's number and column's 2 number.
so my answer set should be
 1,2,3,4,5
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jul 14, 2011
        I have following requirement. Let say i have to generate a range based on "start number" and "end number" dynamically.Some kind of hash buckets.
e.g Start Number : 1 and End Number : 1001. 
Also i want to divide that range based on some dynamic value like for above example 10 ranges of 100 each. and both 1 and 1001 should be included only once and the next row start number cannot be same as previous row end number.
Means
 
Range 1 1 -101
Range 2 102-200
Range 3 201-300 
...
Range 10 901-1001
Is there any way of doing it automatically. I tried with Model clause. it works fine for even cases but for odd i have issues also when i take small start and end number i get an error.
SELECT case when ranges=1 then ranges else ranges+1 end Start_Id, ranges+round((1001-1)/10) End_Id
from
(
[Code].....
I want this to be generic for any values here 1 is Start Number 1001 is end number and 10 is the bucket. I need these parameters dynamic and want's the same kind of results for any values.
	View 22 Replies
    View Related
  
    
	
    	
    	
        Oct 16, 2012
        I have a query that seems to repeatedly call an index scan on a table for reasons I'm not sure about. Why it would be doing the index scan on totaldwellingarea in the dimensions table (DIMEN_PID_TDWELLAREA) repeatedly? This only seems to happen when I put on the range clause d.totaldwellingarea between scr.lowvalue and scr.highvalue.
I am using Oracle version 9.2.0.3.
select d.propertyid,d.totaldwellingarea, e.size_,  scr.size_
from  eqid e, dimensions d,  brt_eval.size_code_ranges scr
where e.style not in ('1','A','G','L') and e.size_  = '0'
and d.propertyid = e.propertyid and e.style = scr.style and d.totaldwellingarea between scr.lowvalue and  scr.highvalue;
CREATE
  TABLE "BRT_ADMIN"."EQID"
  (
    "PROPERTYID"   VARCHAR2(20 BYTE) NOT NULL ENABLE,
    "EQID"         CHAR(10 BYTE),
    "ZONE_"        CHAR(1 BYTE),
    "AREA"         CHAR(1 BYTE),
[code].....
	View 3 Replies
    View Related
  
    
	
    	
    	
        Apr 27, 2013
        create table call(id number(10) primary key,mobile_no number(10), other_no number(10), call_type varchar2(10),call_date_time date, duration number(10));
insert into call values(1,9818764535,9899875643,'IN','24-APR-13 02:10:43',10);
insert into call values(1,9818764535,9898324234,'IN','24-APR-13 05:06:78',10);
insert into call values(1,9818764535,9215468734,'IN','24-APR-13 15:06:78',10);
insert into call values(1,9818764535,9899875643,'OUT','25-APR-13 01:06:78',10);
insert into call values(1,9899875643,9899875643,,'OUT','25-APR-13 22:06:78',10);
Query : need to find first and last call of '9818764535' mobile number and of call_date between '24-apr-13' and '25-apr-13';
Result : 
date ,mobile_no , other_no, call_type, duration
24/apr/13 , 9818764535,9899875643,'IN',10
24/apr/13 ,9818764535,9215468734,'IN',10
[Code]....
	View 5 Replies
    View Related
  
    
	
    	
    	
        Jul 7, 2012
        I have a table which has 2 range partitions on a date column currently. 
CREATE TABLE TABLEA (
     RUN_TIME INT NOT NULL
)
PARTITION BY RANGE (RUN_TIME)
(
     PARTITION DATAONE VALUES LESS THAN (20110101000000) TABLESPACE SPACE1
     PARTITION DATATWO VALUES LESS THAN (MAXVALUE) TABLESPACE SPACE2
);
I am planning to drop one partition i.e DATAONE. So table will have one partition left for MAXVALUE. Does it make sense to have a partition with MAXVALUE? Isn't it same as TABLEA in terms of number of records? TABLEA is also in tablespace SPACE2. Should i remove partition DATATWO also? If i have to what is the best way to move all DATATWO records to base table TABLEA?
	View 6 Replies
    View Related
  
    
	
    	
    	
        Apr 29, 2011
        I am trying to load the data from .csv file into the table using SQL Loader. 
The table has the following schema: 
src_id : number,
dest_id : number,
range: intsys.interval_typ  --- > a type containing  (lower,upper)
payload : varchar2(100)
The loader.ctl file is :
load data
infile *
append
into table sb_packet
fields terminated by "," optionally enclosed by ' " '
(src_id,dest_id,range,payload)
BEGINDATA
3,32,intsys.interval_typ(10043,142703),"misc data"
When I use the following this ctl file to transfer the data, i get the following error:
SQL*Loader-418: Bad datafile datatype for column RANGE
	View 2 Replies
    View Related
  
    
	
    	
    	
        Sep 28, 2012
        my column type is NUMBER(10,0) ,it accept the input value from text field  I using TO_NUMBER(?) to insert value into table, is the a way to handle if the input is 'aaaaaaaaaa' not digit?
	View 6 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
  
    
	
    	
    	
        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
  
    
	
    	
    	
        Apr 4, 2013
        I have problem to transfer data in non partitioning table to partitioning table.
I have non partitioning table and i create new table partitioning that have same column and type like in non partitioning. So how can i transfer data from table in non partitioning to table in partitioning?
	View 10 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
  
    
	
    	
    	
        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
  
    
	
    	
    	
        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
  
    
	
    	
    	
        Mar 21, 2011
        I think I am having a rounding issue, but not sure. If I add all 4 rows below I get 1530.06. But when I use SUM, I get 1529.87  
select   PAY_EVENTS_AMOUNT 
from PAYROLL_PAY_EVENTS_T1  PPET1
where ppet1.regnum = 130402134
and ppet1.pay_period = 2
                          
PAY_EVENTS_AMOUNT
=================
-1499.19
2998.38
-30.68
61.36
=======
1530.06 TOTAL  
                    
========================================================
 
select   sum(PAY_EVENTS_AMOUNT ) PAY_EVENTS_AMOUNT
from PAYROLL_PAY_EVENTS_T1  PPET1
where ppet1.regnum = 130402134
and ppet1.pay_period = 2
            
PAY_EVENTS_AMOUNT
=================
       1529.87  TOTAL
	View 12 Replies
    View Related
  
    
	
    	
    	
        Dec 30, 2005
        In chapter 17 of the 'Oracle Database 10g, The Complete Reference' it says "You can increase or decrease the number of decimal places in a NUMBER column at any time". When trying to modify a column from NUMBER(38) to NUMBER(38,3) I get the ORA-01440 error. Is there a way around this when you have the maximum number of digits (precision = 38).
	View 2 Replies
    View Related
  
    
	
    	
    	
        Mar 25, 2010
        In a table, I have a column in a table with the following values:
targetcol
30 WD
180 WD
70%
0
80%
180 CD
70%
0
7 WD
2 WD
0
-
-
-
-
-
-
-
-
-
where WD is working days and CD Calendar days.
I just need to extract number from above.
	View 11 Replies
    View Related
  
    
	
    	
    	
        May 16, 2011
        I have a column defined as Number( 8 ) which is supposed to have date values. I would like to check if all the rows in that table have valid dates. We could use to_date(coulmn_name, 'YYYYMMDD') and catch the rownums for error conditions using pl/sql. I would like to know if we could just do it using sql only and return the row numbers for those that are invalid dates?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Apr 14, 2011
        create table test_table(
rn varchar2(10),
col1 varchar2(10),
col2 varchar2(10),
[code]...
I want update col1 whis is null to max(col1) ++ in a row, order by cr_date like 
1,1,20110102
2,2,20110101
3,null,20110105 => 3,5,20110105 because this row is after 20110103
4,3,20110104
5,null,20110103 => 5,4,20110103 because this row is before 20110105
update test_table
set col1 = (select max(col1) from test_table) + rownum
where col1 is null;
this gives ora-00933
	View 6 Replies
    View Related
  
    
	
    	
    	
        Oct 12, 2012
        From a list of values from a number column, I need to verify is there any values not satisfying number(3).
Ex- I have a column col1 where we have following values
'qwq'
'12.3'
'1'
'15'
Can I write a query to check the value not satisfying number(3) datatype.Eg the query should return
'qwq'
'12.3'
as the above two will not fit in to number(3) datatype columns
	View 13 Replies
    View Related
  
    
	
    	
    	
        Aug 1, 2011
        My need is to calculate rows and write result into column: 
c1 if current month is 1st in quarter, 
c2 if current month is 2nd in quarter, 
c3 if current month is 3rd in quarter. 
How do I perform it?
	View 22 Replies
    View Related
  
    
	
    	
    	
        Apr 20, 2013
        I have a query that should return count the number of rows depending on the value of SLOT. The expected result will be like this:
WIPDATAVALUE          SLOT             N            M
1-2                   TRALTEST43S1     1            3
1-2                   TRALTEST43S1     2            3
3                     TRALTEST43S1     3            3
4-6                   TRALTEST43S2     1            4
4-6                   TRALTEST43S2     2            4
4-6                   TRALTEST43S2     3            4
7                     TRALTEST43S2     4            4
The M column is used to count the total number of occurrences of a SLOT. Now, as for the N field, this is used to count the occurrence of the SLOT. In my example for the SLOT TRALTEST43S1, it has three occurrences so M will be 3. Why 3, is because of the WIPDATAVALUE. The WIPDATAVALUE of TRALTEST43S1 is 1-2 and 3. 1-2 WIPDATAVALUE signifies two occurrences (one to two) and 3 signifies only one occurrence. As for N, it should just count the number of occurrence. To further explain, see below:
WIPDATAVALUE       SLOT                N                M
1-2                TRALTEST43S1        1                3        -> First occurrence in the total of 3
1-2                TRALTEST43S1        2                3        -> Second occurrence in the total of 3
3                  TRALTEST43S1        3                3        -> Third occurrence in the total of 3
4-6                TRALTEST43S2        1                4        -> First occurrence in the total of 4
4-6                TRALTEST43S2        2                4        -> Second occurrence in the total of 4
4-6                TRALTEST43S2        3                4        -> Third occurrence in the total of 4
7                  TRALTEST43S12       4                4        -> Fourth occurrence in the total of 4
This is the query that I have so far:
SELECT DISTINCT
WIPDATAVALUE, SLOT
, LEVEL AS n
, m 
FROM
(
  SELECT
    WIPDATAVALUE
    , SLOT
    , (dulo - una) + 1 AS m 
[code]....
  
I think that my current query is basing its M and N results on WIPDATAVALUE and not the SLOT that is why I get the wrong output. I have also tried to use the WITH Statement and it works well but unfortunately, our system cant accept subquery factoring.
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 24, 2012
        I want to decrease the size of testid column of number datatype in my "test" named table from size 20 to 15 and the data of  maximum size is of 10 digits. but oracle throws an error "ORA-01440: column to be modified must be empty to decrease precision or scale". i cant understand why it is happening? 
 what is the reason behind it even though new size is maximum than the maximum size of existing data.  but when i decrease the size of "varchar2"  then oracle does not through any error.
	View 3 Replies
    View Related