简体   繁体   English

在休眠状态下使用序列中的主键

[英]Using primary key from a sequence on hibernate

How can a use primary key in hibernate from a Postgres sequence? 如何从Postgres序列中使用主键休眠? I need the primary be autogenerated, and them how i can get the sequence value for use in Hibernate 我需要主要是自动生成的,他们如何获得在Hibernate中使用的序列值

this is my code 这是我的代码

Mapped class 映射类

import java.io.Serializable;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
import javax.persistence.Temporal;

@Entity
@Table(name="ensaio")
public class Ensaio implements Serializable {

  @Id
  @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="ensaio_seq")
  @SequenceGenerator(name="ensaio_seq", sequenceName="ensaio_seq")
  @Column(name="ensaio_id")
  private long id;
  private String nome;
  @Column(nullable=false)
  private String modelo;
  private String site;
  @Temporal(javax.persistence.TemporalType.DATE)
  private Date datadoensaio;
  private int qtdeFotos;
  private String fotografo;

  getter and setters...
}

My DAO: 我的DAO:

import java.util.List;
import model.Ensaio;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import util.hibernate.HibernateUtil;

public class HEnsaioDAO {

  private Session session;
  private SessionFactory sessionFactory = HibernateUtil.getSessionFactory();

  public HEnsaioDAO() {
    session = sessionFactory.openSession();
  }

  public List<Ensaio> findAll(){
    Query query = session.createQuery("from Ensaio");
    return query.list();
  }

  public void insertEnsaio(Ensaio ensaio){
    session.save(ensaio);
  }

  //testing insertion
  public static void main(String[] args) {
    Ensaio e = new Ensaio();
    e.setModelo("Roberta Maria");
    e.setSite("dsestudio");
    e.setFotografo("Jose Sobrero");
    e.setNome("Dama das camelias");

    HEnsaioDAO dao = new HEnsaioDAO();

    dao.insertEnsaio(e);


    List<Ensaio> list = dao.findAll();
    for (Ensaio ensaio : list) {
      System.out.println(ensaio.getModelo());
      System.out.println(ensaio.getNome());
      System.out.println(ensaio.getFotografo());
    }
  }

}

Nothing happens in database (Postgres 8.3). 在数据库中什么也没有发生(Postgres 8.3)。 What wrong? 怎么了? Thanks 谢谢

You define a generator of type sequence for your id. 您可以为id定义类型sequencegenerator

Hibernate will handle the id assignation for you. Hibernate将为您处理ID分配。

More info on ids and generators can be found here 有关ID和生成器的更多信息,请参见此处

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

相关问题 从Oracle序列在Hibernate中将字符串作为主键 - String as Primary Key in Hibernate from oracle sequence 使用当前年份的JPA /休眠主键值序列 - JPA/Hibernate primary key value sequence using current year 将休眠类从基于序列的整数主键迁移到GUID主键,同时保留旧键以实现向后兼容? - migrating a hibernate class from a sequence based integer primary key to a GUID primary key while retaining the old keys for backward compatibility? SpringBoot-Hibernate-Mysql id 主键值序列使用@GeneratedValue 在我的所有域中共享 - SpringBoot-Hibernate-Mysql id primary key value sequence is shared in all of my domain using @GeneratedValue 如何在 spring 引导中使用 data.sql 添加主键,使用 hibernate 增强序列生成器策略 - How to add primary key using data.sql in spring boot with hibernate enhanced sequence generator strategy 从表中读取数据,其中使用休眠模式将主键合成 - Read data from table where primary key is composite using hibernate Hibernate使用数据库触发器填充主键 - Hibernate populate primary key using database trigger 使用GeneratedValue作为主键的Hibernate SaveOrUpdate - Hibernate SaveOrUpdate using GeneratedValue for primary key 使用@Embedded和@Id的Hibernate复合主键 - Hibernate composite primary key using @Embedded and @Id 如何使用休眠方式更新主键字段 - how to update fields of primary key using hibernate
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM