在关系映射配置文件中这样写:
 <class name="Test" table="test">
<id name="id">
<generator class="native"></generator>
</id>
 </class>
测试的时候报错,提示是语法错误,查看hibernate生成的建表语句,为:
create table test (id integer not null identity, primary key (id))
好像是identity出错,我的问题是:为什么会生成identity型的,不应该是auto_increment吗?

解决方案 »

  1.   

    org.hibernate.dialect.MySQLDialect这是mysql 的配置你说的那个native不是sql方言,native是相对于hql语句一类的查询语句来说的!
      

  2.   

    native选择数据库默认的主键生成策略,不同数据库,默认策略不一样
      

  3.   

    你用的mysql 么? 用id这个字段么?
    加上这个试下 auto_increment
      

  4.   

     <class name="Test" table="test">
    <id name="id">
    <generator class="identity"></generator>
    </id>
     </class>
     改成这样就好了
      

  5.   

    用native策略是
    需要在oracle中创建一个hibernate_sequence序列
      

  6.   


    是啊,理论上对于mysql数据库它就应该生成auto_increment型的id啊,但是,它却生成identity型的,所以mysql数据库就报错,说语法错误。
      

  7.   


    这样和使用native一样的啊,最后生成的语句都是create table test(id integer identity not null,primary key(id));
    问题就是不能生成identity型的id,而应该是auto_increment才可以。