映射文件中查询语句部分:
接口文件中对应的查询方法:
测试代码:
map中的key值与映射文件中的select语句#{}占位符中的值需要一一对应
在mybatis中,任何传入的参数都会被对应封装成Map集合,然后会以map的key=value形式取值。
对传入的参数是List集合,mybatis会对list集合进行特殊处理,其取值方式通过list[下标]或collection[下标]的方式入参取值。
对于数组,Mybatis同样会做特殊处理,它会对数组采用array[下标]的方式入参取值。
Mybatis查询传递Map参数 使用场景mybaits传递Map查询数据,choose里面的判断根据自己的map参数类型自行使用,这里传的value是Object类型,这里用不到
这里需要注意的一点是${K},首先map的key一定要跟数据表字段保持一致。如果这里的${K}写成了#{K}则生成的sql语句如下所示:
程序不会报错,条件无效。${}和#{}的区别相信大家都了解,简单概括就是一个是替换占位符,一个是当做参数传入
传参 持久层 生成sql 查询结果总结:这样的好处是参数的个数不固定、参数的类型不固定,适用的场景较多。缺点也很明显map传参可读性差,参数难以控制等。以上为个人经验,希望能给大家一个参考,也希望大家多多支持七叶笔记。