在mybatis映射器的接口中,一般在查询时需要传递一些参数作为查询条件,有时候是一个,有时候是多个。当只有一个参数时,我们只要在sql中使用接口中的参数名称即可,但是如果是多个呢,就不能直接用参数名称了,mybatis中有以下四种

第一种:使用map传递

1⃣️定义接口

 // 使用map传递多个参数进行查询
public List<Product> getByMap(Map<String, Object> paramMap);

2⃣️sql语句

 <!--第一种:通过map传递 -->
<select id="getByMap" resultType="product" parameterType="map">
SELECT * FROM product
WHERE product_name LIKE concat('%',#{name},'%') AND
CAST(product_price AS INT) > #{price}
</select>

需要注意的有:

1、parameterType参数类型为map(此处使用别名)

2、参数名称是map中的key

3⃣️查询

 /**
* 通过map传递多个参数
*
* @return
*/
public void getProductsByMap() {
System.out.println("使用map方式传递多个参数");
List<Product> products = new ArrayList<>();
Map<String, Object> paramMap = new HashMap<>();
paramMap.put("name", "恤");
paramMap.put("price", 200);
sqlSession = MybatisTool.getSqlSession();
productMapper = sqlSession.getMapper(ProductMapper.class);
products = productMapper.getByMap(paramMap);
printResult(products);
}

4⃣️查看结果

 使用map方式传递多个参数
T恤2的价格是230元
T恤3的价格是270元
T恤4的价格是270元

这种方式的缺点是:

1、map是一个键值对应的集合,使用者只有阅读了它的键才能知道其作用;

2、使用map不能限定其传递的数据类型,可读性差

所以一般不推荐使用这种方式。

第二种:使用注解传递

1⃣️创建接口

 // 使用注解传递多个参数进行查询
public List<Product> getByAnnotation(@Param("name") String name, @Param("price") int price);

2⃣️定义sql

 <!--第二种:通过注解传递 -->
<select id="getByAnnotation" resultType="product">
SELECT * FROM product
WHERE product_name LIKE concat('%',#{name},'%') AND CAST(product_price
AS INT) >
#{price}
</select>

这种方式不需要设置参数类型 ,参数名称为注解定义的名称

3⃣️查询

 /**
* 通过注解传递多个参数
*/
public void getProductByAnnotation() {
System.out.println("使用注解方式传递多个参数");
List<Product> products = new ArrayList<>();
sqlSession = MybatisTool.getSqlSession();
productMapper = sqlSession.getMapper(ProductMapper.class);
products = productMapper.getByAnnotation("恤", 200);
printResult(products);
}

4⃣️查看结果

 使用注解方式传递多个参数
T恤2的价格是230元
T恤3的价格是270元
T恤4的价格是270元

这种方式能够大大提高可读性,但是只适合参数较少的情况,一般是少于5个用此方法,5个以上九要用其他方式了。

第三种:使用javabean传递

此中方式需要将传递的参数封装成一个javabean,然后将此javabean当作参数传递即可,为了方便,我这里只有两个参数封装javabean。

1⃣️参数封装成javabean

 /**
* 定义一个Javabean用来传递参数
*/
public class ParamBean {
public String name;
public int price; public ParamBean(String name, int price) {
this.name = name;
this.price = price;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getPrice() {
return price;
} public void setPrice(int price) {
this.price = price;
}
}

2⃣️创建接口

 // 使用JavaBean传递多个参数进行查询
public List<Product> getByJavabean(ParamBean paramBean); 

3⃣️定义sql

 <!--第三种:通过javabean传递 -->
<select id="getByJavabean" resultType="product" parameterType="paramBean">
SELECT * FROM product
WHERE product_name LIKE concat('%',#{name},'%')
AND CAST(product_price AS INT) > #{price}
</select>

需要注意的是:

1、参数类型parameterType为前面定义的javabean的全限定名或别名;

2、sql中的参数名称是javabean中定义的属性;

4⃣️查询

 /**
* 通过javabean传递多个参数
*/
public void getProductByJavabean() {
System.out.println("使用javabean方式传递多个参数");
List<Product> products = new ArrayList<>();
sqlSession = MybatisTool.getSqlSession();
productMapper = sqlSession.getMapper(ProductMapper.class);
ParamBean paramBean = new ParamBean("恤", 200);
products = productMapper.getByJavabean(paramBean);
printResult(products);
}

5⃣️查看结果

 使用javabean方式传递多个参数
T恤2的价格是230元
T恤3的价格是270元
T恤4的价格是270元 

这种方式在参数多于5个的情况下比较实用。

第四种:使用混合方式传递

假设我要进行分页查询,那么我可以将分页参数单独封装成一个javabean进行传递,其他参数封装成上面的javabean,然后用注解传递这两个javabean,并在sql中获取。

1⃣️封装分页参数javabean

 /*
* 定义一个分页的javabean
*/
public class PageParamBean {
public int start;
public int limit; public PageParamBean(int start, int limit) {
super();
this.start = start;
this.limit = limit;
} public int getStart() {
return start;
} public void setStart(int start) {
this.start = start;
} public int getLimit() {
return limit;
} public void setLimit(int limit) {
this.limit = limit;
} }

2⃣️创建接口

 // 使用混合方式传递多个参数进行查询
public List<Product> getByMix(@Param("param") ParamBean paramBean, @Param("page") PageParamBean pageBean);

可以看出此处使用javabean+注解的方式传递参数

3⃣️定义sql

 <!--第四种:混合方式传递 -->
<select id="getByMix" resultType="product">
SELECT * FROM product WHERE
product_name LIKE concat('%',#{param.name},'%') AND CAST(product_price
AS INT) >
#{param.price} LIMIT #{page.limit} OFFSET #{page.start}
</select>

只要是注解方式,就不需要定义参数类型。

4⃣️查询

 /**
* 通过混合方式传递多个参数
*/
public void getProductByMix() {
System.out.println("使用混合方式传递多个参数");
List<Product> products = new ArrayList<>();
sqlSession = MybatisTool.getSqlSession();
productMapper = sqlSession.getMapper(ProductMapper.class);
ParamBean paramBean = new ParamBean("恤", 200);
PageParamBean pageBean = new PageParamBean(0, 5);
products = productMapper.getByMix(paramBean, pageBean);
printResult(products);

5⃣️查看结果

 使用混合方式传递多个参数
T恤2的价格是230元
T恤3的价格是270元
T恤4的价格是270元

以上就是四种方式传递多个参数的实例。

MyBatis映射器(一)--多参数传递方式的更多相关文章

  1. MyBatis映射器(转载)

    什么是MyBatis映射器? MyBatis框架包括两种类型的XML文件,一类是配置文件,即mybatis-config.xml,另外一类是映射文件,例如XXXMapper.xml等.在MyBatis ...

  2. MyBatis映射器元素

     映射器是MyBatis最强大的工具,也是我们使用MyBatis时用的最多的工具,映射器中主要有增删改查四大元素,来满足不同场景的需要: 下面是主要元素的介绍:         select:查询语句 ...

  3. mybatis映射器配置细则

    前面三篇博客我们已经多次涉及到映射器的使用了,增删查基本上都用过一遍了,但是之前我们只是介绍了基本用法,实际上mybatis中映射器可以配置的地方还是非常多,今天我们就先来看看映射器还有哪些需要配置的 ...

  4. mybatis 映射器

    1 映射器 Mapper 是由java接口和 XML 文件共同组成.它的作用如下 1)定义参数类型 2)描述缓存 3)描述 SQL 语句 4)定义查询结果和POJO的映射关系 2 SqlSession ...

  5. Mybatis映射器接口代理对象的方式 运行过程

    查询一张表的所有数据. 环境: 使用工具IntelliJ IDEA 2018.2版本. 创建Maven工程不用骨架 1.pom.xml <?xml version="1.0" ...

  6. 【长文】Spring学习笔记(七):Mybatis映射器+动态SQL

    1 概述 本文主要讲述了如何使用MyBatis中的映射器以及动态SQL的配置. 2 MyBatis配置文件概览 MyBatis配置文件主要属性如下: <settings>:相关设置,键值对 ...

  7. mybatis 映射器(mappers) 配置说明 加载映射文件方式

    映射器(mappers) 既然 MyBatis 的行为已经由上述元素配置完了,我们现在就要定义 SQL 映射语句了.但是首先我们需要告诉 MyBatis 到哪里去找到这些语句. Java 在自动查找这 ...

  8. Mybatis 映射器接口实现类的方式 运行过程debug分析

    查询一张表的所有数据. 环境: 使用工具IntelliJ IDEA 2018.2版本. 创建Maven工程不用骨架 <?xml version="1.0" encoding= ...

  9. MyBatis拦截器:给参数对象属性赋值

    该拦截器的作用:在进行增加.修改等操作时,给数据模型的一些通用操作属性(如:创建人.创建时间.修改人.修改时间等)自动赋值. 该实现是在DAO层拦截,即存入DB前最后一层.后经分析,不是很合理,改为在 ...

随机推荐

  1. iOS扩展Extension之Today

    1.简介 扩展(Extension)是iOS 8中引入的一个新特性.扩展让app之间的数据交互成为可能.在iOS 8系统之前,每一个app在物理上都是彼此独立的,app之间不能互访彼此的私有数据.而在 ...

  2. iOS开发之SceneKit框架--加载多个模型.dae/.scn文件

    1.通过SCNGeometry或子类SCNParametricGeometry创建 相关链接:iOS开发之SceneKit框架--SCNGeometry.h iOS开发之SceneKit框架--SCN ...

  3. jquery判断是pc端还是移动端

    原文地址:https://www.cnblogs.com/mo-cha/p/6038872.html $(function(){ var system = { win: false, mac: fal ...

  4. Acess link

  5. Maven使用初步

    一.安装: 1.下载:http://maven.apache.org/download.cgi 2.设置环境变量 1.创建"M2_HOME",值为Maven安装路径(如:D:\Ja ...

  6. Luogu P2619 [国家集训队2]Tree I(WQS二分+最小生成树)

    P2619 [国家集训队2]Tree I 题意 题目描述 给你一个无向带权连通图,每条边是黑色或白色.让你求一棵最小权的恰好有\(need\)条白色边的生成树. 题目保证有解. 输入输出格式 输入格式 ...

  7. 杜教筛&套路总结

    杜教筛 \[ \begin{split} (g*f)(i)&=\sum_{d|i}g(d)f(\frac id)\\ \Rightarrow g(1)S(n)&=\sum_{i=1}^ ...

  8. 【2011集训贾志鹏】Crash 的数字表格

    题面 题目分析 (默认\(n<m\)) 题目要求\(\sum\limits_{i=1}^n\sum\limits_{j=1}^mlcm(i,j)\). 由\(lcm(i,j)=\frac{i\c ...

  9. Loadrunner安装与破解【转】

    Loadrunner安装与破解 一.下载 我的LoadRunner 11下载地址是: http://pan.baidu.com/s/1qYFy2DI 二.安装 1.启动安装程序 运行setup.exe ...

  10. 转载:Linux命令经典面试题:统计文件中出现次数最多的前10个单词

    1.使用linux命令或者shell实现:文件words存放英文单词,格式为每行一个英文单词(单词可以重复),统计这个文件中出现次数最多的前10个单词 主要考察对sort.uniq命令的使用,相关解释 ...