PostgreSql Partition + Hibernate Insert

來源:互聯網
上載者:User

標籤:before   sql   now()   pac   its   gui   blank   declare   批量   

與Oracle不同。PostgreSQL須要手動控制分區規則引發器。

步驟一:建立分區

CREATE TABLE table_partition_1( CHECK partition_column criteria) INHENRITS (table)

步驟二:為分區表建立PK跟index,這裡使用btree
ALTER TABLE ONLY table_partition_1 ADD CONSTRAINT table_partition_1_pkey PRIMARY KEY (key_column);

CREATE INDEX index_table_partition_1 ON table_partition_1  USING btree(column);

步驟三:手動建立觸發器
CREATE OR REPLACE FUNCTION before_insert_table()  RETURNS trigger AS$BODY$ DECLARE  BEGINif criteria  thenEXECUTE 'insert into appropriate table ...'  SELECT  ($1).* '  USING NEW;end if;return null;END;$BODY$  LANGUAGE plpgsql VOLATILE  COST 100;ALTER FUNCTION before_insert_table()  OWNER TO db;

rule在大量操作時更合適,可是對於單獨操作會佔用較大的開銷。

CREATE RULE table_partition_1 _insert AS(criteria ...)DO INSTEAD     INSERT INTO table_partition_1 VALUES (NEW.*)

步驟四:觸發器方式hibernate向分區插入資料時。獲得的result count為0,會導致推斷失敗而復原。

解決方案是使用rule,或者聲明分區插入時不進行result檢查。

@SQLInsert(sql = "INSERT INTO "+ "table(column,...)"+ " VALUES(?,...)", check = ResultCheckStyle.NONE)

在Java項目中。考慮到分區建立會採用job方式自己主動建立,能夠通過function完畢建立。

CREATE OR REPLACE FUNCTION "public"."function"()  RETURNS void AS $BODY$  DECLARE    _tablename text ;   quarter integer;record1 record;  BEGINselect function(now()) as quarter  into record1;  quarter := record1.quarter;_tablename := 'partition_name';PERFORM 1FROM   pg_catalog.pg_class cWHERE  c.relname = _tablename;IF FOUND <> TRUE THENEXECUTE 'CREATE TABLE ' || _tablename  || ' (        CHECK ( criteria)      ) INHERITS (table)';EXECUTE 'ALTER TABLE ' || _tablename  || ' OWNER TO db ';EXECUTE  ' alter table ' ||   _tablename || ' add CONSTRAINT  ' || _tablename||'_pkey  PRIMARY key (column) ' ;EXECUTE  ' CREATE INDEX ' || _tablename|| '_indexON '||  _tablename ||'USING btree(column)';   END IF;END$BODY$  LANGUAGE 'plpgsql' VOLATILE COST 100;ALTER FUNCTION "public"."function"() OWNER TO "db";



參考資料:entity-hibspec-customsql.html
postgresql-table-partitioning-hibernate.html


PostgreSql Partition + Hibernate Insert

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.