zoukankan      html  css  js  c++  java
  • spring+hibernate中的Result object returned from HibernateCallback isn't a List

    Ok the problem is that for executeFind() the return type is List....so there is no way to use uniqueResult() within the callback from executeFind()...may be we should use execute()

    上面这段话来自http://forum.springframework.org/showthread.php?t=58370

    在使用executeFind方法时,如果返回的不是List类型的数据则会出现引异常

    例:
     public Integer findCount(final Class clazz,final String str) {
      return Integer.parseInt(getHibernateTemplate().executeFind(new HibernateCallback()
      {

       @Override
       public Object doInHibernate(Session session)
         throws HibernateException, SQLException {
        StringBuilder sb=new StringBuilder();
        sb.append("select count(*) from ");
        sb.append(clazz.getName());
        sb.append(" ");
        sb.append(str);
        log.info(sb.toString());
        return session.createQuery(sb.toString()).uniqueResult();
       }
       
      }).toString());
     }

    解决方法是把executeFind方法改为execute方法

     public Integer findCount(final Class clazz,final String str) {
      return Integer.parseInt(getHibernateTemplate().execute(new HibernateCallback()
      {

       @Override
       public Object doInHibernate(Session session)
         throws HibernateException, SQLException {
        StringBuilder sb=new StringBuilder();
        sb.append("select count(*) from ");
        sb.append(clazz.getName());
        sb.append(" ");
        sb.append(str);
        log.info(sb.toString());
        return session.createQuery(sb.toString()).uniqueResult();
       }
       
      }).toString());
     }

  • 相关阅读:
    【CSS】 布局之圣杯布局
    PHP函数
    spry菜单栏(二)
    正则表达式补充
    练习用php做表格
    PHP入门
    MySQL常用函数
    数据库习题
    总结
    Navicat
  • 原文地址:https://www.cnblogs.com/henuyuxiang/p/4273079.html
Copyright © 2011-2022 走看看