<small id='jr5Fl'></small><noframes id='jr5Fl'>

<legend id='jr5Fl'><style id='jr5Fl'><dir id='jr5Fl'><q id='jr5Fl'></q></dir></style></legend>
      <i id='jr5Fl'><tr id='jr5Fl'><dt id='jr5Fl'><q id='jr5Fl'><span id='jr5Fl'><b id='jr5Fl'><form id='jr5Fl'><ins id='jr5Fl'></ins><ul id='jr5Fl'></ul><sub id='jr5Fl'></sub></form><legend id='jr5Fl'></legend><bdo id='jr5Fl'><pre id='jr5Fl'><center id='jr5Fl'></center></pre></bdo></b><th id='jr5Fl'></th></span></q></dt></tr></i><div id='jr5Fl'><tfoot id='jr5Fl'></tfoot><dl id='jr5Fl'><fieldset id='jr5Fl'></fieldset></dl></div>
      <tfoot id='jr5Fl'></tfoot>
      • <bdo id='jr5Fl'></bdo><ul id='jr5Fl'></ul>

      1. Mybatis执行多条语句/批量更新方式

        时间:2023-12-06

      2. <tfoot id='fi6tR'></tfoot>
          <bdo id='fi6tR'></bdo><ul id='fi6tR'></ul>

          <small id='fi6tR'></small><noframes id='fi6tR'>

            <legend id='fi6tR'><style id='fi6tR'><dir id='fi6tR'><q id='fi6tR'></q></dir></style></legend>
              <tbody id='fi6tR'></tbody>
            <i id='fi6tR'><tr id='fi6tR'><dt id='fi6tR'><q id='fi6tR'><span id='fi6tR'><b id='fi6tR'><form id='fi6tR'><ins id='fi6tR'></ins><ul id='fi6tR'></ul><sub id='fi6tR'></sub></form><legend id='fi6tR'></legend><bdo id='fi6tR'><pre id='fi6tR'><center id='fi6tR'></center></pre></bdo></b><th id='fi6tR'></th></span></q></dt></tr></i><div id='fi6tR'><tfoot id='fi6tR'></tfoot><dl id='fi6tR'><fieldset id='fi6tR'></fieldset></dl></div>

                  Mybatis是一款优秀的ORM框架,提供了多种方式执行SQL语句。当需要批量执行多条SQL语句或进行批量更新时,Mybatis提供了两种方式:batchforeach

                  1. Batch方式

                  Batch方式是将多条SQL语句打包成一条批量执行。在Mybatis中,一般使用SqlSession的Batch()方法来进行批量更新。

                  示例代码如下:

                  try (SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH)) {
                      UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
                      List<User> users = new ArrayList<>();
                      users.add(new User("user1", "password1"));
                      users.add(new User("user2", "password2"));
                      users.add(new User("user3", "password3"));
                      for (User user : users) {
                          userMapper.insert(user);
                      }
                      sqlSession.flushStatements();
                      sqlSession.commit();
                  }
                  

                  Batch方式需要将所有的SQL语句打包成一条批量执行,因此需要将所有需要执行的SQL语句先存储到集合中,再进行循环执行。由于Batch方式不支持返回结果集,因此需要手动在循环中获取执行的结果。

                  2. Foreach方式

                  Foreach方式则是利用循环批量执行多条SQL语句。在Mybatis中,可以使用foreach标签来实现批量执行某条SQL语句。

                  示例代码如下:

                  <!-- UserMapper.xml -->
                  <update id="updateUsers">
                      <foreach collection="users" item="user" separator=";">
                          UPDATE t_user
                          SET password=#{user.password}
                          WHERE username=#{user.username}
                      </foreach>
                  </update>
                  
                  try (SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH)) {
                      UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
                      List<User> users = new ArrayList<>();
                      users.add(new User("user1", "newPassword1"));
                      users.add(new User("user2", "newPassword2"));
                      users.add(new User("user3", "newPassword3"));
                      userMapper.updateUsers(users);
                      sqlSession.flushStatements();
                      sqlSession.commit();
                  }
                  

                  其中,collection指定了需要进行批量更新的集合,item指定集合中每个元素的别名,separator指定SQL语句之间的分隔符。在Java代码中,只需要调用Mapper接口中的方法即可进行批量更新。

                  总体来说,batch和foreach两种方式各有优缺点,需要根据实际的情况进行选择。Batch方式比较适合执行多条SQL语句,Foreach方式比较适合批量更新同一条SQL语句。

                  上一篇:MySQL慢sql优化思路详细讲解 下一篇:MybatisPlus查询条件为空字符串或null问题及解决

                  相关文章

                      <bdo id='jWcfM'></bdo><ul id='jWcfM'></ul>

                    <small id='jWcfM'></small><noframes id='jWcfM'>

                    <tfoot id='jWcfM'></tfoot>

                    1. <i id='jWcfM'><tr id='jWcfM'><dt id='jWcfM'><q id='jWcfM'><span id='jWcfM'><b id='jWcfM'><form id='jWcfM'><ins id='jWcfM'></ins><ul id='jWcfM'></ul><sub id='jWcfM'></sub></form><legend id='jWcfM'></legend><bdo id='jWcfM'><pre id='jWcfM'><center id='jWcfM'></center></pre></bdo></b><th id='jWcfM'></th></span></q></dt></tr></i><div id='jWcfM'><tfoot id='jWcfM'></tfoot><dl id='jWcfM'><fieldset id='jWcfM'></fieldset></dl></div>

                      <legend id='jWcfM'><style id='jWcfM'><dir id='jWcfM'><q id='jWcfM'></q></dir></style></legend>