[mybatis]映射文件_参数处理

参数处理

  • 单个参数:mybatis不会做特殊处理

    • #{参数名}:取出参数值
  • 多个参数:mybatis会做特殊处理

    • 多个参数会被封装成一个map
      • key:param1…paramN,或者参数的索引
      • value:传入的参数值
    • #{}就是从map中获取指定的key的值;
  • 命名参数:明确指定封装参数时map的key:@Param(“id”)

    • 多个参数会被封装成一个map
      • key:使用@Param注解指定值
      • value:参数值
    • #{指定的key}取出对应的参数值
  • pojo

    • 如果多个参数正好是我们业务逻辑的数据模型,我们就可以直接传入pojo;
    • #{属性名}:取出传入的pojo的属性值
  • 如果多个参数不是业务模型中的数据,没有对应的pojo,为了方便,我们也可以传入map

    • #{key}:取出map中对应的值
  • TO

    • 如果多个参数不是业务模型中的数据,但是经常使用,推荐来编写一个TO(Transfer Object)数据传输对象
//TO
Page
{int index;int size;
}
    public Employee getEmpByIdAndLastName(Integer id,String lastName);
 <select id = "getEmpByIdAndLastName" resultType="com.atguigu.mybatis.bean.Employee">select * from tb1_employee where id = #{id} and last_name = #{lastName}</select>
   Employee employee = mapper.getEmpByIdAndLastName(1, "Admin");

报错:

org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: org.apache.ibatis.binding.BindingException: Parameter 'id' not found. Available parameters are [arg1, arg0, param1, param2]
### Cause: org.apache.ibatis.binding.BindingException: Parameter 'id' not found. Available parameters are [arg1, arg0, param1, param2]

正确写法:

    <select id = "getEmpByIdAndLastName" resultType="com.atguigu.mybatis.bean.Employee">select * from tb1_employee where id = #{param1} and last_name = #{param2}</select>

命名参数法:

    public Employee getEmpByIdAndLastName(@Param("id") Integer id,@Param("lastName") String lastName);
    <select id = "getEmpByIdAndLastName" resultType="com.atguigu.mybatis.bean.Employee">select * from tb1_employee where id = #{id} and last_name = #{lastName}</select>

map法:

  public Employee getEmpByMap(Map<String ,Object> map);
    <!--public Employee getEmpByMap(Map<String,Object> map);--><select id="getEmpByMap" resultType="com.atguigu.mybatis.bean.Employee">select * from tb1_employee where id = #{id} and last_name = #{lastName}</select>
    Map<String,Object> map = new HashMap<>();map.put("id",1);map.put("lastName","Tom");Employee employee = mapper.getEmpByMap(map);

扩展思考:

public Employee getEmp(@Param("id") Integer id,String lastName);

取值:
id -> #{id/param1}
lastName -> #{param2}

public Employee getEmp( Integer id,@Param("e") Employee emp);

取值:
id -> #{param1}
lastName -> #{param2.lastName/e.lastName}

  • 特别注意:如果是Collection(List,Set)类型或者数组,也会特殊处理。也是把传入的list或者数组封装在map中
    • key:Collection(collection),如果是List还可以使用这个key(list),数组(array)
public Employee getEmp(List<Integer> ids);

取值:
取出第一个id的值:
#{list[0]}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308833.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

骚年快答 | 技术中台与业务中台都是啥?

【答疑解惑】| 作者 / Edison Zhou这是恰童鞋骚年的第262篇原创内容最近有童鞋在我之前发布的《聊聊中台》一文中提问&#xff1a;技术中台是什么&#xff1f;和业务中台又有什么区别&#xff1f;考虑到在工作中&#xff0c;也有部分同事问过这个问题&#xff0c;我这里总结一下…

[mybatis]映射文件_参数处理_#和$取值区别

#{}&#xff1a;可以获取map中的值或者pojo对象属性的值${}&#xff1a;可以获取map中的值或者pojo对象属性的值 区别&#xff1a; #{}&#xff1a;是以预编译的形式&#xff0c;将参数设置到sql语句中&#xff0c;相当于原生jdbc的PreparedStatement&#xff1b;防止sql注入${…

平台or职位,你怎么选?

这里是Z哥的个人公众号每周五11&#xff1a;45 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「150」篇原创敬上大家好&#xff0c;我是Z哥。这周有位小伙伴和我聊到一个问题&#xff0c;选择工作的时候是平台重要还是职位重要&#xff1f;我想&#xff0c;很…

闲谈设计模式

闲谈设计模式Intro设计模式&#xff08;Design Pattern&#xff09;是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。了解这些前辈们总结出来的经验有助于帮助你写出来更优秀的代码&#xff0c;帮助你写出可扩展、可读、可维护的高质量代码。在极客时间里推出…

[mybatis]log4j

引入依赖&#xff1a; <dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency>在资源文件下写一个log4j配置文件: <?xml version"1.0" encoding"UT…

eShopOnContainers 知多少[11]:服务间通信之gRPC

1. 引言最近翻看最新3.0 eShopOncontainers源码&#xff0c;发现其在架构选型中补充了 gRPC 进行服务间通信。那就索性也写一篇&#xff0c;作为系列的补充。2. gRPC老规矩&#xff0c;先来理一下gRPC的基本概念。gRPC是Google开源的RPC框架&#xff0c;比肩dubbo、thrift、brp…

[mybatis]映射文件_参数处理_#取值时指定参数相关规则

jdbcType通常需要在某种特定的条件下被设置&#xff1a; 在我们数据为null的时候&#xff0c;有些数据库可能不能识别mybatis对null的默认处理。比如Oracle&#xff08;报错&#xff09;&#xff1b;jdbcType OTHER&#xff1a;无效的类型&#xff1b;因为mybatis对所有的null映…

龙芯开源社区上线.NET主页

龙芯团队从2019年7 月份开始着手.NET Core的MIPS64支持研发&#xff0c;经过将近一年的研发&#xff0c;在2020年6月18日完成了里程碑性的工作&#xff0c;在github CoreCLR 仓库&#xff1a;https://github.com/gsvm/coreclr&#xff0c; 随后受到.NET社区的很大参与热情鼓舞之…

[mybatis]映射文件_select_返回集合(List,Map)

select返回List public interface EmployeeMapper {public List<Employee> getEmpsByLastNameLike(String lastName);}<!-- public List<Employee> getEmpsByLastNameLike(String lastName);--><!--resultType;如果返回的是一个集合&#xff0c;要写集…

免费 | 数千个 Azure 官方高清矢量图标大放送!

点击上方关注“汪宇杰博客” ^_^导语我们平时绘制云应用架构图时&#xff0c;经常要用 Azure 各项服务的图标。不知各位会自己去截图&#xff0c;还是在浏览器 F12 里使劲抠图&#xff1f;是不是做PPT 5分钟&#xff0c;扣图2小时&#xff1f;现在用不着自己使劲啦&#xff0c;…

[mybatis]select_resultMap_自定义结果集映射规则

resultMap 自定义某个javaBean的封装规则 type&#xff1a;自定义规则的Java类型id&#xff1a;唯一id方便引用 指定主键列的封装规则 id&#xff1a;定义主键底层会有优化column&#xff1a;指定哪一列property&#xff1a;指定对应的javaBean属性 public interface Employ…

设计模式中的那些工厂

设计模式中的那些工厂Intro设计模式中有几个工厂模式&#xff0c;聊一聊这几个工厂模式的各自用法和使用示例&#xff0c;工厂模式包含简单工厂&#xff0c;抽象工厂&#xff0c;工厂方法&#xff0c;这些均属于创建型模式&#xff0c; 所谓创建型模式&#xff0c;就是说这几个…

[mybatis]映射文件_select_resultMap_关联查询

普通方式 public class Employee {private Integer id;private String lastName;private String email;private String gender;private Department dept;}public class Department {private Integer id;private String departmentName;}public interface EmployeeMapperPlus {…

使用sqlserver搭建高可用双机热备的Quartz集群部署

一般拿 Timer 和 Quartz 相比较的&#xff0c;简直就是对 Quartz 的侮辱&#xff0c;两者的功能根本就不在一个层级上&#xff0c;如本篇介绍的Quartz强大的集群机制&#xff0c;可以采用基于sqlserver&#xff0c;mysql的集群方案&#xff0c;当然还可以在第三方插件的基础上实…

从Memcached到Redis,从RabbitMQ到Kafka,为了高并发,这些年我们不容易!

周一上班又撕了一页台历&#xff0c;随即心里头却是一惊。如今高考落下帷幕&#xff0c;不曾想2020竟已过了一半&#xff01;这一年又是疫情又是洪水&#xff0c;我们的目光被各种重大事件所吸引&#xff0c;此时审视一下自己&#xff0c;突然觉得不踏实了&#xff01;一场疫情…

[mybatis]动态sql_if_where_trim判断OGNL

OGNL if 要求&#xff1a;查询员工&#xff0c;要求&#xff0c;携带了哪个字段查询条件就带上这个字段的值 //携带了哪个字段查询条件就带上这个字段的值public List<Employee> getEmpsByConditionIf(Employee employee);<!-- public List<Employee> getEm…

通过 Continual Learning 提高 ML.NET 模型准确性并增强性能

从事机器学习的学者大多认为持续学习&#xff08;Continual Learning&#xff09;是迈向人工智能的根本一步。持续学习是模型模仿人类在整个生命周期中不断从数据流中学习、微调、转移知识和技能的能力。实际上&#xff0c;这意味着模型在进入新数据时能自主学习和适应生产。过…

[mybatis]动态sql_choose_分支选择

choose 如果带了id就用id查&#xff0c;如果带了lastName就用lastName查&#xff1b;只会进入其中一个 public List<Employee> getEmpByConditionChoose(Employee employee);<!-- public List<Employee> getEmpByConditionChoose(Employee employee);-->…

7.15周三晚8点,dotnet课堂全新起航,张善友/陈计节/刘腾飞我们一起来聊聊abp的故事...

直播主题&#xff1a;我们和Abp的故事直播嘉宾&#xff1a;张善友&#xff0c;陈计节&#xff0c;刘腾飞直播话题张善友&#xff1a;我是如何使用Abp的刘腾飞&#xff1a;利用Abp的模块化解决单体和分布式混合架构陈计节&#xff1a;Abp开源项目的DevOps实践Abp VNext 处于被低…

[mybatis]动态sql_set_与if结合的动态更新

因为sql语句拼装后&#xff0c;set语句后面可能会多一个逗号&#xff0c;所以要用set标签 set <!-- public void updateEmp(Employee employee);--> <update id"updateEmp">update tb1_employee<set><if test "lastName!null"&…