Oracle 11g 虛擬列子分區實驗sql
如下兩個create 語句均爲建立成功;less
需求描述:ide
項目要求對3個字段進行分區,如時間,小時,還有個區域ID,便聯想到虛擬列。spa
drop table test_part purge; create table test_part (t_time date, hour number, city_id number, hour_city varchar2(108) GENERATED ALWAYS AS(to_char(hour)||'|'||to_char(city_id))) partition by range(t_time) subpartition byhash(hour_city) (partition part_201705 values less than(to_date('20170601', 'yyyymmdd')) (subpartition subpart_201705_01, subpartition subpart_201705_02), partition part_201706 values less than (to_date('20170701', 'yyyymmdd')) (subpartition subpart_201706_01, subpartition subpart_201706_02)) create table test_part (t_time date, hour number(2), city_id number, day_hour varchar2(50) GENERATED ALWAYS AS (to_char(t_time,'yyyymmdd')||'|'||to_char(hour))) partition by range(day_hour) subpartition byhash(city_id) (partition part_201705 values less than('2017060100') (subpartition subpart_201705_01, subpartition subpart_201705_02), partition part_201706 values less than ('2017070100') (subpartition subpart_201706_01, subpartition subpart_201706_02))