mybatis如何遍历Map的key和value【增删改查】
转:
mybatis如何遍历Map的key和value
1.sql.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
- <!--namespace必须是接口的全类名 -->
- <mapper namespace="com.genius">
- <!-- 1.0 查询表结构是否存在 -->
- <select id="selectOne" parameterType="java.util.HashMap"
- resultType="java.util.HashMap">
- select count(*) as num from ${tableName} where seq =
- #{seq};
- </select>
- <!-- 1.1 插入一条数据 -->
- <insert id="insertOne" parameterType="java.util.Map">
- insert into ${tableName}
- <foreach collection="content.keys" item="key" open="(" close=")"
- separator=",">
- ${key}
- </foreach>
- values
- <foreach collection="content.values" item="value" open="("
- close=")" separator=",">
- #{value}
- </foreach>
- </insert>
- <!-- 1.2 更新记录 -->
- <update id="updateOne" parameterType="java.util.Map">
- UPDATE ${tableName} SET
- <foreach collection="content.keys" item="key" open="" close=""
- separator=",">
- ${key} = #{content[${key}]}
- </foreach>
- where seq = #{content[seq]} and genius_uid <=
- #{content[genius_uid]};
- </update>
- <!-- 1.3 删除无效数据 -->
- <delete id="deleteOne" parameterType="java.util.Map">
- delete from ${tableName}
- where seq = #{content[seq]};
- </delete>
- </mapper>
2.java代码:
- SqlSession session = MyBatisConnectionFactory.getSession("pg");
- HashMap<String, Object> params = new HashMap<>(); //传入的参数
- params.put("content", tableContent);
- params.put("tableName", tableName);
- params.put("seq", seq);
- int flag = session.delete("deleteOne", params); //删除记录
- HashMap<String, Object> map = session.selectOne("selectOne", params); //查询记录是否存在
- flag = session.update("updateOne", params) > 0 ? true : false; //更新
- flag = session.insert("insertOne", params) > 0 ? true : false; //新增
mybatis如何遍历Map的key和value【增删改查】的更多相关文章
- mybatis实战教程(mybatis in action)之三:实现数据的增删改查
前面已经讲到用接口的方式编程.这种方式,要注意的一个地方就是.在User.xml 的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.I ...
- Mybatis的学习总结(一)——使用配置文件实现增删改查
在使用Mybatis作为持久层来进行操作数据库,有很多的操作都是一样的,基本上都是先得到session,然后调用session提供的相关方法进行操作,接着提交session,最后关闭session.那 ...
- Mybatis学习(3)实现数据的增删改查
前面已经讲到用接口的方式编程.这种方式,要注意的一个地方就是.在User.xml 的配置文件中,mapper namespace="com.yihaomen.mybatis.inter.I ...
- Mybatis select、insert、update、delete 增删改查操作
MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索.MyBatis 可以使用简单的XML ...
- 【MyBatis】-----【MyBatis】---表级联系【一对一】--增删改查
一.核心配置文件 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration ...
- MyBatis学习(二)MyBatis-Statement方式的增删改查
1.前期准备 项目骨架图如下所示 1.配置conf.xml <?xml version="1.0" encoding="UTF-8" ?> < ...
- Mybatis学习总结(二)—使用接口实现数据的增删改查
在这一篇中,让我们使用接口来实现一个用户数据的增删改查. 完成后的项目结构如下图所示: 在这里,person代表了一个用户的实体类.在该类中,描述了相关的信息,包括id.name.age.id_num ...
- MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存
二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...
- SpringMVC,MyBatis商品的增删改查
一.需求 商品的增删改查 二.工程结构 三.代码 1.Mapper层 (1) ItemsMapperCustom.java package com.tony.ssm.mapper; import ja ...
随机推荐
- ISO/IEC 15444-12 MP4 封装格式标准摘录 4
目录 Movie Fragments Movie Extends Box Movie Extends Header Box Track Extends Box Movie Fragment Box M ...
- js常用骚操作总结
打开网址 window.open("http://www.runoob.com"); 判断是否为url var url = $("#url").val(); i ...
- 不使用C库函数(Sprintf)将void* 指针转换为十六进制字符串
#include <stdio.h> #include <stdint.h> #include <stdlib.h> void hexDump(void *ptr, ...
- curses is not supported on this machine:(curses 在pycharm(Windows)中的安装 )
curse在Windows下的pycharm中安装,curse是不能直接在Windows下跑的.需要安装相关环境,要根据直接project的编译器版本来选择下载相关的whl. 找到project的Sc ...
- 云原生相关名词Istio发音
服务网格词汇 Istio,希腊语言中大概是风帆的意思, 发音 [iːst'iəʊ] ,相当于中文的 伊斯特亿欧
- 返回vector指针
#include<iostream> #include <vector> using namespace std; vector<int> *MyFind() { ...
- springboot2.x下actuator模块
一.简介 spring-boot-starter-actuator模块是一个spring提供的监控模块.我们在开运行发过程中,需要实时和定时监控服务的各项状态和可用性.Spring Boot的s ...
- RestTemplate响应值乱码
@Bean public RestTemplate getRestTemplate(){ RestTemplate restTemplate = new RestTemplate(); //解决中文乱 ...
- vue 剪切图片上传头像,使用 cropperjs 实现
我使用的是vue,移动端的项目. 官网地址:cropperjs GitHub地址:https://github.com/fengyuanchen/cropperjs/blob/master/READM ...
- luogu 1072 Hankson 的趣味题 唯一分解定理+线性筛
貌似是比大多数题解优的 $O(n^2logn)$ ~ Code: #include <bits/stdc++.h> #define N 50004 #define setIO(s) fre ...