mybatis-plus 自定义SQL,XML形式,传参的几种方式
前提说明
所涉及文件
传参类型说明
1.Java代码中使用QueryWrapper动态拼装SQL
2.简单类型参数(如String,Long,Integer等),适用于固定且确定的参数
3.参数传入类型为Class类,或mybatis-plus生成的 entity类
4.参数传入类型为Map类型的数据
前提说明
在使用 mybatis-plus 进行操作数据库,有一部分比较复杂的操作需要写SQL语句,这样就会涉及到传参数。下面记载一下我遇到的几种传参数情况。如果有更好的可以留言,继续完善。 所涉及文件
自定义SQL涉及到两种类型的文件:###Mapper.java 和 ###Mapper.xml 。这两种文件都是mybatis-plus自动生成的。
例如下面的例子: TGrouponMapper.java文件的内容
public interface TGrouponMapper extends BaseMapper<TGroupon> {
/**
* @description: 获取用户参加的团购信息
* @author: haojg
* @date: 2020/6/18 19:48
* @return:
*/
IPage<TGroupon> selectUserJoinGroupon(Page<?> page, @Param("userId") Long userId);
} TGrouponMapper.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">
<mapper namespace="com.hddata.xpt.db.mapper.TGrouponMapper">
<select id="selectUserJoinGroupon" resultType="TGroupon">
SELECT g.*, ref.join_status, ref.join_name, ref.join_phone, ref.user_id as join_user_id
FROM t_groupon g, t_groupon_user_ref ref
WHERE g.id = ref.groupon_id
AND g.is_delete != 1
AND ref.user_id = ${userId}
ORDER BY g.create_time desc
</select>
</mapper> 传参类型说明
1.Java代码中使用QueryWrapper动态拼装SQL
Java代码中使用QueryWrapper动态拼装SQL后,最后在马Mapper.xml文件中使用。这种情况适用于where条件比较复杂,分支比较多的情况,更多情况自己品味吧。直接上代码如下: Mapper.java文件内容:
public interface TIdentityDocumentInfoMapper extends BaseMapper<TIdentityDocumentInfo> {
/**
* @Description: 根据身份证和医院患者Id获取系统患者Id等信息
* @Author: Haojg on 2019/8/7 23:37
* @return:
*/
List<TIdentityDocumentInfo> getPatientByIdAndPat(@Param(Constants.WRAPPER) QueryWrapper<TIdentityDocumentInfo> wrapper); } Mapper.xml文件内容: ew.sqlSegment 是固定的写法,请注意。 <select id="getPatientByIdAndPat" resultType="TIdentityDocumentInfo">
SELECT t1.*, t3.*
FROM t_medical_card_info t1, t_identity_document_info t3
WHERE t1.identity_document_id = t3.identity_document_id
AND ${ew.sqlSegment}
</select> 调用接口方法:
这里通过Java直接拼接where语句。 QueryWrapper<TIdentityDocumentInfo> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("t3.id", IdCard);
queryWrapper.eq("t1.hospital_id", hosId);
List<TIdentityDocumentInfo> queryList = tIdentityDocumentInfoMapper.getPatientByIdAndPat(queryWrapper); 2.简单类型参数(如String,Long,Integer等),适用于固定且确定的参数
这种情况直接上代码。 Mapper.java文件内容,通过 @Param 进行参数设置。
IPage<TGroupon> selectUserJoinGroupon(Page<?> page, @Param("userId") Long userId);
1
Mapper.xml文件内容:直接使用参数 userId
<select id="selectUserJoinGroupon" resultType="TGroupon">
SELECT g.*, ref.join_status, ref.join_name, ref.join_phone, ref.user_id as join_user_id
FROM t_groupon g, t_groupon_user_ref ref
WHERE g.id = ref.groupon_id
AND g.is_delete != 1
AND ref.join_status != 0
AND ref.user_id = ${userId}
ORDER BY g.create_time desc
</select> 3.参数传入类型为Class类,或mybatis-plus生成的 entity类
Mapper.java文件内容: **HoRefunds ** 是数据库中表映射成的entity类
int updateRefundOk(@Param("subTable") String subTable, @Param("hoRefunds") HoRefunds hoRefunds);
1
Mapper.xml文件内容中, 如下面的代码中: hoRefunds.refundResponse , hoRefunds 是 entity类, refundResponse 是字段名称。
<update id="updateRefundOk">
update ho_refunds_${subTable} set
refund_request = #{hoRefunds.refundRequest},
refund_response = #{hoRefunds.refundResponse},
err_code = #{hoRefunds.errCode},
err_code_des = #{hoRefunds.errCodeDes}
where id = #{hoRefunds.id}
</update> 4.参数传入类型为Map类型的数据
当entity类不满足情况的时候,可以使用Map类型的数据,具体例子如下。 Mapper.java文件内容: paramsMap 为Map类型
public int getPushHistoryIsExsit(Map<String, Object> paramsMap);
1
Mapper.xml文件内容中,
01,标明传入参数的类型 ** parameterType=“java.util.Map” **
02,直接使用传入参数中的Key, 如:step , cardId, notifyType
<select id="getPushHistoryIsExsit" parameterType="java.util.Map" resultType="int">
select count(t1.id) from hcustom_his_push t1
inner join hcustom_notify_config t2
on t1.notify_config_id = t2.id
and t2.notify_steps = #{step} and t2.notify_type = #{notifyType} and t1.medical_card_id = #{cardId}
</select> 调用实例
Map<String, Object> paramsMap = new HashMap<>();
paramsMap.put("cardId", cardId);
paramsMap.put("step", step);
paramsMap.put("notifyType", notifyType);
int pushCount = hcustomHisPushMapper.getPushHistoryIsExsit(paramsMap);

  

mybatis-plus 自定义SQL,XML形式,传参的几种方式的更多相关文章

  1. Vue路由传参的几种方式

    原 Vue路由传参的几种方式 2018年07月28日 23:52:40 广积粮缓称王 阅读数 12613   前言:顾名思义,vue路由传参是指嵌套路由时父路由向子路由传递参数,否则操作无效.传参方式 ...

  2. react-绑定this并传参的三种方式

    绑定this并传参的三种方式 在事件中绑定this并传参: <input type="button" value="在事件中绑定this并传参" onCl ...

  3. ajax的data传参的两种方式

    ajax的data传参的两种方式 本文为转载. 1.[javascript] view plain copy /** * 订单取消 * @return {Boolean} 处理是否成功 */ func ...

  4. vue 路由传参中刷新页面参数丢失 及传参的几种方式?

    在页面跳转中,我通过路由传参,结果发现页面参数丢失了.路径返回了根目录.... 1. 先说下路由传参的几种方式吧? 比如:<div v-for="item in items" ...

  5. jq ajax传参的两种方式

    第一种   在url ? 后通过拼接传参   第二种 通过data传参 (1)第一种方法:(通过url传参) function GetQuery(id) { if (id ==1||id==7) { ...

  6. mybatis传参的几种方式

    1,@Param @参考文章 @Select("select s_id id,s_name name,class_id classid from student where  s_name= ...

  7. TestNG传参的几种方式

    1. 通过parameter传参 java代码部分: import org.testng.annotations.Parameters; import org.testng.annotations.T ...

  8. vue里面路由传参的三种方式

    1.方式一 通过query的方式也就是?的方式路径会显示传递的参数 HTML的方式<router-link :to="{name:xxx,query:{page:1,code:8899 ...

  9. 总结QueueUserWorkItem传参的几种方式

    最近在学习citrix的xenserver6.2的源代码,发现多处用到System.Threading命名空间下的ThreadPool.QueueUserWorkItem方法: public stat ...

随机推荐

  1. Kubernetes-20:日志聚合分析系统—Loki的搭建与使用

    日志聚合分析系统--Loki 什么是Loki? Loki 是 Grafana Labs 团队最新的开源项目,是一个水平可扩展,高可用性,多租户的日志聚合系统.它的设计非常经济高效且易于操作,因为它不会 ...

  2. 【抓取】6-DOF GraspNet 论文解读

    [抓取]6-DOF GraspNet 论文解读 [注]:本文地址:[抓取]6-DOF GraspNet 论文解读 若转载请于明显处标明出处. 前言 这篇关于生成抓取姿态的论文出自英伟达.我在读完该篇论 ...

  3. Java 安全之Java Agent

    Java 安全之Java Agent 0x00 前言 在前面发现很多技术都会去采用Java Agent该技术去做实现,比分说RASP和内存马(其中一种方式).包括IDEA的这些破解都是基于Java A ...

  4. 对于Web开发最棒的22个Visual Studio Code插件

    翻译    原文作者:James Quick    原文地址:https://scotch.io/bar-talk/22-best-visual-studio-code-extensions-for- ...

  5. 第8.6节 Python类中的__new__方法深入剖析:调用父类__new__方法参数的困惑

    上节<第8.5节 Python类中的__new__方法和构造方法__init__关系深入剖析:执行顺序及参数关系案例详解>通过案例详细分析了两个方法的执行顺序,不知大家是否注意到了,在上述 ...

  6. java课堂作业--异常处理

    一. 运行结果: 二. 结果: ArrayIndexOutOfBoundsException/内层try-catch 发生ArithmeticException 三. 结果: ArrayIndexOu ...

  7. 攻防世界 web进阶区 lottery

    首先进入题目的页面. 按其要求登录.然后看到以下界面. 御剑扫描目录,发现了robots.txt (robots协议) ,进入查看 进入.git/目录,用神器 GitHack 下载文件. 然后查看源码 ...

  8. 笔试题.NET基础代码面试题

    题目如下,本随笔只是记录,都是一些自身面经的题目,您既然点开了的话,学习下无妨,说不定有帮助呢 以下答案都经过博主一个个去运行过. 题目1 (实例化后 x=?;y=? 输出什么): public cl ...

  9. Cookie 和JWT 并存同一项目代码记录

    Cookie管理后台管理,JWT对外提供接口验证 具体官方文档链接 使用 ASP.NET Core 中的特定方案授权 实现思路: 1.添加两种授权方式配置, AddAuthentication 的参数 ...

  10. 小齐读者拿到快手、百度、网易等 offer 的独门秘籍!

    小齐说: 这篇文章来自读者冰红茶,他刚结束了秋招,拿了很多家 offer. 和他聊完之后,我觉得他的备考思路也完全适用于美国的面试,只是分值要调整一下,但是具体每一块的内容,地球村通用.所以分享给大家 ...