关于使用 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?