小方的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 方佳瑋 閱讀(489) 評論(0)  編輯  收藏 所屬分類: 開發經驗點滴

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


          網站導航:
           
          主站蜘蛛池模板: 镇坪县| 阳朔县| 大姚县| 和硕县| 常熟市| 阳西县| 台中县| 科技| 贺兰县| 出国| 民权县| 兖州市| 武邑县| 荔波县| 杭州市| 德阳市| 乌拉特中旗| 观塘区| 明溪县| 富民县| 怀来县| 洛阳市| 叙永县| 司法| 临沂市| 甘洛县| 崇文区| 漠河县| 肇州县| 阜南县| 逊克县| 如皋市| 高尔夫| 会泽县| 宜宾县| 南宁市| 鸡东县| 临夏市| 县级市| 琼海市| 清水河县|