posts - 495,  comments - 11,  trackbacks - 0

          直接上代碼吧:

          > Demo one
          public void batch_op_one() {

              session = Jorm.getSession();
              JdbcBatcher batcher = session.createBatcher();
              batcher.addBatch("delete from t_id_auto");
              batcher.addBatch("delete from t_incre");
              batcher.addBatch("delete from t_user");
              batcher.execute();
             
              session.beginTransaction();
              long start;
              try {
                  start = System.currentTimeMillis();
                  String sql = "INSERT INTO t_user(sex,age,career,name,id) VALUES(?,?,?,?,?)";
                  for (int i = 0; i < 100000; i++) {
                      batcher.addBatch(sql, new Object[] {"男", Numbers.random(98), Strings.random(10), Strings.fixed(6), (i+1) });}
                      String sqlx = "INSERT INTO t_id_auto(name, id) VALUES(?, ?)";
                      for (int i = 0; i < 100000; i++) {
                          batcher.addBatch(sqlx, new Object[] {Strings.fixed(6), (i+1)});
                          if(i > 200) {
                              //Integer.parseInt("kkk");
                          }
                      }
                      batcher.execute();   
                      System.out.println(System.currentTimeMillis() - start);
              } catch (Exception e) {
                  session.rollback();
              } finally {
                  session.endTransaction();
                  session.close();
              }
          }

          > Demo two
          public void batch_op_two() {

              session = Jorm.getSession();
              session.beginTransaction();
              session.clean(User.class);
              JdbcBatcher batcher = session.createBatcher();
              batcher.setBatchSize(500);// 指定每批處理的記錄數
             
              User u;
              int times = 20 * 100;
              long start = System.currentTimeMillis();
              for(int i = 0; i < times; i++) {
               String sex = (i % 2 == 0 ? "男" : "女");
               u = new User(Strings.fixed(6), sex, Numbers.random(100), Strings.random(16));
               batcher.save(u);
              }
              batcher.execute();
              session.endTransaction();
              long cost = (System.currentTimeMillis() - start);
              System.out.println("Total:" + cost);
              System.out.println("Each:" + (float) cost / times);
              session.close();
          }

          項目地址:http://javaclub.sourceforge.net/jorm.html
          下載地址: http://sourceforge.net/projects/javaclub/files/jorm/

          posted on 2011-10-09 20:09 jadmin 閱讀(1301) 評論(0)  編輯  收藏

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


          網站導航:
           
          主站蜘蛛池模板: 正宁县| 寻乌县| 双桥区| 延安市| 庄浪县| 石台县| 浦北县| 阿克苏市| 海南省| 兴义市| 本溪市| 正蓝旗| 普陀区| 公安县| 达州市| 淳化县| 桐庐县| 和龙市| 林州市| 广丰县| 诸城市| 全南县| 宝山区| 杨浦区| 安国市| 嵊州市| 银川市| 合山市| 乐平市| 兰坪| 嘉禾县| 塘沽区| 凤庆县| 丹阳市| 栾川县| 茌平县| 鄂州市| 汤原县| 永定县| 博罗县| 汉中市|