初学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();
    }
相关推荐
原来是猿3 分钟前
谈谈环境变量
java·开发语言
Austindatabases9 分钟前
DBA 从“修电脑的” 到 上演一套 “数据治理” 大戏 --- 维护DBA生存空间,体现个体价值
数据库·dba
LB211218 分钟前
Redis黑马点评 day01
数据库·redis·缓存
白小筠26 分钟前
创建Django项目
数据库·django·sqlite
oioihoii40 分钟前
深入理解 C++ 现代类型推导:从 auto 到 decltype 与完美转发
java·开发语言·c++
韩立学长1 小时前
【开题答辩实录分享】以《租房小程序的设计和实现》为例进行答辩实录分享
java·spring boot·小程序
zl9798991 小时前
SpringBoot-数据访问之MyBatis与Redis
java·spring boot·spring
K_i1341 小时前
Tomcat核心原理与运维实战指南
java·运维·tomcat
重生之我是Java开发战士2 小时前
【Java EE】快速上手Spring Boot
java·spring boot·java-ee
從南走到北2 小时前
JAVA国际版一对一视频交友视频聊天系统源码支持H5 + APP
java·微信·微信小程序·小程序·音视频·交友