Mybatis使用包装对象当条件查询
2020-03-29 13:00
239 查看
场景
开发中通过 pojo 传递查询条件 ,查询条件是综合的查询条件,不仅包括用户查询条件还包括其它的查 询条件(比如将用户购买商品信息也作为查询条件),这时可以使用包装对象传递输入参数。 Pojo 类中包含 pojo。 需求:根据用户名查询用户信息,查询条件放到 QueryVo 的 user 属性中。
//dao层 /** * 根据queryVo中的条件查询用户 * @param vo * @return */ List<User> findUserByVo(QueryVo vo);
//实体类 public class QueryVo { private User user; public User getUser() { return user; } public void setUser(User user) { this.user = user; } }
//测试类 /** * 测试使用QueryVo作为查询条件 */ @Test public void testFindByVo(){ QueryVo vo = new QueryVo(); User user = new User(); user.setUsername("王"); vo.setUser(user); //5.执行查询一个方法 List<User> users = userDao.findUserByVo(vo); for(User u : users){ System.out.println(u); } }
sql将用2种方式查询(注意user.username)
1.#{}来完成模糊查询
<!-- 根据QueryVo的条件查询用户 --> <select id="findUserByVo" parameterType="com.itheima.domain.QueryVo" resultType="com.itheima.domain.User"> select * from user where username like concat('%',user.username,'%') </select>
2.${}来完成模糊查询
<!-- 根据QueryVo的条件查询用户 --> <select id="findUserByVo" parameterType="com.itheima.domain.QueryVo" resultType="com.itheima.domain.User"> select * from user where username like '%${user.username}%' </select>
总结,如果拼接sql用concat比较好
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- mybatis使用in语句作为查询条件
- mybatis中SQL块使用/动态条件查询
- mybatis 查询多个条件IN的使用方法
- mybatis使用注释方式查询出关联的对象
- mybatis 的like多条件模糊查询使用
- Ruby on Rails,使用where方法对持久化对象进行条件查询
- 在使用Mybatis 做查询时遇到查询到的对象为空的问题
- mybatis查询sql中in条件使用(foreach)
- SSM框架day02-MyBatis——029——复合条件查询-对象封装
- Ruby on Rails,使用where方法对持久化对象进行条件查询
- 使用Hibernate条件查询时,无法识别对象属性
- 03_MyBatis基本查询,mapper文件的定义,测试代码的编写,resultMap配置返回值,sql片段配置,select标签标签中的内容介绍,配置使用二级缓存,使用别名的数据类型,条件查询ma
- Ruby on Rails,使用where方法对持久化对象进行条件查询
- Hibernate查询,返回new对象(注意这个新定义的类要有构造函数),使用sql带条件分页查询并且把结果显示到一个对象的集里面的解决方案
- Mybatis 多条件查询(模糊查询 使用in查询)
- Spring Boot2(十一):Mybatis使用总结(自增长、多条件、批量操作、多表查询等等)
- 【Maven+SSM】Mybatis基础使用及动态SQL拼接根据对象查询数据
- 使用mybatis的Vo对象简单完成需求查询
- Hibernate查询,返回new对象(注意这个新定义的类要有构造函数),使用sql带条件分页查询并且把结果显示到一个对象的集里面的解决方案
- mybatis查询sql中in条件使用(foreach)