淺談 [Ljava.lang.Object 異常

來源:互聯網
上載者:User

初學者使用hibernate執行查詢的時候,很容易遇到結果集的類型轉換問題,所以明確“執行結果”裡的資料類型很重要。下面有兩小例子:

(1):使用HQL進行條件查詢。此結果集List包含的是對象數組,其中對象數組的索引0位置是Dept對象,該對象數組的長度取決於參與的表的個數。

 

 

    Session session = HibernateSessionFactory.getSession();

 

Query q = session.createQuery("from Dept d where d.dept is not null");

List<Object> list = query.list();//List包含的是對象數組

for(int i = 0 ; i < list.size(); i ++){//迴圈列印Dept的屬性值

Object [] obj = (Object [])list.get(i);//obj中儲存的是查詢出的對象

Dept d = (Dept)obj[0];//索引0位置是Dept對象

System.out.println(d.getDname() );

}

 

    HibernateSessionFactory.closeSession();

(2):使用SQL進行條件查詢。此結果集List包含的也是對象數組,不同的是對象數組索引0位置是Dept對象的第一個屬性,該對象數組的長度取決於Dept表的屬性的多少。

    Session session = HibernateSessionFactory.getSession();

 

Query q = session.createSQLQuery("select * from DEPT where FatherNo is not null"); 

List<Object> list = q.list();

for(int i=0;i<list.size();i++){

Object[] obj = (Object[])list.get(i);//obj中儲存的是查詢出的對象的屬性值

for(int j = 0 ; j < obj.length; j ++){//迴圈列印Dept的屬性值

System.out.print(obj[j] + "/t");

}

System.out.println("/n");

}

 

    HibernateSessionFactory.closeSession();

 

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.