<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 閱讀(1119) 評論(0)  編輯  收藏

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


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

    常用鏈接

    留言簿

    隨筆檔案

    文章檔案

    相冊

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲精品美女久久久久99小说| 无遮免费网站在线入口| 久久国产精品免费一区| 亚洲成人激情小说| 国产精品观看在线亚洲人成网| 亚洲人成www在线播放| 美女被免费网站在线视频免费| 亚洲视频无码高清在线| 男女啪啪免费体验区| 久久国产精品萌白酱免费| 黄色网址免费在线观看| 真实国产乱子伦精品免费| 日本一道综合久久aⅴ免费| 亚洲色精品vr一区二区三区| 亚洲国产精品美女| 老外毛片免费视频播放| 久久免费福利视频| 久久久久久国产精品免费免费男同 | 久久亚洲AV成人无码| 亚洲av无码偷拍在线观看| CAOPORN国产精品免费视频| 日韩免费精品视频| 色噜噜亚洲精品中文字幕| 国产av无码专区亚洲av果冻传媒 | 一级做a毛片免费视频| 99精品视频免费观看| 免费吃奶摸下激烈视频| 亚洲日本乱码一区二区在线二产线| 久久久久亚洲av无码专区喷水 | 亚洲第一成年人网站| 一级毛片免费全部播放| 午夜a级成人免费毛片| 亚洲AV无码国产精品色午友在线 | 亚洲人成网站免费播放| 97无码人妻福利免费公开在线视频 | 黑人粗长大战亚洲女2021国产精品成人免费视频 | 亚洲日韩欧洲无码av夜夜摸| 亚洲精品乱码久久久久久V | v片免费在线观看| 日韩a在线观看免费观看| 亚洲小视频在线播放|