转:

mybatis如何遍历Map的key和value

2017年11月28日 10:07:57 Joker_Ye 阅读数:4158
 

1.sql.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  3. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  4. <!--namespace必须是接口的全类名 -->
  5. <mapper namespace="com.genius">
  6.  
  7. <!-- 1.0 查询表结构是否存在 -->
  8. <select id="selectOne" parameterType="java.util.HashMap"
  9. resultType="java.util.HashMap">
  10. select count(*) as num from ${tableName} where seq =
  11. #{seq};
  12. </select>
  13.  
  14. <!-- 1.1 插入一条数据 -->
  15. <insert id="insertOne" parameterType="java.util.Map">
  16. insert into ${tableName}
  17. <foreach collection="content.keys" item="key" open="(" close=")"
  18. separator=",">
  19. ${key}
  20. </foreach>
  21. values
  22. <foreach collection="content.values" item="value" open="("
  23. close=")" separator=",">
  24. #{value}
  25. </foreach>
  26. </insert>
  27.  
  28. <!-- 1.2 更新记录 -->
  29. <update id="updateOne" parameterType="java.util.Map">
  30. UPDATE ${tableName} SET
  31. <foreach collection="content.keys" item="key" open="" close=""
  32. separator=",">
  33. ${key} = #{content[${key}]}
  34. </foreach>
  35. where seq = #{content[seq]} and genius_uid <=
  36. #{content[genius_uid]};
  37. </update>
  38.  
  39. <!-- 1.3 删除无效数据 -->
  40. <delete id="deleteOne" parameterType="java.util.Map">
  41. delete from ${tableName}
  42. where seq = #{content[seq]};
  43. </delete>
  44.  
  45. </mapper>

2.java代码:

  1. SqlSession session = MyBatisConnectionFactory.getSession("pg");
  2. HashMap<String, Object> params = new HashMap<>(); //传入的参数
  3. params.put("content", tableContent);
  4. params.put("tableName", tableName);
  5. params.put("seq", seq);
  6. int flag = session.delete("deleteOne", params); //删除记录
  7. HashMap<String, Object> map = session.selectOne("selectOne", params); //查询记录是否存在
  8. flag = session.update("updateOne", params) > 0 ? true : false; //更新
  9. flag = session.insert("insertOne", params) > 0 ? true : false; //新增

mybatis如何遍历Map的key和value【增删改查】的更多相关文章

  1. mybatis实战教程(mybatis in action)之三:实现数据的增删改查

    前面已经讲到用接口的方式编程.这种方式,要注意的一个地方就是.在User.xml  的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.I ...

  2. Mybatis的学习总结(一)——使用配置文件实现增删改查

    在使用Mybatis作为持久层来进行操作数据库,有很多的操作都是一样的,基本上都是先得到session,然后调用session提供的相关方法进行操作,接着提交session,最后关闭session.那 ...

  3. Mybatis学习(3)实现数据的增删改查

    前面已经讲到用接口的方式编程.这种方式,要注意的一个地方就是.在User.xml  的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.I ...

  4. Mybatis select、insert、update、delete 增删改查操作

    MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索.MyBatis 可以使用简单的XML ...

  5. 【MyBatis】-----【MyBatis】---表级联系【一对一】--增删改查

    一.核心配置文件 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration ...

  6. MyBatis学习(二)MyBatis-Statement方式的增删改查

    1.前期准备 项目骨架图如下所示 1.配置conf.xml <?xml version="1.0" encoding="UTF-8" ?> < ...

  7. Mybatis学习总结(二)—使用接口实现数据的增删改查

    在这一篇中,让我们使用接口来实现一个用户数据的增删改查. 完成后的项目结构如下图所示: 在这里,person代表了一个用户的实体类.在该类中,描述了相关的信息,包括id.name.age.id_num ...

  8. MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存

    二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...

  9. SpringMVC,MyBatis商品的增删改查

    一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ...

随机推荐

  1. ble ic

    ti cc25xxnordic nrf24xx nrf51xx nrf52xx Beken bk34xx

  2. Mark点

    MARK点是PCB应用于设计中的自动贴片机上的位置识别点,也被称为基准点.直径为1MM.钢网Mark点是电路板贴片加工中PCB印刷锡膏/红胶时的位置识别点.Mark点的选用直接影响钢网的印刷效率,确保 ...

  3. php正则表达式提取数字,字符串中提取数字

    <?php $str = "请注意:有谁知道30901.5号路怎么走?这个因为我买了100块的烧饼和7901的钥匙了,那个对了,我再拿个30000"; $pattern = ...

  4. 【经验分享】-PHP程序员的技能图谱

    一.技术知识积累作为参与工作一定年限的程序员,最重要的就是静下心来把遇到的和遗漏的知识点记录下来,做好学习和总结的准备.学习方面,除了看书上网查资料之外,实践也是非常重要的一点,很多不懂的或者不明白的 ...

  5. golang 数组之间的交集,差集,并集,补集

    今天公司需求两个数组之间的差集,类库下不下来,就独立出来了一份,希望读者有用 package model import ( "sort" "sync" ) ty ...

  6. 第八章 watch监听 83 名称案例-使用watch监听文本框数据的变化

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  7. 王道机试指南题解(C/C++版)

    第 2 章 经典入门 一 排序 例 2.1 排序 代码 2.1 冒泡排序(时间复杂度 \(O(n^2)\)) #include <iostream> using std::cin; usi ...

  8. CF888G Xor-MST[最小生成树+01trie]

    前注:关于这题,本人的解法暂时没有成功通过此题,原因是被卡常了.可能需要等待某种机缘来请人调试. 类似uoj的一道题(新年的繁荣),不过是一个有些简单的版本. 因为是完全图,有没有办法明显优化建边,所 ...

  9. 【模板】多标记 LCT

    代码如下 #include <bits/stdc++.h> using namespace std; typedef long long LL; const int mod = 51061 ...

  10. Oracle之:Function :dateToNumber()

    create or replace function dateToNumber(i_date in date) return number is result number ; begin resul ...