java - 使用 hibernate 序列中的主键

标签 java hibernate postgresql

How can a use primary key in hibernate from Postgres sequence? 我需要自动生成主要对象,以及如何获取用于 Hibernate 的序列值

这是我的代码

映射类

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...
}

我的 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());
    }
  }

}

数据库中没有任何反应(Postgres 8.3)。 怎么了? 谢谢

最佳答案

你为你的 id 定义了一个类型为 sequencegenerator

Hibernate 将为您处理 id 分配。

可以找到有关 ID 和生成器的更多信息 here

关于java - 使用 hibernate 序列中的主键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5466725/

相关文章:

java - skip() 方法是短路操作吗?

java - 使用 KeyStroke 进行输入,是否有更简单的方法来读取 A - Z 键?

python - 在 SQL 查询中使用变量

java - Hibernate - 在运行时更改连接字符串

php - postgres 中一些带双引号的列和一些不带双引号的列

postgresql - 为什么 postgres date_trunc 返回 24 小时?

java - 无法添加到 map

java - 如何使用gradle为servlet创建MANIFEST.MF文件?

java - 如何在 Sql Server 2000 上使用 Hibernate 调用存储过程?

java - Hibernate/JPA 如何修复子类错误生成数据库表