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

请教个关于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条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog