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 |
我的道:
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(); |
第一次部署应用时,在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 配置了事务管理器或在调用 insertPerson 的服务上定义了 @Transactional?
来源:https://www.codenong.com/8645474/