1. 組合分區(qū)表的創(chuàng)建方式("范圍-哈稀"),見附1
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:申請域名、雅安服務(wù)器托管、營銷軟件、網(wǎng)站建設(shè)、繁昌網(wǎng)站維護(hù)、網(wǎng)站推廣。
2. 樓主的需求,即"范圍-范圍分區(qū)",在ORACLE 9i, 10g經(jīng)過測試都是不能實(shí)現(xiàn)的
在附1的基礎(chǔ)上修改為"范圍-范圍"組合分區(qū),創(chuàng)建時(shí)報(bào)錯(cuò):ORA-14151:無效的表分區(qū)方法
3. 關(guān)于sxdtgsh兄的回答,我測了
3.1 沒有maxvalue上限分區(qū)設(shè)置,在插入超出分區(qū)的數(shù)據(jù)時(shí)會(huì)報(bào)錯(cuò)ORA-14400: 插入的分區(qū)關(guān)鍵字未映射到任何分區(qū)
3.2 按回答的語句創(chuàng)建分區(qū)表沒有問題,但數(shù)據(jù)無法按照樓主的需求分布
====附1
附錄:創(chuàng)建"范圍-哈稀"組合分區(qū)表
CREATE TABLE TAB11 (ID NUMBER,DT DATE)
PARTITION BY RANGE (DT)
SUBPARTITION BY HASH (ID) SUBPARTITIONS 2 -- 自分區(qū)個(gè)數(shù),可以不寫,由系統(tǒng)判斷
(
PARTITION Y2012 VALUES LESS THAN (TO_DATE('2013-01-01','YYYY-MM-DD'))
(
SUBPARTITION Y2012_H1
,SUBPARTITION Y2012_H2
)
,PARTITION Y2013 VALUES LESS THAN (TO_DATE('2014-01-01','YYYY-MM-DD'))
(
SUBPARTITION Y2013_H1
,SUBPARTITION Y2013_H2
)
,PARTITION YMAX VALUES LESS THAN (MAXVALUE)
(
SUBPARTITION YMAX_H1
,SUBPARTITION YMAX_H2
)
)
====附2,請樓主檢查最后查詢的數(shù)據(jù)分布
create table T_TEST
(
ID NUMBER(20) NOT NULL,
TIME DATE NOT NULL
)
partition by range(TIME, ID) -- 按時(shí)間、ID范圍分區(qū) 這個(gè)例子是按年的
(
partition P_2012_10 values less than (to_date('2013-01-01','yyyy-MM-dd'), 10),
partition P_2012_20 values less than (to_date('2013-01-01','yyyy-MM-dd'), 20),
partition P_2012_MAX values less than (to_date('2013-01-01','yyyy-MM-dd'), MAXVALUE),
partition P_2013_10 values less than (to_date('2014-01-01','yyyy-MM-dd'), 10),
partition P_2013_20 values less than (to_date('2014-01-01','yyyy-MM-dd'), 20),
partition P_2013_MAX values less than (to_date('2014-01-01','yyyy-MM-dd'), MAXVALUE),
partition P_MAX values less than (MAXVALUE,MAXVALUE)
);
INSERT INTO T_TEST VALUES (1,TO_DATE('20121204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (12,TO_DATE('20121204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (32,TO_DATE('20121204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (2,TO_DATE('20131204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (12,TO_DATE('20131204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (33,TO_DATE('20131204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (3,TO_DATE('20141204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (23,TO_DATE('20141204 00:00:00','YYYYMMDD HH24:MI:SS'));
INSERT INTO T_TEST VALUES (43,TO_DATE('20151204 00:00:00','YYYYMMDD HH24:MI:SS'));
SELECT * FROM T_TEST;
SELECT * FROM T_TEST PARTITION(P_2012_10);
SELECT * FROM T_TEST PARTITION(P_2012_20);
SELECT * FROM T_TEST PARTITION(P_2012_MAX);
SELECT * FROM T_TEST PARTITION(P_2013_10);
SELECT * FROM T_TEST PARTITION(P_2013_20);
SELECT * FROM T_TEST PARTITION(P_2013_MAX);
SELECT * FROM T_TEST PARTITION(P_MAX);
配置不同的oracle用戶就相當(dāng)于不同的databases;比如system,scott
dataHost name="oracle1" maxCon="1000" minCon="1"balance="0" writeType="0" dbType="oracle" dbDriver="jdbc"
heartbeatselect1 from dual/heartbeat
connectionInitSqlaltersession set nls_date_format='yyyy-mm-dd hh24:mi:ss'/connectionInitSql
writeHosthost="hostM1" url="jdbc:oracle:thin:@localhost:1521:orcl"user="system" password="123456" /
/dataHost
dataHost name="oracle2" maxCon="1000" minCon="1"balance="0" writeType="0" dbType="oracle" dbDriver="jdbc"
heartbeatselect1 from dual/heartbeat
connectionInitSqlaltersession set nls_date_format='yyyy-mm-dd hh24:mi:ss'/connectionInitSql
writeHosthost="hostM1" url="jdbc:oracle:thin:@localhost:1521:orcl"user="scott" password="123456" /
/dataHost
1、在數(shù)據(jù)庫服務(wù)器的開始菜單中找到Datebase Configuration Assistant。
2、在創(chuàng)建畫面第一步選擇:創(chuàng)建新數(shù)據(jù)庫,點(diǎn)擊下一步。
3、根據(jù)需求選擇自己的數(shù)據(jù)庫類型(一般默認(rèn))后,跳轉(zhuǎn)到全局?jǐn)?shù)據(jù)庫名這個(gè)畫面時(shí),重點(diǎn)來了:新建數(shù)據(jù)庫名稱不能和已經(jīng)存在的任何一個(gè)數(shù)據(jù)庫名稱相同。
4、在管理帳戶密碼界面,可以與別的數(shù)據(jù)庫管理帳戶密碼相同也可以不同,需注意的是,Oracle數(shù)據(jù)庫默認(rèn)是區(qū)分密碼大小寫的。
5、跳轉(zhuǎn)到Oracle內(nèi)存分配大小頁面,這里建議將Oracle內(nèi)存調(diào)整為物理主機(jī)內(nèi)存的70%。
6、點(diǎn)擊完成后,等待數(shù)據(jù)庫創(chuàng)建完成。
7、數(shù)據(jù)庫創(chuàng)建完成后,用sqlplus?語句連接數(shù)據(jù)庫,在同一服務(wù)器上建立多個(gè)Oracle數(shù)據(jù)庫操作完成。
oracle暫時(shí)沒有這個(gè)功能。
關(guān)于你說的“oracle分區(qū)表還是不能解決幾百億數(shù)據(jù)存量下的插入性能”是什么意思?是將數(shù)據(jù)插入這么多記錄的表上性能無法保證,還是太大并發(fā)會(huì)導(dǎo)致性能問題?
另外,如果你的并發(fā)不太大,而且還想實(shí)現(xiàn)分表,可以通過觸發(fā)器實(shí)現(xiàn)啊