使用hibernate时候id自动增长的错误

linyukai 2007-04-02 03:51:31
错误提示如下:
ids for this class must be manually assigned before calling save()

这种错误的原因是什么?在hibernate下数据库表不能设置自动增长的id吗?
解决方法是什么?如果我需要这么一个自动增长的建值
...全文
704 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
gwu0318 2007-04-03
  • 打赏
  • 举报
回复
用native
HappinessBoy 2007-04-02
  • 打赏
  • 举报
回复
mark!
ananroad 2007-04-02
  • 打赏
  • 举报
回复
<generator class="" />
generator有很多属性
increment是hibernate自己给你自动增长
它先用select max(id) from table;
然后在这个基础上加1
native是根据你使用的数据库来进行,具体的不是很清楚
identity是你在数据库建立表的时候设置了自动增长就用这个,像mysql和sqlserver
还有sequence 针对使用序列进行增长的oracle
huoyanshi 2007-04-02
  • 打赏
  • 举报
回复
我用native就可以
imA 2007-04-02
  • 打赏
  • 举报
回复
不是,是改为:
<generator class="increment" />
imA 2007-04-02
  • 打赏
  • 举报
回复
<generator class="identity" />

改为
<generator class="assigned " />
试试

67,550

社区成员

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

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