关闭

springMVC 接收数组参数,springMVC mybatis批量增删改操作

标签: spring mvcmybatis
2168人阅读 评论(0) 收藏 举报
分类:

案例是给一个用户赋予多个权限,多个权限用其对应的主键 id 为参数,组成了 一个id数组,传给springMVC,然后springMVC传给mybatis,然后mybatis批量插入。其实类似的场景还有批量删除多个,也是类似的。

1. 前台页面

        <thead><tr><th>权限选择</th><th>name</th><th>permission</th></tr></thead>
                  <c:forEach var="priv" items="${list }">
                       <tr class="odd gradeX">
                      <td><input type="checkbox" name="priv_id" value="${priv.id}" /></td>
                      <td><c:out value="${priv.name}"/></td>
                      <td><c:out value="${priv.permission}"/></td>
                    </tr>
                  </c:forEach>

2. jquery获得选中的项的id值:

//jquery获取复选框值    
  var priv_ids =[];//定义一个数组    
  $('input[name="priv_id"]:checked').each(function(){    // 遍历每一个name为priv_id的复选框,其中选中的执行函数    
      priv_ids.push($.trim($(this).val()));    // 将选中的值添加到数组priv_ids中    
  });
  console.log(priv_ids);
  var indata = {userId:user_id, privIds:priv_ids};
  $.post("/ems/priv/setPrivilege", indata, function(data){
      if(data != null && data.result == 'ok'){
          console.log(data.msg);
          alert(data.msg);
      }else{
          alert(data.msg);
      }
  }, 'json');

提交的json格式的数据: var indata = {userId:user_id, privIds:priv_ids};

其中的 priv_ids 是一个有 id 组成的数组。

3. springMVC接收数组参数:

@RequestMapping(value="/setPrivilege")
@ResponseBody
public void setPrivilege(@RequestParam(value = "privIds[]") Integer[] privIds, Integer userId, PrintWriter writer){
  System.out.println(JSON.toJSONString(privIds));
  System.out.println(JSON.toJSONString(userId));
  int result = this.privilegeService.setPrivilegeForUser(privIds, userId);
  System.out.println("result=" + JSON.toJSONString(result));
  Map<String, String> map = new HashMap<>();
  if(result > 0){
    map.put("result", "ok");
    map.put("msg", "设置成功");
    writer.write(JSON.toJSONString(map));
  }
}

我们看到使用了: @RequestParam(value = "privIds[]" ) Integer[] privIds 来获取前台传来的数组参数。

springMVC接收参数时,最好不要使用 int, long等原始类型,而应该使用它们对应的包装类型,不然当传入的参数为空时,会报错,而包装类型可以使用null表示传入的空值。

4. service层的处理,很简单,直接使用map向mybatis传递参数:

@Service("privilegeService")
@Transactional
public class PrivilegeServiceImpl implements PrivilegeService {
  @Autowired
  private PrivilegeMapper privilegeMapper;
  @Override
  @Transactional(readOnly=true)
  public List<Privilege> getAllPrivilege() {
    return privilegeMapper.getAllPrivilege();
  }
  @Override
  public int setPrivilegeForUser(Integer[] privIds, Integer userId) {
    Map<String, Object> map = new HashMap<>();
    map.put("privIds", privIds);
    map.put("userId", userId);
    return this.privilegeMapper.setPrivilegeForUser(map);
  }
}

5. 最后看 mybatis 的 xml 中的sql如何写:

<insert id="setPrivilegeForUser" parameterType="map">
      insert into user_privilege(user_id, privilege_id) values 
      <foreach collection="privIds" index="index" item="item" separator=",">
          ( #{userId}, #{item} )
      </foreach>
  </insert>

我们看到使用了 foreach 来循环传递进来的数组 privIds ,最后组成的sql语句如下所示:

insert into user_privilege(user_id, privilege_id) values (3, 1),(3,2),(33),(3,4)

user_id 不变,而privilege_id 是数组 privIds 中的循环出来的 id 值。其实就是数据库的批量插入。

6. 批量删除多个的处理

删除时,和前面批量插入处理也是极其类似的,只在最后mybatis中xml中sql的写法有点区别:

<delete id="deleteByIds" parameterType="java.util.List">
      delete from user_privilege where id in
      <foreach collection="list" index="index" item="item" open="(" separator="," close=")">   
        #{item}   
      </foreach>  
  </delete>

比较批量删除和批量插入,可以看出 foreach 中的 open="(" 和 close=")" 只在循环的开始和结束会加上 ,而 separator="," 是每循环一次,就加一次逗号 

7. 批量插入传入对象List的例子:

<insert id="batchInsertStudent" parameterType="java.util.List">  
    insert into student (id,name,sex,tel,address) values
    <foreach collection="list" item="item" index="index" separator="," >  
        (#{item.id},#{item.name},#{item.sex},#{item.tel},#{item.address})  
    </foreach>  
</insert>

其实掌握了 批量插入和批量删除,批量更新也是一样的。

---------------------------------------------------------------------------------------------------------------------------------------- 

如果您认为本教程质量不错,读后觉得收获很大,预期工资能蹭蹭蹭的往上涨,那么不妨小额赞助我一下,让我有动力继续写出高质量的教程。 
   ----------------------------------------------------------------------------------------------------------------------------------------                                                           

0
0
查看评论

springmvc+mybatis+ajax 批量插入数据

原文地址:https://my.oschina.net/u/2245029/blog/526848批量插入。AJAX发起请求,核心代码如下: var mids = new Array(); for (var i=0; i< rows.length; i++) { mids.pus...
  • wojiaoguchenghuanye
  • wojiaoguchenghuanye
  • 2017-04-18 10:19
  • 763

springmvc批量修改

jsp页面中: function updateUsers() { document.userList.action="${pageContext.request.contextPath}/editUserAllCommit"; document.userList.sub...
  • qq_25816185
  • qq_25816185
  • 2017-02-20 17:39
  • 971

spring springmvc mybatis 整合批量操作,批量更新,批量插入

1.批量插入 INSERT INTO CISHAN_SUBSIDY_ACCOUNT_RECHARGE_MONTH(BATCH_NO,ACCOUNT_ID,USER_ID, NAME,IDNO,MOBILE,MONTH_AMOUNT,CISHAN_CHANNEL_...
  • zl386119974
  • zl386119974
  • 2016-09-30 09:25
  • 5092

Spring data jpa批量插入和更新

1 public interface BatchDao { 2     public void batchInsert(List list); ...
  • wangshfa
  • wangshfa
  • 2014-05-28 11:38
  • 46826

jdbcTemplate高效批量插入和批量更新

个人学习web开发过程中的一些经验总结,希望这个博客能记录下我的成长历程,每天进步一点。 也希望跟大家共同学习,欢迎评论,转载请注明出处.......
  • Nifury
  • Nifury
  • 2016-06-17 10:25
  • 7971

mybatis执行批量更新batch update 的方法(oracle,mysql)

oracle和mysql数据库的批量update在mybatis中配置不太一样: oracle数据库: ? 1 2 3 4 5 6 7 8 9 10 11 update id="batchUpdate"  paramet...
  • mmm333zzz
  • mmm333zzz
  • 2015-04-26 12:14
  • 11253

poj 1005 I Think I Need a Houseboat

http://poj.org/problem?id=1005 pi=3.141593 168K 0MS #include #include using namespace std; int main(){ int i,n,z; double r2,x,y; scanf(&quo...
  • eunyeon
  • eunyeon
  • 2015-01-27 02:43
  • 156

SpringMVC获取表单批量提交数据

关键点:封装一个JavaBean的List原始JavaBean public class Person { //省略getter、setter,Serialiable接口实现,toString(),equals(),HashCode() private String username...
  • zhulidie
  • zhulidie
  • 2017-06-01 19:34
  • 1501

【java web】springMVC框架实现用多选框批量删除表数据功能

本功能是基于springMVC+mybatis框架实现的,实现过程如下: jsp代码: <input type="checkbox" id="subcheck" ...
  • m0_37459696
  • m0_37459696
  • 2017-06-06 23:06
  • 2839

Spring框架开发实现对商品列表的增删改查以及批量删除和批量修改

SpringMVC其实也是Spring的一个模块,只是有时候单独使用它的机会很多,所以习惯性的将它独立出来了,Spring本身是有很多模块的,当我从其官网看它的各个模块的时候就感受它的强大了。使用spring以后,我们可以将NEW这个功能放开交给Spring来处理,那么我们只需要使用注解就可以获得到...
  • zhou_shaowei
  • zhou_shaowei
  • 2017-03-11 09:56
  • 3251
    个人资料
    • 访问:349163次
    • 积分:4384
    • 等级:
    • 排名:第8136名
    • 原创:123篇
    • 转载:25篇
    • 译文:0篇
    • 评论:44条
    最新评论