我用ssh,但是有一些很复杂的查询需要用到sql,我写了如下方法:String sql = "select * from user";
Session s = this.getHibernateTemplate().getSessionFactory().openSession();
Query q = s.createSQLQuery(sql);
List<User> list = q.list();
for(int i=0;i<list.size();i++)
{
    System.out.println(list.get(i));
}User是一个普通的类,里面有id,name等属性。我执行方法输出的是:
[Ljava.lang.Object;@1ac1e22
[Ljava.lang.Object;@ee6ad6
[Ljava.lang.Object;@a826da
[Ljava.lang.Object;@18ed77a
[Ljava.lang.Object;@e496ab如果System.out.println(list.get(i).getId());会报异常,请问怎么能输入User里的属性的值

解决方案 »

  1.   

    调试一下
    看看有没有加载User的属性
      

  2.   

    查询出来的结果list是个object数组。要用((Object[])list.get(i))[1]访问。
      

  3.   

    是不是在.hbm.xml将lazy配置成了true?
    这是懒加载.
      

  4.   

    方案一:
    String sql = "select {u.*} from user u";
    Session s = this.getHibernateTemplate().getSessionFactory().openSession();
    Query q = s.createSQLQuery(sql).addEntity("u",User.class);
    List<User> list = q.list();
    for(int i=0;i<list.size();i++)
    {
        System.out.println(list.get(i));
    }
    方案二:  直接用hql="from user";   s.createQuery();
      

  5.   

    List<Object []> list = query.list();
    if(list.size()>0){
      for(Object obj [] : list){
        System.out.println(obj[0].toString());
        System.out.println(obj[1].toString());
      }
    }
      

  6.   

    你可以传一个User变量进List集合当中,然后用list.get(i)取出来的值用User定义的一个变量来接收,然后比如你要取ID出来,User.getId();不是就可以了,如果你的数据比较少的话,或者查找某条数据的ID的话,你可以这样子试试,不过SQL语句的后面就要加上where条件了.
      

  7.   

    用原生态sql查询的时候 返回的结果是Object[] 类型的 需要另外转换下
      

  8.   

    LZ可能要这样做:
    List list = q.list();
    List<User> listUser = new ArrayList<User>();
    for(int i=0;i<list.size();i++)
    {
        Object[] obj = list.get(i);
        User user = new User();
        user.setId(obj[0]);
        user.setUsername(obj[1]);
        // ...  
        
        listUser.add(user);   
    }
      

  9.   

    System.out.println(((User)list.get(i)).getId());
      

  10.   

    你那个是object 当然 不能。get了你要强制装换类型才可以的
      

  11.   


    强制转换下就可以了
    System.out.println(((User)list.get(i)).getId());//默认是object对象,转换成User
      

  12.   

    String sql = "select * from user";
    Session s = this.getHibernateTemplate().getSessionFactory().openSession();
    List<User> list = s.createSQLQuery(sql).addEntity(User.class).list();
    for(User user : list)
    {
        System.out.println(user.getUserName());
    }OK了
      

  13.   


    报如下的错误:
    java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to com.test.bean.User
    at com.test.dao.impl.UserDAOImpl.test(UserDAOImpl.java:52)
    at com.test.dao.impl.UserDAOImplTest.test(UserDAOImplTest.java:14)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:73)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:46)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:180)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:41)
    at org.junit.runners.ParentRunner$1.evaluate(ParentRunner.java:173)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:220)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:46)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
      

  14.   

    问题解决了
    List<User> list = s.createSQLQuery(sql).addEntity(User.class).list();
    这样写才有效,有几位解答者说要修改为System.out.println(((User)list.get(i)).getId());
    我试过了,还是无效。
      

  15.   

    我这里要用到sql,而不是hql,本人才疏学浅,一般的sql可以改写为hql,复杂的sql实在没能力改成hql
      

  16.   

    我的总该给分吧。顺便告诉你,sql查出来的不象hql,hql查出来的象Map的存储方式是键值对的,sql查出来的只有值,不论你怎样转换都不行的。只有用
    List<User> list = s.createSQLQuery(sql).addEntity(User.class).list();这样才行。、
      

  17.   

    抱歉,没看见已经给过分了,其实本次来不是来要分的,主要看你解决问题没有,多看看Hibernate帮助很容易解决的。