小方的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)  編輯  收藏 所屬分類: 開發經驗點滴

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


          網站導航:
           
          主站蜘蛛池模板: 昌乐县| 阿城市| 东港市| 正镶白旗| 鄂州市| 新化县| 会理县| 类乌齐县| 衡阳市| 商丘市| 密山市| 塘沽区| 钦州市| 丰镇市| 绥江县| 霍山县| 永济市| 临沭县| 响水县| 安化县| 龙岩市| 志丹县| 三河市| 莆田市| 韶关市| 宜宾县| 凤山市| 永清县| 盖州市| 绥棱县| 武夷山市| 宁乡县| 太白县| 黎平县| 仁寿县| 兴国县| 左云县| 会宁县| 澄江县| 铜陵市| 定边县|