iteye_5961 2010-03-12 09:38
浏览 259
已采纳

纠结了一晚上的问题!麻烦哪位帮忙解决一下!

我想从一张表中随机读取N条信息出来,并且将这N条数据的ID封装成String放到另一张表去。可是在循环封装ID的时候就报错,以至于自己不能解决了。报错信息为“java.lang.ClassCastException: [Ljava.lang.Object;”,小弟十分感谢,谢谢啦!
以下是我的具体代码:

这个是DaoImple的代码
[code="java"]
public List randWare(final Integer count) throws Exception{

    return (List<Ware>) this.getHibernateTemplate().execute(new HibernateCallback() {

        public Object doInHibernate(Session session)

        throws HibernateException, SQLException {

            String sql = "select * from ware order by rand() limit "+count+"";

            Query query = session.createSQLQuery(sql);

            return query.list();
        }
    });
}

[/code]

这个是ServiceImpl的代码:
[code="java"]
public String randWare(Integer count) throws Exception{

    List<Ware> list = wareDao.randWare(count);

    StringBuffer sb = new StringBuffer();

    for(Ware ware : list){

        sb.append(",");

        sb.append(ware.getId());
    }

    System.out.println("-------sb------"+sb);

    return sb.substring(1);
}

[/code]

  • 写回答

4条回答 默认 最新

  • 拽拽的初行者 2010-03-12 10:17
    关注

    [b]
    改为这样试试:(实体类的名称要改为全名称,即带有package名的)[/b]
    [code="java"]
    String sql = "select * from ware order by rand() limit "+count+"";
    Query query = session.createSQLQuery(sql).addEntity(Ware.class);
    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染