小方的Java博客

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            27 隨筆 :: 17 文章 :: 115 評論 :: 0 Trackbacks

          1.有個大大提高性能的建議:

          比如得到list 是5個班級,然后要得到5個班級的所有學生

          垃圾辦法:5次通過級聯獲得,等于執行5條sql語句

          好辦法:

          this .getSession().createQuery(
          ????????
          " from?User?a,Clazz?b?where?a.clazz=b?and?b?in(:clazz) " )
          ?.setParameterList(
          " clazz " ,?list)
          ?.list();

          僅執行一條


          2.還有個很實用的方法,如何通過hql語句返回多個po

          List?list? = ? this .getSession().createQuery(
          ?
          " from?User?a,Clazz?b?where?a.clazz=b " ).list();

          // 使用的時候:
          Iterator?it? = ?list.iterator();
          ??
          while (it.hasNext()){
          ?Object[]?vo?
          = ?(Object[])it.next();
          ?User?user?
          = ?(User)vo[ 0 ];
          ?Clazz?clazz?
          = ?(Clazz)vo[ 1 ];
          ?System.out.println(user.getUserName()?
          + ? " , " ? + ?clazz.getClassName());
          }?


          3.我們全部用一對一,多對一等。如果過濾有問題,有個辦法

          List?students? = ? this .getSession().createFilter(clazz.getStudents(), " where?this.status='A' " ).list();?
          posted on 2007-02-14 23:30 方佳瑋 閱讀(494) 評論(0)  編輯  收藏 所屬分類: 開發經驗點滴

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


          網站導航:
           
          主站蜘蛛池模板: 瑞丽市| 龙胜| 商水县| 苏尼特右旗| 本溪市| 海林市| 灵宝市| 永定县| 应城市| 邛崃市| 玉溪市| 彭山县| 延长县| 琼中| 翼城县| 高清| 安义县| 海林市| 营口市| 民丰县| 万源市| 襄樊市| 西藏| 米易县| 呼伦贝尔市| 屯门区| 濮阳县| 府谷县| 滁州市| 昌吉市| 高邮市| 瓮安县| 拜泉县| 衡阳县| 玉门市| 兴安盟| 和龙市| 祁东县| 大冶市| 灌阳县| 襄城县|