<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 64,  comments - 9,  trackbacks - 0
    原來的查詢語句:

    Java代碼
    1. String sql = "select a.* from tb_doc_catalog a where a.cat_code like '"+catCode+"%'";   
    2. Session session = this.getSession();   
    3. try {   
    4. List catNameList = session.createSQLQuery(sql).list();   
    5. return catNameList ;   
    6. finally {   
    7. releaseSession(session); //釋放session   
    8. }  


    分析:原來是查詢出來的字段并不能自動轉換為bean對象。

    解決思路一(采用hql查詢):

    Java代碼
    1. String sql = "select a from DocCatalogInfo a where a.catCode like '"+catCode+"%'";   
    2. List catNameList =getHibernateTemplate().find(sql);   
    3. return catNameList ;  

    ok,測試一下發現沒問題,看來還是因為用原生sql查詢的原因,網上搜一下:createsqlQuery返回對象,看到一篇文章才覺悟到:

    解決思路二(采用原生sql查詢):
    Java代碼
    1. String sql = "select a.* from tb_doc_catalog a where a.cat_code like '"+catCode+"%'";   
    2. Session session = this.getSession();   
    3. try {   
    4. List catNameList = session.createSQLQuery(sql).addEntity(DocCatalogInfo.class).list();   
    5. return catNameList ;   
    6. finally {   
    7. releaseSession(session); //釋放session   
    8. }  


    又ok了。

    該篇文章也貼上來:
    hibernate 中createQuery與createSQLQuery兩者區別是:
    前者用的hql語句進行查詢,后者可以用sql語句查詢
    前者以hibernate生成的Bean為對象裝入list返回
    后者則是以對象數組進行存儲
    所以使用createSQLQuery有時候也想以hibernate生成的Bean為對象裝入list返回,就不是很方便
    突然發現createSQLQuery有這樣一個方法可以直接轉換對象
    Query query = session.createSQLQuery(sql).addEntity(XXXXXXX.class);
    XXXXXXX 代表以hibernate生成的Bean的對象,也就是數據表映射出的Bean。
    呵呵以后多注意,還是時不時的要看看hibernate各個對象方法的使用。

    還有另外一個相關的小細節應注意:
    比如有這樣一個po
    PO: User.class
    properties: userId,userName
    DDL: create table tuser (userid varchar(10),username varchar(20));
    當執行:
    session.createQuery("from User u").list()時生成的SQL:
      select userid,username from tuser;
    當執行:

    session.createQuery("from User u").iterator()時生成的SQL:
      
    select userid from tuser;
      
    可以看出list()一次將數據從數據庫中讀出直接填充到List中
      
    iterator()將數據的主鍵從數據庫中讀出,當循環這個Iterator時才添加執行:
      
    select userid,username from user where userid=?;把數據讀出。
    posted on 2009-09-11 14:13 super_nini 閱讀(1111) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    <2009年9月>
    303112345
    6789101112
    13141516171819
    20212223242526
    27282930123
    45678910

    常用鏈接

    留言簿

    隨筆檔案

    文章檔案

    相冊

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲成AV人片高潮喷水| 三级黄色免费观看| 自拍偷自拍亚洲精品第1页| 成人片黄网站色大片免费观看APP| 亚洲福利在线观看| 国产精品麻豆免费版| 中文字幕一区二区三区免费视频| 亚洲一区二区中文| 国产免费午夜a无码v视频| 无码国产精品一区二区免费3p | 国产产在线精品亚洲AAVV| 亚洲热妇无码AV在线播放| 一个人在线观看视频免费| 九九综合VA免费看| 久久精品亚洲AV久久久无码| 亚洲无码日韩精品第一页| 噼里啪啦电影在线观看免费高清| 拍拍拍无挡视频免费观看1000| 亚洲日韩中文字幕一区| 国产亚洲精品xxx| 国产男女猛烈无遮挡免费视频网站| 可以免费观看的国产视频| 自拍偷自拍亚洲精品播放| 亚洲精品美女久久久久9999| 久久久久久A亚洲欧洲AV冫| 日韩在线天堂免费观看 | 国产成人免费网站| a级毛片免费网站| 亚洲AV成人无码网站| 亚洲欧洲高清有无| 亚洲色婷婷六月亚洲婷婷6月| 免费涩涩在线视频网| 91精品视频免费| 午夜视频在线免费观看| 国产精品免费久久| 黄页网址大全免费观看12网站| 亚洲中文字幕无码av永久| 久久亚洲精品无码aⅴ大香| 亚洲日韩精品无码一区二区三区| 免费va人成视频网站全| 成人性生活免费视频|