mybatis05--多条件的查询
public interface StudentDao {
/**
* 前台的表单给出的查询条件不能封装成一个对象的时候
* 查询只能是多个参数了! 也就是参数不全是Student中的属性!
* 这时候就有两个解决方案
* 01.第一种方式 使用map查询姓名带小 年龄大于10 的学生信息
*/ List<Student> selectStudentsByNameAndAge(Map<String, Object> map); }

先从前台的测试开始写

public class StudentTest {
StudentDao dao;
SqlSession session; @Before
public void before() {
// 因为需要关闭session 需要把session提取出去
session = SessionUtil.getSession();
dao = session.getMapper(StudentDao.class);
} @After
public void after() {
if (session != null) {
session.close();
}
} // 01.查询姓名带 小 年龄大于10 的学生信息
@Test
public void test() {
Map<String,Object> map=new HashMap<String, Object>();
map.put("StuName", "小");
map.put("StuAge", 10);
List<Student> list = dao.selectStudentsByNameAndAge(map);
for (Student student : list) {
System.out.println(student);
}
} }

那么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="cn.bdqn.dao.StudentDao">
<!-- id要和dao的方法名相同
#{值} 必须和前台map中的key一致!否则会报错--> <select id="selectStudentsByNameAndAge" resultType="Student">
select id,name,age from student
where name like '%' #{StuName} '%'
and age > #{StuAge}
</select> </mapper>

之后运行测试类代码即可!
现在又多了一个需求!查询姓名带 小 年龄大于10 ,并且编号大于 小黑 的学生信息
修改测试类代码

// 02.查询姓名带 小 年龄大于10 并且编号大于 小黑 的学生信息
@Test
public void test2() {
//创建小黑 对象
Student stu=new Student(16, "小黑", 30); Map<String,Object> map=new HashMap<String, Object>();
map.put("StuName", "小");
map.put("StuAge", 10);
//增加对象到map中
map.put("stu", stu);
List<Student> list = dao.selectStudentsByNameAndAge(map);
for (Student student : list) {
System.out.println(student);
}
}

修改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="cn.bdqn.dao.StudentDao">
<!-- id要和dao的方法名相同
#{值} 必须和前台map中的key一致!否则会报错--> <select id="selectStudentsByNameAndAge" resultType="Student">
select id,name,age from student
where name like '%' #{StuName} '%'
and age > #{StuAge}
<!-- 关键是#{}里面必须是写 对象名.属性 -->
and id >#{stu.id}
</select> </mapper>

运行测试代码 即可得到结果!
第二种方式 使用索引的方式来解决 多个参数的问题

public interface StudentDao {
/**
* 前台的表单给出的查询条件不能封装成一个对象的时候
* 查询只能是多个参数了! 也就是参数不全是Student中的属性!
* 这时候就有两个解决方案
* 02.使用多个参数查询姓名有小 年龄大于10的学生信息
*/ //
List<Student> selectStudentsByNameAndAge(String name, int age);
}

测试类中的代码如下

// 03.查询姓名带 小 年龄大于10 的学生信息
@Test
public void test2() {
List<Student> list = dao.selectStudentsByNameAndAge("小",10);
for (Student student : list) {
System.out.println(student);
}
}

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="cn.bdqn.dao.StudentDao">
<!-- #{0} 和 #{1} 存放的是参数列表的位置 -->
<select id="selectStudentsByNameAndAge" resultType="Student">
select id,name,age from student
where name like '%' #{0} '%'
and age > #{1}
</select> <!--
小结:#{}中可以存放什么内容
01.参数对象的属性
02.任意内容,此时的#{}只是一个占位符
03.map的key
04.如果key所对应的value是对象,则存放的是对象的属性
05.参数的索引号!从0开始
-->
</mapper>

运行测试代码即可得到结果!
mybatis05--多条件的查询的更多相关文章
- asp.net mvc多条件+分页查询解决方案
开发环境vs2010 css:bootstrap js:jquery bootstrap paginator 原先只是想做个mvc的分页,但是一般的数据展现都需要检索条件,而且是多个条件,所以就变成了 ...
- JSP+Servlet+javabean+oracle实现页面多条件模糊查询
之前写过一篇JSP+Servlet+javabean+mysql实现页面多条件模糊查询 使用的是mysql进行的分页查询,mysql用limit控制,而oracle则是用rownum,今天第一次写or ...
- 【java】spring-data-jpa 集成hibernate实现多条件分页查询
初次接触spring-data-jpa,实现多条件分页查询. 基础环境 Spring Boot+spring-data-jpa+hibernate+mysql 1.接口 要继承这个接口,这个接口提供了 ...
- HBase多条件筛选查询方案
最近的项目需要使用Hbase做实时查询,由于Hbase只支持一级索引,也就是使用rowkey作为索引查询,所以对于多条件筛选查询的支持不够,在不建立二级索引的情况下,只能使用Hbase API中提供的 ...
- SQL中以count及sum为条件的查询
在开发时,我们经常会遇到以“累计(count)”或是“累加(sum)”为条件的查询.比如user_num表: id user num 1 a 3 2 a 4 3 b 5 4 b 7 例1:查询出现 ...
- asp下实现多条件模糊查询SQL语句
常写一个简单的模糊查询的SQL语句格式可以如下例: sql="select * from 表名 where 字段名 like ’%" & request.form(&quo ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架 ...
- 使用ArcGIS API for Silverlight 进行复合多条件空间查询
原文:使用ArcGIS API for Silverlight 进行复合多条件空间查询 这两天帮网上认识的一个兄弟做了一个查询的示例,多多少少总结一下,在此和大家分享. 为什么说是复合多条件呢?因为进 ...
- 实现多条件模糊查询SQL语句
很多网友问到如何写模糊查询语句和多条件查询,这里我整理了一下,假设以姓名.性别.电话号...作为数据库中的字段名. 通常写一个简单的模糊查询的SQL语句格式可以如下例: sql="selec ...
- mysql 索引学习--多条件等值查询,顺序不同也能应用联合索引啦
以前学习这一块的时候,是说:假设建立了联合索引a+b,那么查询语句也一定要是这个顺序才能应用该索引. 那么实际是怎样呢,经过mysql这么多次版本升级,相信mysql已经给我们做了某些优化. 下面是我 ...
随机推荐
- yuv rgb 互转 公式 及算法
1 前言 自然界的颜色千变万化,为了给颜色一个量化的衡量标准,就需要建立色彩空间模型来描述各种各样的颜色,由于人对色彩的感知是一个复杂的生理和心理联合作用的过程,所以在不同的应用领域中为了更好更准确的 ...
- XSplit Quality, VBV-Buffer, VBV-Maxrate and Preset Settings
XSplit uses the x264 encoder, so let's start off by saying that parameters mentioned in the title, w ...
- golang 对slice的深拷贝 copy
测试 slice的地址 copy的时候 发现有问题: package main import "fmt" func main() { nums:=[]int{1,2,3,4,5} ...
- VS Code 插件
https://blog.fundebug.com/2018/07/24/vs-extensions/
- Mongodb系列- CRUD操作介绍
---恢复内容开始--- 一 Create 操作 在MongoDB中,插入操作的目标是一个集合. MongoDB中的所有写入操作在单个文档的层次上都是原子的. For examples, see In ...
- 简单理解 RPC(转载)
原文地址:http://www.syyong.com/architecture/Simple-understanding-of-RPC.html RPC(Remote Procedure Call P ...
- NetCore指令集和
1.查看当前目录的版本号 C:\Users\Administrator>dotnet --version 1.0.4 2.发布程式,进入到指定目录 dotnet publish 3.运行程式 # ...
- Object C函数指针@selector
其作用相当于函数指针,现在我看到的大多说用法都是在调用某些函数需要传递一个 函数指针 参数时,使用@selector.它会在当前类里面查找selector后面所跟的函数,返回一个SEL类型的值. S ...
- Java基础(二)面向对象(上)
面向对象基础知识 面向对象是相对面向过程而言的 面向对象和面向过程都是一种思想 面向过程强调的是功能行为 面向对象将功能封装进对象,强调具备了功能的对象 面向对象是基于面向过程的 面向对象的特征: 封 ...
- atitit r9 doc on home ntpc .docx
卷 p2soft 的文件夹 PATH 列表 卷序列号为 9AD0-D3C8 D:. │ Aittit pato 面对拒绝 的回应.docx │ Atitit 中国明星数量统计 attilax. ...