MyBatis实现万能Map和模糊查询
万能Map
我们在上一节博文里面将到利用Mybatis实现CRUD操作的时候,我们在数据库表中新增一条数据是这样操作的:
实体类对象的字段有:
package com.hpf.bean; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; //编写实体类User @Data @AllArgsConstructor @NoArgsConstructor public class User { private Long id; private String username; private String password; }
新增一条记录的xml文件配置内容为:
<insert id="addUser" parameterType="com.hpf.bean.User"> insert into userinfo (id,username,password) values (#{id},#{username},#{password}) </insert>
其中,#后带的字段名都是我们实体类用户类里面一模一样的字段名。
接着我们再来试试用Map的方式实现用户记录的新增:
<insert id="addUserByMap" parameterType="Map"> insert into userinfo (id,username,password) values (#{id},#{user},#{pwd}) </insert>
测试部分:
@Test public void testAddUserByMap(){ SqlSession sqlSession = MyBatisUtils.getSqlSession(); UserDao mapper = sqlSession.getMapper(UserDao.class); Map<String,Object> map = new HashMap<>(); map.put("id", 6L); map.put("user", "张三"); map.put("pwd", "666"); int res = mapper.addUserByMap(map); sqlSession.commit(); sqlSession.close(); }
说明:我们业务相关的参数需要哪些字段内容,我们就往map里面传哪些字段内容就行。
模糊查询
要求查询下表内为李性的用户信息:
package com.hpf.dao; import com.hpf.bean.User; import java.util.List; import java.util.Map; //这个接口实现的是对于用户的相关操作 public interface UserDao { //模糊查询用户信息 List<User> getUserByLike(Map map); }
<select id="getUserByLike" parameterType="Map" resultType="com.hpf.bean.User"> select * from userinfo where username like #{value} </select>
@Test public void testGetUserByLike(){ SqlSession sqlSession = MyBatisUtils.getSqlSession(); UserDao mapper = sqlSession.getMapper(UserDao.class); Map<String,Object> map = new HashMap<>(); map.put("value", "李%"); List<User> userByLike = mapper.getUserByLike(map); for(User user:userByLike) System.out.println(user); }
结果如图所示:
说明:模糊查询在这种方式下其实还有一种写法也可以得出结果,但是为了防止sql注入问题,我们不建议如下的写法:
<select id="getUserByLike" parameterType="Map" resultType="com.hpf.bean.User"> select * from userinfo where username like #{value}"%" </select>
到此这篇关于MyBatis实现万能Map和模糊查询的文章就介绍到这了,更多相关MyBatis 万能Map和模糊查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解spring cloud中使用Ribbon实现客户端的软负载均衡
这篇文章主要介绍了详解spring cloud中使用Ribbon实现客户端的软负载均衡,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-01-01Spring Boot集成Resilience4J实现限流/重试/隔离
在Java的微服务生态中,对于服务保护组件,像springcloud的Hystrix,springcloud alibaba的Sentinel,以及当Hystrix停更之后官方推荐使用的Resilience4j,所以本文给大家介绍了Spring Boot集成Resilience4J实现限流/重试/隔离,需要的朋友可以参考下2024-03-03java并发编程专题(二)----如何创建并运行java线程
这篇文章主要介绍了java并发编程如何创建并运行java线程,文中讲解非常详细,示例代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下2020-06-06java.lang.NullPointerException出现的几种原因及解决方案
这篇文章主要介绍了java.lang.NullPointerException出现的几种原因及解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-05-05基于 SpringBoot 实现 MySQL 读写分离的问题
这篇文章主要介绍了基于 SpringBoot 实现 MySQL 读写分离的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-02-02
最新评论