在我和我的Eclipse苦苦挣扎数小时后,我希望你能在这里解答我的问题。希望在这里找到一些缓解。
我正在尝试通过Hibernate 3.0将一个pojo对象保存到MySQL数据库中。基本上我的要求是:在保存之前,我需要为对象分配id,而不是让Hibernate为我完成。
为此,我查阅了文档,并发现完全符合我的需求。因此,我更新了.hbm.xml文件中的id标签如下:
我的POJO对象完美地匹配了.hbm.xml文件。
我设置了所有的参数,包括我的POJO对象的ID,并调用了Hibernate的saveOrUpdate(object)方法。
如果有帮助的话,我的数据库表中的ID列已禁用“自动增量”。
难以置信的是,当我查看数据库表的内容时,一行被插入了Hibernate自己的ID,而不是我设置的ID。
这是怎么可能的?是否还有其他影响ID的因素?我是否漏掉了什么?有什么解决方法?
我的hibernate.properties如下(如果有帮助):
我正在尝试通过Hibernate 3.0将一个pojo对象保存到MySQL数据库中。基本上我的要求是:在保存之前,我需要为对象分配id,而不是让Hibernate为我完成。
为此,我查阅了文档,并发现完全符合我的需求。因此,我更新了.hbm.xml文件中的id标签如下:
<id name="id" type="int">
<column name="ID" />
<generator class="assigned" />
</id>
我的POJO对象完美地匹配了.hbm.xml文件。
我设置了所有的参数,包括我的POJO对象的ID,并调用了Hibernate的saveOrUpdate(object)方法。
如果有帮助的话,我的数据库表中的ID列已禁用“自动增量”。
难以置信的是,当我查看数据库表的内容时,一行被插入了Hibernate自己的ID,而不是我设置的ID。
这是怎么可能的?是否还有其他影响ID的因素?我是否漏掉了什么?有什么解决方法?
我的hibernate.properties如下(如果有帮助):
hibernate.connection.driver_class =com.mysql.jdbc.Driver
hibernate.dialect =org.hibernate.dialect.MySQLDialect
hibernate.connection.url =jdbc:mysql://localhost/dbdbdbdbdb
hibernate.connection.username=root
hibernate.connection.password=password
hibernate.connection.pool_size=10
jdbc.batch_size=30
hibernate.show_sql=true
hibernate.current_session_context_class=true
hibernate.hbm2ddl.auto=validate
hibernate.cglib.use_reflection_optimizer=false
hibernate.generate_statistics=true
hibernate.cache.use_query_cache=true
hibernate.cache.region.factory_class=net.sf.ehcache.hibernate.EhCacheRegionFactory