初学Mybatis之 Map 传参与模糊查询

实体类或数据库中的表,字段或参数过多,考虑使用Map

接口里定义方法

java 复制代码
int addUser(Map<String,Object> map);

mapper.xml:

parameterType 参数类型设置为 map

sql 语句的 values 不一定要与数据库中的表字段相同

XML 复制代码
    <insert id="addUser" parameterType="map">
        insert into mybatis.user(id,name,pwd) values(#{userId},#{userName},#{userPwd});
    </insert>

测试类:

先 new 一个 HashMap

再调用 put 方法添加数据

java 复制代码
    @Test
    public void addUser(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        Map<String, Object> map = new HashMap<String, Object>();

        map.put("userId",5);
        map.put("userName","张三5");
        map.put("userPwd","123");
        
        mapper.addUser(map);
        
        sqlSession.commit();

        sqlSession.close();
    }

Map 传递参数,直接在 sql 中取出 key 即可,parameterType="map"

对象传递参数,直接在 sql 中取对象的属性即可,parameterType="Object"

只有一个基本类型参数的情况下,可以直接在 sql 中取到

多个参数用 Map,或者注解

模糊查询:

写个接口

java 复制代码
List<User> getUserLike(String value);

mapper.xml:

XML 复制代码
    <select id="getUserLike" resultType="com.demo.pojo.User">
        select * from mybatis.user where name like #{value}
    </select>

测试类:

模糊查询加通配符%

java 复制代码
    @Test
    public void getUserLike(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

        List<User> userList = mapper.getUserLike("%张%");

        for(User user : userList){
            System.out.println(user);
        }

        sqlSession.close();
    }
相关推荐
日月云棠6 小时前
各版本JDK对比:JDK 25 特性详解
java
用户8307196840827 小时前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide7 小时前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家8 小时前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺8 小时前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户908324602738 小时前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端
桦说编程8 小时前
实战分析 ConcurrentHashMap.computeIfAbsent 的锁冲突问题
java·后端·性能优化
爱可生开源社区9 小时前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
程序员清风12 小时前
用了三年AI,我总结出高效使用AI的3个习惯!
java·后端·面试
beata13 小时前
Java基础-13: Java反射机制详解:原理、使用与实战示例
java·后端