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

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


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

    常用鏈接

    留言簿

    隨筆檔案

    文章檔案

    相冊

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 精品亚洲一区二区三区在线观看| 亚洲第一成年免费网站| 亚洲精品高清一二区久久| 中文免费观看视频网站| 三级黄色在线免费观看| 国产亚洲欧美在线观看| 亚洲一级毛片免费观看| 亚洲国产精品线在线观看| 青青草原亚洲视频| 亚洲精品乱码久久久久久不卡| 成人毛片免费视频| AV无码免费永久在线观看| 午夜精品射精入后重之免费观看| 精品乱子伦一区二区三区高清免费播放| 亚洲精品久久无码| 四虎必出精品亚洲高清| 亚洲中文字幕人成乱码| 久久久久亚洲av无码专区喷水| 日本亚洲视频在线| 伊人久久大香线蕉亚洲| 精品国产日韩亚洲一区| 亚洲乱码国产一区网址| 亚洲国产精品专区在线观看| 国产视频精品免费| 国产高清在线免费视频| 日日夜夜精品免费视频| 免费毛片在线视频| 小小影视日本动漫观看免费| 性做久久久久免费看| 又粗又硬又黄又爽的免费视频| 国产zzjjzzjj视频全免费 | 久久精品国产亚洲AV麻豆不卡| 亚洲午夜av影院| 久久亚洲AV无码西西人体| 精品国产亚洲男女在线线电影| 国产成人99久久亚洲综合精品 | 国产成人精品免费视频大全| eeuss影院www天堂免费| 国内少妇偷人精品视频免费| 久久国产免费一区二区三区| **aaaaa毛片免费同男同女|