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--多条件的查询的更多相关文章

  1. asp.net mvc多条件+分页查询解决方案

    开发环境vs2010 css:bootstrap js:jquery bootstrap paginator 原先只是想做个mvc的分页,但是一般的数据展现都需要检索条件,而且是多个条件,所以就变成了 ...

  2. JSP+Servlet+javabean+oracle实现页面多条件模糊查询

    之前写过一篇JSP+Servlet+javabean+mysql实现页面多条件模糊查询 使用的是mysql进行的分页查询,mysql用limit控制,而oracle则是用rownum,今天第一次写or ...

  3. 【java】spring-data-jpa 集成hibernate实现多条件分页查询

    初次接触spring-data-jpa,实现多条件分页查询. 基础环境 Spring Boot+spring-data-jpa+hibernate+mysql 1.接口 要继承这个接口,这个接口提供了 ...

  4. HBase多条件筛选查询方案

    最近的项目需要使用Hbase做实时查询,由于Hbase只支持一级索引,也就是使用rowkey作为索引查询,所以对于多条件筛选查询的支持不够,在不建立二级索引的情况下,只能使用Hbase API中提供的 ...

  5. SQL中以count及sum为条件的查询

    在开发时,我们经常会遇到以“累计(count)”或是“累加(sum)”为条件的查询.比如user_num表: id user num 1 a 3 2 a 4 3 b 5 4 b 7   例1:查询出现 ...

  6. asp下实现多条件模糊查询SQL语句

    常写一个简单的模糊查询的SQL语句格式可以如下例: sql="select * from 表名 where 字段名 like ’%" & request.form(&quo ...

  7. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(20)-多条件模糊查询和回收站还原的实现 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架 ...

  8. 使用ArcGIS API for Silverlight 进行复合多条件空间查询

    原文:使用ArcGIS API for Silverlight 进行复合多条件空间查询 这两天帮网上认识的一个兄弟做了一个查询的示例,多多少少总结一下,在此和大家分享. 为什么说是复合多条件呢?因为进 ...

  9. 实现多条件模糊查询SQL语句

    很多网友问到如何写模糊查询语句和多条件查询,这里我整理了一下,假设以姓名.性别.电话号...作为数据库中的字段名. 通常写一个简单的模糊查询的SQL语句格式可以如下例: sql="selec ...

  10. mysql 索引学习--多条件等值查询,顺序不同也能应用联合索引啦

    以前学习这一块的时候,是说:假设建立了联合索引a+b,那么查询语句也一定要是这个顺序才能应用该索引. 那么实际是怎样呢,经过mysql这么多次版本升级,相信mysql已经给我们做了某些优化. 下面是我 ...

随机推荐

  1. Python常用的软件包

    下面是Python开发常用的软件包. 名称 用途 安装命令 opengl   sudo pip3 install PyOpenGL  pyqtgraph GUI图形库 sudo pip3 instal ...

  2. Linux如何快速跳转到文档开头或者末尾

    输入 gg 命令,光标会移动到文档开头 : 输入 G 命令,光标会移动到文档末尾: 另外可以敲击 上下键.Page UP.Page Down 键快速查看文档:

  3. [Web 前端] mobx教程(二)-mobx主要概念

    cp from : https://blog.csdn.net/smk108/article/details/84960159 通过<Mobx教程(一)-Mobx简介>我们简单理解了Mob ...

  4. iOS:练习题中如何用技术去实现一个连线题

    一.介绍 本人做的app涉及的是教育行业,所以关于练习题的开发肯定是家常便饭.例如,选择题.填空题.连线题.判断题等,每一种题型都需要技术去实现,没啥多大难度,这里呢,就给出实现连线题的核心代码吧.过 ...

  5. Python的pandas

    pandas 是python中很重要的组件,网上关于pandas 的文章也很多,比如Python科学计算之Pandas 和 Python数据分析入门 Pandas基于两种数据类型:series与dat ...

  6. Ubuntu 16.04 升级git

    To update git on Ubuntu 12.04 just follow this line of commands: sudo apt-get install python-softwar ...

  7. RobotFrameWork接口项目分层及通用控制方式

    1. 前言 上一篇文章介绍了在设计接口用例之前应遵守的设计规范,详见<RobotFramework接口设计规范>,当然读者公司的内部规范也不一定非得完全遵循笔者所提到的,适合自己公司内部的 ...

  8. PHP-问题处理Fatal error: Uncaught Error: Call to undefined function simplexml_load_file()

    1.问题 今天重新安装了ubuntu,PHP,MySQL,Apache,到测试CMS项目时发生一个错误: Fatal error: Uncaught Error: Call to undefined ...

  9. 【转】Java并发的AQS原理详解

    申明:此篇文章转载自:https://juejin.im/post/5c11d6376fb9a049e82b6253写的真的很棒,感谢老钱的分享. 打通 Java 任督二脉 —— 并发数据结构的基石 ...

  10. B2B相关编码说明

    B2B Cross reference Pre-Ordering enliteB2B RosettaNet EDIFACT ANSI X12 OAGIS iDOC Price Catalogue X ...