繁体   English   中英

JPA并插入表的分区

[英]JPA and insert into partition of table

我在 PostgreSQL 中有一个 TABLE,其中有 n 个分区(TABLE_1、TABLE_2、...、TABLE_n)。 有一个触发器,当你插入表 TABLE 时,将数据插入到一个分区中。 扳机:

IF (NEW.program_id=1) THEN INSERT INTO st.table_1 VALUES (NEW.*);
        ELSIF (NEW.program_id=2) THEN INSERT INTO st.table_2 VALUES (NEW.*);
 ....
return NEW;

我有一个对象:

@Entity
@Table(name = "TABLE", schema = "st")
public class TABLE implements Serializable {


@Getter
@Setter
@Column(name = "id", nullable = false, insertable = false, columnDefinition = "integer auto_increment")
private Integer id;


@Getter
@Setter
@Column(name = "program_id", nullable = false)
private Integer programId;

.... }

我有一个 JpaRepository:

public interface TableRepository extends JpaRepository<TABLE, Integer> {}

所以,当我保存对象表时:

TableRepository.save(myTable);

记录重复...多个表TABLE中的一条记录,分区中的第二条记录...

如何制作仅在分区中的记录?

更新。

例如我的@SQLInsert

@SQLInsert(sql = "INSERT INTO store.invoice(id,program_id,db_id,acs_number,is_active,date_doc,summa,is_entry," +
             "invoice_type_id,from_id,to_id,from_req_id,to_req_id,agent_id,offic,bn,date_create,date_update," +
             "offic_number,comment,date_ship,is_edited,store_rule_id,inv_cc_days,fact_date_doc,update_id,store_doc," +
             "order_num,parent_num,addition_num,user_create,user_update,place_id,type_data_col_id,contract_id," +
             "delivery,cert_num,uid,original_uid,date_return,reason_get_back_id,entry_night,send_stm,time_send_stm," +
             "invoice_type_for_1c,isa_id,isa_status_id,uid_ishop_id,delivery_ag_id,fraction_offic_number," +
             "forwarder_id,declarant_id,ext_locked,declarant_employee_num,revision_id,src_doc_sum,op_num," +
             "is_factoring,is_add_2amounts,is_load_2isa,num_sf,id_from_1c)" +
             "VALUES(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)", check = ResultCheckStyle.NONE)

该错误不在JPA中,而是在您的触发器中: return NEW; 将始终执行原始INSERT ,您只想在触发器中执行INSERT

你应该使用return null; 相反,取消原来的INSERT INTO TABLE

Como mencionado 前门

Na 触发器,返回 nulo:返回 null;

e na entidade, insera o @SQLInsert

Funcionando em Sprint 引导 2

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM