hibernate中SQL方言问题

SunCd3210oqq 2010-05-23 09:41:03
在关系映射配置文件中这样写:
<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吗?
...全文
135 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
qingzhe2008 2010-05-24
  • 打赏
  • 举报
回复
没用hibernate,帮顶
SunCd3210oqq 2010-05-24
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 lq282514781 的回复:]

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

这样和使用native一样的啊,最后生成的语句都是create table test(id integer identity not null,primary key(id));
问题就是不能生成identity型的id,而应该是auto_increment才可以。
SunCd3210oqq 2010-05-24
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 shizhijie737 的回复:]

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

是啊,理论上对于mysql数据库它就应该生成auto_increment型的id啊,但是,它却生成identity型的,所以mysql数据库就报错,说语法错误。
llf371755616 2010-05-24
  • 打赏
  • 举报
回复
用native策略是
需要在oracle中创建一个hibernate_sequence序列
lq282514781 2010-05-24
  • 打赏
  • 举报
回复
<class name="Test" table="test">
<id name="id">
<generator class="identity"></generator>
</id>
</class>
改成这样就好了
不善^ 2010-05-24
  • 打赏
  • 举报
回复
你用的mysql 么? 用id这个字段么?
加上这个试下 auto_increment
绿光 2010-05-24
  • 打赏
  • 举报
回复
native选择数据库默认的主键生成策略,不同数据库,默认策略不一样
ssszhangbo 2010-05-24
  • 打赏
  • 举报
回复
org.hibernate.dialect.MySQLDialect这是mysql 的配置

你说的那个native不是sql方言,native是相对于hql语句一类的查询语句来说的!

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧