<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. }  


    分析:原來是查詢出來的字段并不能自動轉(zhuǎn)換為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,測試一下發(fā)現(xiàn)沒問題,看來還是因為用原生sql查詢的原因,網(wǎng)上搜一下: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兩者區(qū)別是:
    前者用的hql語句進(jìn)行查詢,后者可以用sql語句查詢
    前者以hibernate生成的Bean為對象裝入list返回
    后者則是以對象數(shù)組進(jìn)行存儲
    所以使用createSQLQuery有時候也想以hibernate生成的Bean為對象裝入list返回,就不是很方便
    突然發(fā)現(xiàn)createSQLQuery有這樣一個方法可以直接轉(zhuǎn)換對象
    Query query = session.createSQLQuery(sql).addEntity(XXXXXXX.class);
    XXXXXXX 代表以hibernate生成的Bean的對象,也就是數(shù)據(jù)表映射出的Bean。
    呵呵以后多注意,還是時不時的要看看hibernate各個對象方法的使用。

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

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

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


    網(wǎng)站導(dǎo)航:
     
    <2009年9月>
    303112345
    6789101112
    13141516171819
    20212223242526
    27282930123
    45678910

    常用鏈接

    留言簿

    隨筆檔案

    文章檔案

    相冊

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 色拍自拍亚洲综合图区| 最新亚洲春色Av无码专区| 特级毛片A级毛片免费播放| 成人毛片免费网站| 久久久久久亚洲精品影院| www.黄色免费网站| 国产成人精品亚洲日本在线| 99国产精品永久免费视频| 女人让男人免费桶爽30分钟| 国产成人精品日本亚洲网址| 无码日韩精品一区二区免费| 亚洲视频无码高清在线| 真实乱视频国产免费观看| 精品亚洲视频在线| 免费A级毛片无码久久版| 成人免费夜片在线观看| 亚洲综合色婷婷七月丁香| 国产精品免费福利久久| 亚洲最大黄色网站| 女人让男人免费桶爽30分钟| 国产亚洲视频在线观看网址| 亚洲午夜久久久久妓女影院| 久久精品视频免费播放| 激情综合亚洲色婷婷五月| 免费国产成人高清视频网站| 2022国内精品免费福利视频| 亚洲嫩草影院久久精品| 毛片a级毛片免费播放下载| 免费看内射乌克兰女| 无码专区—VA亚洲V天堂| 亚洲成在人线aⅴ免费毛片| 男男gay做爽爽的视频免费| 亚洲深深色噜噜狠狠爱网站| 91av免费观看| 国产成人高清亚洲一区久久| 国产精品亚洲精品日韩已满| 美女黄频免费网站| 久久久久亚洲AV片无码| 最近中文字幕免费mv视频7| eeuss影院免费92242部| 亚洲丰满熟女一区二区v|