Gab*_*son 20 java mysql hibernate
我正在努力学习Hibernate的工作原理,并且我遇到了几乎无法接受的学习曲线.我看不出如何让Hibernate尊重我的对象的auto_increment策略.相反,它使用现有ID覆盖数据库中的条目,从1开始.
我有一个简单的Foo
对象,由如下定义的MySQL表支持:
CREATE TABLE `Foo` (
`fooId` int(11) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (`fooId`),
)
Run Code Online (Sandbox Code Playgroud)
我已经确认用SQL(insert into Foo values();
)手动插入多个Foo对象是正确的.
我的Java类使用如下注释指定了ID:
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="fooId")
private Integer id;
Run Code Online (Sandbox Code Playgroud)
然后我执行一些测试代码,简单地实例化Foo对象并将它们保存到数据库中(使用session.save(obj)
).它似乎使用自己的主键序列,从一开始,并没有查看表的关键策略.它会覆盖那里的一切.
我已尝试过该@GeneratedValue
位的变体(使用所有可能的策略,不考虑括号子句).有人甚至建议GeneratedValue
完全放弃.似乎没什么用.
我要留下什么了?我错过了什么?Hibernate真的很难吗?
(如果有人有另一种Java数据库持久性选项,请建议一个.我正在制作原型,而不是长期的mondo工程项目.)
Cli*_*int 29
我相信你想要的GenerationType.IDENTITY
.MySql不使用表或序列来生成Id值.
我在接受的答案下的评论中写了这个,但默认情况下没有显示,所以我会重新发布它作为答案.
我在一些家伙的网站上使用了一个hibernate.cfg.xml文件,它有这个:
<property name="hibernate.hbm2ddl.auto">create</property>
Run Code Online (Sandbox Code Playgroud)
这使得系统每次运行我的应用程序时都会重新创建我的表.评论它解决了这个问题.
关于创建ID的各种方法的另外两个答案是正确的.我的原始问题的症状似乎与ID生成有关,但实际原因是配置错误.
归档时间: |
|
查看次数: |
33805 次 |
最近记录: |