关于使用 hibernate 插入记录:在 postgres db 中使用 hibernate-spring 插入记录。序列生成器问题 | 珊瑚贝

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 配置了事务管理器或在调用 insertPerson 的服务上定义了 @Transactional?


来源:https://www.codenong.com/8645474/

微信公众号
手机浏览(小程序)
0
分享到:
没有账号? 忘记密码?