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插入数据库,单线程没问题,但是我开了两个线程之后就会出现这个问题,我按照网上的方法,添加了事物都不能解决问题

解决方案 »

  1.   

    null id in com.barewalls.entity.db.MImagedownloadinfo entry 应该是字段的问题
      

  2.   

    你查询的出来的对象MImagedownloadinfo没有主键值!?
      

  3.   

    MImagedownloadinfoDAO dao=new MImagedownloadinfoDAO();
      //session
      Session session=dao.getSession();
    能不能贴一下MImagedownloadinfoDAO 类,你有没有用ThreadLocal绑定session
      

  4.   

    你这个异常我第一次看见,但是原因我觉得应该和缓存有点关系don't flush the Session after an exception occurs
      

  5.   

    我也遇到了这样的问题,我一开始也以为是主键自增长的问题,在网上搜索了也没有找到真正的解决办法。后来,我考虑了,一下,可能是其他字段类型不匹配,导致的,具体原因为什么会报null id,我也不清楚。后来,把其他的字段都注释了,运行之后,可以插入。说明主键没有问题。然后一个一个测试,发现有个字段貌似类型匹配,然后就解决问题了。我不知道,兄弟,你的问题是不是,因为你的代码有限。你试试看!