[英]Using primary key from a sequence on hibernate
如何從Postgres序列中使用主鍵休眠? 我需要主要是自動生成的,他們如何獲得在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)。 怎么了? 謝謝
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.