org.hibernate.AssertionFailure: null id in异常

大龄程序员-Ricky 2010-10-11 03:00:31
pojo类的配置文件:
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="com.barewalls.entity.db.MImagedownloadinfo" table="m_imagedownloadinfo" catalog="postersfirst">
<id name="id" type="java.lang.Integer">
<column name="id" not-null="true"/>
<generator class="native" />
<!--<generator class="increment" />-->
</id>
<property name="imageurl" type="java.lang.String">
<column name="imageurl" length="200" unique="true"/>
</property>
<property name="downloadstate" type="java.lang.String">
<column name="downloadstate" length="20" />
</property>
</class>
</hibernate-mapping>

出问题的代码:
public List findByProperty(String propertyName, Object value) {
log.debug("finding MImagedownloadinfo instance with property: "
+ propertyName + ", value: " + value);
try {
String queryString = "from MImagedownloadinfo as model where model."
+ propertyName + "= ?";
Query queryObject = getSession().createQuery(queryString);
queryObject.setParameter(0, value);
return queryObject.list();
} catch (RuntimeException re) {
log.error("find by property name failed", re);
throw re;
}finally{
if(getSession().getCacheMode().isGetEnabled()){
getSession().flush();<-------------------------(出问题的地方)
getSession().clear();
}
}
}

执行代码:
private void saveOrupdateImageDownLoadState(String imageurl,String state){
//dao
MImagedownloadinfoDAO dao=new MImagedownloadinfoDAO();
//session
Session session=dao.getSession();
//映射类
MImagedownloadinfo m=new MImagedownloadinfo();
m.setImageurl(imageurl);
m.setDownloadstate(state);
//查找
List<MImagedownloadinfo> list=dao.findByImageurl(imageurl);();<------------------(出问题的地方)

if(list.size()!=0){
for(int i=0;i<list.size();i++){
dao.attachDirty(list.get(i));
}
}else{
try{
//开始事务
session.beginTransaction();
dao.save(m);
session.getTransaction().commit();
}catch(Exception e){
e.printStackTrace();
session.getTransaction().rollback();
}
}
}

异常:
Exception in thread "main" org.hibernate.AssertionFailure: null id in com.barewalls.entity.db.MImagedownloadinfo entry (don't flush the Session after an exception occurs)
at org.hibernate.event.def.DefaultFlushEntityEventListener.checkId(DefaultFlushEntityEventListener.java:78)
at org.hibernate.event.def.DefaultFlushEntityEventListener.getValues(DefaultFlushEntityEventListener.java:187)
at org.hibernate.event.def.DefaultFlushEntityEventListener.onFlushEntity(DefaultFlushEntityEventListener.java:143)
at org.hibernate.event.def.AbstractFlushingEventListener.flushEntities(AbstractFlushingEventListener.java:219)
at org.hibernate.event.def.AbstractFlushingEventListener.flushEverythingToExecutions(AbstractFlushingEventListener.java:99)
at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:49)
at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1028)
at com.barewalls.dao.MImagedownloadinfoDAO.findByProperty(MImagedownloadinfoDAO.java:119)
at com.barewalls.dao.MImagedownloadinfoDAO.findByImageurl(MImagedownloadinfoDAO.java:126)
at com.barewalls.content.util.DownLoadImage.saveOrupdateImageDownLoadState(DownLoadImage.java:108)
at com.barewalls.content.util.DownLoadImage.download(DownLoadImage.java:76)
at com.barewalls.test.content.util.TestDownLoadImage.main(TestDownLoadImage.java:32)

大家好,我通过hibernate插入数据库,单线程没问题,但是我开了两个线程之后就会出现这个问题,我按照网上的方法,添加了事物都不能解决问题
...全文
2140 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
BIGboy 2012-05-14
  • 打赏
  • 举报
回复
我也遇到了这样的问题,我一开始也以为是主键自增长的问题,在网上搜索了也没有找到真正的解决办法。后来,我考虑了,一下,可能是其他字段类型不匹配,导致的,具体原因为什么会报null id,我也不清楚。后来,把其他的字段都注释了,运行之后,可以插入。说明主键没有问题。然后一个一个测试,发现有个字段貌似类型匹配,然后就解决问题了。我不知道,兄弟,你的问题是不是,因为你的代码有限。你试试看!
assdust110 2010-12-09
  • 打赏
  • 举报
回复
你这个异常我第一次看见,但是原因我觉得应该和缓存有点关系don't flush the Session after an exception occurs
wzju64676266 2010-12-08
  • 打赏
  • 举报
回复
MImagedownloadinfoDAO dao=new MImagedownloadinfoDAO();
//session
Session session=dao.getSession();


能不能贴一下MImagedownloadinfoDAO 类,你有没有用ThreadLocal绑定session
zn85600301 2010-12-08
  • 打赏
  • 举报
回复
你查询的出来的对象MImagedownloadinfo没有主键值!?
Jlins 2010-12-08
  • 打赏
  • 举报
回复
null id in com.barewalls.entity.db.MImagedownloadinfo entry

应该是字段的问题
  • 打赏
  • 举报
回复 1
查看下是否是数据库关键字保留字的问题,如果你占用他就会报错。我刚遇到过

67,513

社区成员

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

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