aiyust070
2011-11-04 11:57
浏览 295
已采纳

请教个关于hibernate中转化成EntityMode.DOM4J的问题

请教个问题,关于hibernate的

[code="java"]
public void getXmlCom(){

    Document doc = DocumentHelper.createDocument(); 

    //Element rootElement = doc.addElement("root");


    Session session = (Session) HibernateSessionFactory.getSession();
    //Session session = factory.openSession();
    Session dom4jSession = (Session) session.getSession(EntityMode.DOM4J);
    Transaction tx = session.beginTransaction();

    List results = dom4jSession
        .createQuery(" select m.f1,s.f2 from table1 m ,table2 s  where m.id=s.id and rownum < ? ")
        .setInteger(0 , 2)
        .list();
    for ( int i=0; i<results.size(); i++ ) {
        //add the customer data to the XML document
        Element customer = (Element) results.get(i);
        //rootElement.add(customer);
        doc.add(customer);
    }
    System.out.println(doc.asXML());
    tx.commit();
    session.close();
}

[/code]

这种情况下会出问题:如果把hql改成(select m.f1 from table1 m where rownum < ?)就没问题,怎么解释?
出错的行为:[code="java"]Element customer = (Element) results.get(i);[/code]

并不是说执行语句有问题
谁能解释下,谢谢各位

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

2条回答 默认 最新

  • iteye_17068 2011-11-04 16:35
    最佳回答

    你是要提取两个表吗? 一个对应一个实体嘛,只要你是a.* 就会封装成Object[]
    举例:select a.name,a.sex from tabl1 a;
    reult:Object[] = {a.name,a.sex}

    评论
    解决 无用
    打赏 举报
查看更多回答(1条)

相关推荐 更多相似问题