insert record with hibernate - spring in postgres db . Sequence generator issue
我试图在 postgres 数据库中插入一条记录,但插入失败。
当尝试选择数据时,选择工作正常,所以我想它不是弹簧hibernate配置错误
环境:Spring 3.1、Hibernate 3.6、Postgres 9.1
这是我的代码:
实体类:
1 2 3 4 5 6 7 8 9 10 11 12 13 | @Entity public class Person implements Serializable { @Id @COLUMN(insertable=FALSE, updatable=FALSE) @TYPE(TYPE="java.lang.Long") @GeneratedValue(strategy = GenerationType.SEQUENCE, generator="PERSON_SEQ") @SequenceGenerator(name="PERSON_SEQ", sequenceName="PERSON_SEQ", allocationSize=1) private Long id; @COLUMN private String firstName; } |
我的道:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | @Repository public class PersonDao extends BaseDao public void insertPerson(){ super.getHibernateTemplate().execute(NEW HibernateCallback() { @Override public Object doInHibernate(SESSION SESSION) throws HibernateException, SQLException { Person p = NEW Person(); p.setFirstName("george"); SESSION.persist(p); RETURN NULL; } }); } } |
第一次部署应用时,在postgres中创建一个新序列
1 2 3 4 5 6 7 8 | CREATE SEQUENCE person_seq INCREMENT 1 MINVALUE 1 MAXVALUE 9223372036854775807 START 1 CACHE 1; ALTER TABLE person_seq OWNER TO postgres; |
sql插入时hibernatesql输出为:
1 2 3 4 5 6 7 8 9 10 | Hibernate: SELECT NEXTVAL ('PERSON_SEQ') Hibernate: INSERT INTO Person (firstName, lastName, money, id) VALUES (?, ?, ?, ?) |
但它从不插入记录,即使序列增加 1
看起来该事务从未提交。
您是否使用 Spring 配置了事务管理器或在调用