【MyBatis框架】mapper配置文件-foreach标签

foreach标签

下面介绍一下一个mapper配置文件中的foreach标签(注意,要跟着前面的总结来看,这里使用的例子是结合前面的工程写的,大部分代码没有再赘述)

foreach的作用是向sql传递数组或List,mybatis使用foreach解析

1.1需求
在用户查询列表和查询总数的statement中增加多个id输入查询。
sql语句如下:

两种方法:
SELECT * FROM USER WHERE id=1 OR id=3 OR id=5

SELECT * FROM USER WHERE id IN(1,3,5)

1.2在输入参数类型中添加List<Integer> ids传入多个id
public class UserQueryVo {

//传入多个id
private List<Integer> ids;

public List<Integer> getIds() {
return ids;
}

public void setIds(List<Integer> ids) {
this.ids = ids;
}
......
}

1.3修改mapper.xml

WHERE id=1 OR id=3 OR id=5
在查询条件中,查询条件定义成一个sql片段,需要修改sql片段。

<pre name="code" class="html"><!-- 定义sql片段
id:sql片段的唯一标识
在sql片段中不要加入where
经验:一般我们定义sql片段是为了可重用性,是基于单表来定义sql片段,
这样的话这个sql片段可重用性才高-->
<sql id="query_user_where">
	<if test="ids!=null">
		<!-- 使用foreach遍历传入ids
		collection指定输入对象中集合属性
		item每次遍历生成的对象名
		open开始遍历时要拼接的串
		close开始遍历时要拼接的串
		separator遍历的两个对象中间需要拼接的串
		-->
		<!-- 使用实现下边的sql拼接
		WHERE (id=1 OR id=3 OR id=5)-->
		<foreach collection="ids" item="user_id" open="AND (" close=")" separator="OR">
			<!-- 每次遍历要拼接的串 -->
			id=#{user_id}
		</foreach>
	</if>
</sql>

<!-- 用户信息综合查询 -->
	<select id="findUserList" parameterType="cn.edu.hpu.mybatis.PO.UserQueryVo"
								resultType="cn.edu.hpu.mybatis.PO.UserCustom">
		select * from user 

		<!-- where标签可以自动去掉第一个and -->
		<where>
			<!-- 应用sql片段的id,如果refid指定的id不再本mapper文件中,需要前边加namespace -->
			<include refid="query_user_where"></include>
			<!-- 在这里还可能要引用其他的sql片段 -->
		</where>
	</select>

在mapper接口类中添加相应方法:

//用户管理的Dao接口
public interface UserMapper {

	//用户信息综合查询
	public List<UserCustom> findUserList(UserQueryVo userQueryVo) throws Exception;
	......
}

1.4测试代码

//用户信息综合查询
	@Test
	public void testFindUserList() throws Exception{

		SqlSession sqlSession=sqlSessionFactory.openSession();

		//创建UserMapper代理对象
		UserMapper userMapper=sqlSession.getMapper(UserMapper.class);

		//创建包装对象,设置查询条件
		UserQueryVo userQueryVo=new UserQueryVo();
		//传入多个Id
		List<Integer> ids=new ArrayList<Integer>();
		ids.add(1);
		ids.add(3);
		ids.add(5);
		//将ids通过userQueryVo传入statement中
		userQueryVo.setIds(ids);

		//调用userMapper的方法
		List<UserCustom> users=userMapper.findUserList(userQueryVo);

		for (int i = 0; i < users.size(); i++) {
			UserCustom user=(UserCustom)users.get(i);
			System.out.println(user.getId()+":"+user.getUsername());
		}
	}

测试结果:
1:张三
3:刘莉莉
5:刘三姐

日志输出:

DEBUG [main] - Opening JDBC Connection
DEBUG [main] - Created connection 6867819.
DEBUG [main] - Setting autocommit to false on JDBC Connection [com.mysql.jdbc.Connection@68cb6b]
DEBUG [main] - ==>  Preparing: select * from user WHERE ( id=? OR id=? OR id=? )
DEBUG [main] - ==> Parameters: 1(Integer), 3(Integer), 5(Integer)
DEBUG [main] - <==      Total: 3

可以看到,sql语句select * from user WHERE ( id=? OR id=? OR id=? ) 通过foreach输出成功

1.5另外一个sql的实现:

<!-- 使用实现下边的sql拼接
AND ID IN(1,3,5)-->
<foreach collection="ids" item="user_id" open="AND ID IN(" close=")" separator=",">
	<!-- 每次遍历要拼接的串 -->
	#{user_id}
</foreach>

转载请注明出处:http://blog.csdn.net/acmman/article/details/46581375

时间: 2024-08-01 23:24:53

【MyBatis框架】mapper配置文件-foreach标签的相关文章

【MyBatis框架】配置文件-resultMap总结

resultMap总结 resultType: 作用:将查询结果按照sql列名pojo属性名一致性映射到pojo中. 场合:常见一些明细记录的展示,比如用户购买商品明细,将关联查询信息全部展示在页面时,此时可直接使用resultType将每一条记录映射到pojo中,在前端页面遍历list(list中是pojo)即可. resultMap:使用association和collection完成一对一和一对多高级映射(对结果有特殊的映射要求). association: 作用:将关联查询信息映射到一个

Java的MyBatis框架中Mapper映射配置的使用及原理解析_java

Mapper的内置方法model层就是实体类,对应数据库的表.controller层是Servlet,主要是负责业务模块流程的控制,调用service接口的方法,在struts2就是Action.Service层主要做逻辑判断,Dao层是数据访问层,与数据库进行对接.至于Mapper是mybtis框架的映射用到,mapper映射文件在dao层用. 下面是介绍一下Mapper的内置方法: 1.countByExample ===>根据条件查询数量 int countByExample(UserEx

java-Spring框架的配置文件中,property标签和其属性都是干嘛用的?

问题描述 Spring框架的配置文件中,property标签和其属性都是干嘛用的? 上图中框出来的标签和属性代表什么?有何用处,谢谢作答 解决方案 你看在你spring配置文件中,配置了session的bean,既然是配置在dao层,那就是为了事务处理而添加的.为了调用事务处理,做事务回滚等操作.

Java Mybatis框架入门基础教程_基础知识

一.Mybatis介绍 MyBatis是一款一流的支持自定义SQL.存储过程和高级映射的持久化框架.MyBatis几乎消除了所有的JDBC代码,也基本不需要手工去 设置参数和获取检索结果.MyBatis能够使用简单的XML格式或者注解进行来配置,能够映射基本数据元素.Map接口和POJOs(普通java对象)到数据库中的记录. 二.MyBatis工作流程 (1)加载配置并初始化 触发条件:加载配置文件 配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个个

【MyBatis框架】SqlMapConfig剖析

下面对SqlMapConfig.xml中的配置进行详细剖析. mybatis的全局配置文件SqlMapConfig.xml,配置内容如下: properties(属性) settings(全局配置参数) typeAliases(类型别名) typeHandlers(类型处理器) objectFactory(对象工厂) plugins(插件) environments(环境集合属性对象)environment(环境子属性对象)transactionManager(事务管理)dataSource(数

Mybatis缓存 缓存配置文件 good

一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的支持 一级缓存: 基于PerpetualCache 的 HashMap本地缓存,其存储作用域为 Session,当 Session flush 或 close 之后,该Session中的所有 Cache 就将清空. 2. 二级缓存与一级缓存其机制相同,默认也是采用 PerpetualCache,HashMap存储,不同在于其存储作用域为 Mapper(Namespace),并且可自定义存储源,如

使用XSD校验Mybatis的SqlMapper配置文件的方法(1)_java

这篇文章以前面对SqlSessionFactoryBean的重构为基础,先简单回顾一下做了哪些操作: 新建SqlSessionFactoryBean,初始代码和mybatis-spring相同: 重构buildSqlSessionFactory()方法,将众多的if语句抽取为一组小方法,预留自定义配置的方法,同时添加常用属性的getter方法: 提取组件工厂接口,并提供组件创建工具类SqlSessionComponetFactorys,将散落在不同地方的new Xxx()集中管理,便于组件的替换

深入理解MyBatis框架的的配置信息

面对一个框架,最重要的不是说回用其代码就可以了,我们需要了解其思想,这样才能更快更好的掌握这个框架.而对于一个框架,最重要的就是其配置文件的作用及功能了.下面,我就来谈一谈我今天遇到的这个MyBatis框架. 核心思想 MyBatis的核心思想就是为了简化开发人员在编写和数据库打交道的时候的持久化的复杂的操作.其工作流程我们先不深究,就看看它实现的功能吧.那我们其实可以类比自己写的代码.我们实现和数据库打交道的操作不就是连接数据库,创建相关的JavaBean对象,然后使用DAO层的语法,借助于S

MyBatis框架之mybatis逆向工程自动生成代码_java

Mybatis属于半自动ORM,在使用这个框架中,工作量最大的就是书写Mapping的映射文件,由于手动书写很容易出错,我们可以利用Mybatis-Generator来帮我们自动生成文件. 逆向工程 1.什么是逆向工程 mybaits需要程序员自己编写sql语句,mybatis官方提供逆向工程 可以针对单表自动生成mybatis执行所需要的代码(mapper.java,mapper.xml.po..) 企业实际开发中,常用的逆向工程方式: 由于数据库的表生成java代码. 2.下载逆向工程 my