百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Mybatis参数传递

bigegpt 2025-04-26 16:57 2 浏览


1. 概述

Mybatis的sql参数传递就是将接口方法中定义的参数传输到sql中。sql有两种形式,一种是XML格式(Mapper映射器)中的sql;一种是注解方式的sql。常用参数的类型主要包括:

  • 基本数据类型
  • Map类型
  • 自定义Bean类型

从参数传递的数量上来说,主要包括单参数和多参数形式。从传递参数的手段上来说,包括注解式和非注解式。下面主要讨论如何通过各种手段来传递单个和多个参数。

2. 单个参数的传递方式

单个参数的传递我们主要讨论单个基本数据类型参数的传递,单个参数(以下所说的单个参数都是指单个基本数据类型的参数)的传递是最简单也是最常用的。单个参数传递简单示例:

接口方法:

UserDO selectOneById(Long id);

xml配置:

<select id="selectOneById" parameterType="long" resultType="com.test.UserDO">
     select * from user where user_id=#{id}
</select>

这里需要说明一下:

  • 单个参数情况下,#{xx}中,“xx”的名称可以和接口方法中定义的变量名称不一致,“xx”甚至可以为任意名称。
  • 如果参数使用注解的话,那么#{xx}中“xx”的名称必须和@Param("xx")中“xx”的名称一致。
  • 如果使用@Select注解的话,@Select注解中的sql获取参数的方式和xml方式无异。

3. 多个参数的传递方式

多个参数的传递可以使用参数位置索引、List或者数组、Map封装和Bean封装的方式进行参数传递。

3.1 参数位置索引

有一个错误,估计很多人都见到过:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter 'xxx' not found. Available parameters are [arg1, arg0, param1, param2]

mybatis支持使用arg或者param加上参数位置索引来传递参数,arg的规则为:

  • 每个参数使用arg开头
  • 参数的位置从0开始,第一个参数为arg0,第二个参数为arg1,依次类推。
  • 条件表达式中(例如if的test)直接使用arg+index
  • sql语句中的使用方法和普通参数一样,#{arg+index}或者${arg+index}

一个简单的例子:

List<UserDO> selectListByCriteria1( String name,String phone);
<select id="selectListByCriteria1" resultType="com.test.User">
    select id, name,phone
    from user
    <trim prefix="where" suffixOverrides="and">
        <if test="arg0!=null and arg0!=''">
            name like concat('%',#{arg0},'%')
        </if>
        <if test="arg1!=null and arg1!=''">
            and phone=#{arg1}
        </if>
    </trim>
</select>

上面的例子中使用了arg+index的方式传递了参数,如果使用param,规则和arg0一样,只是index从1开始即可。

3.2 Map封装

使用Map封装方式来传递参数,我们只需要设置parameterType=“map”即可,现在将3.1中的例子换成map方式,如下:

List<UserDO> selectListByCriteria1(Map<String,String> map);
<select id="selectListByCriteria1" parameterType="map" resultType="com.test.User">
        select id, name,phone
        from user
    <trim prefix="where" suffixOverrides="and">
          <if test="name!=null and name!=''">
              name like concat('%',#{name},'%')
          </if>
          <if test="phone!=null and phone!=''">
              and phone=#{phone}
          </if>
    </trim>
</select>

3.3 JavaBean封装

使用JavaBean封装传递参数,需要设置parameterType为指定的JavaBean类型,将上面的例子修改为如下:

List<UserDO> selectListByCriteria1(UserDO user);
<select id="selectListByCriteria1" parameterType="map" resultType="com.test.User">
        select id, name,phone
        from user
    <trim prefix="where" suffixOverrides="and">
          <if test="name!=null and name!=''">
              name like concat('%',#{name},'%')
          </if>
          <if test="phone!=null and phone!=''">
              and phone=#{phone}
          </if>
    </trim>
</select>

3.4 使用注解方式

使用注解方式传递多个参数,就不需要设置parameterType的值,直接在sql语句中引用@Param中配置的参数名称,修改如下:

List<UserDO> selectListByCriteria1(@Param("name") String name,@Param("phone") String phone);
<select id="selectListByCriteria1" resultType="com.test.User">
        select id, name,phone
        from user
    <trim prefix="where" suffixOverrides="and">
          <if test="name!=null and name!=''">
              name like concat('%',#{name},'%')
          </if>
          <if test="phone!=null and phone!=''">
              and phone=#{phone}
          </if>
    </trim>
</select>

在xml中,不再需要设置parameterType的值,#{}中的值只需要和@Param中的值名称一样即可。注解方式是一种比较方便的传递多个参数的实现方式,但是参数个数不宜太多,如果五个以下还行,如果太多了,使用注解并不是一种最好的选择。

4. 传递数组或者可迭代集合

<foreach>标签在动态sql中使用频率是非常高的,这个时候一般会传入一个集合或者数组作为参数。我们先介绍下<foreach>的几个属性。

  • item:集合元素迭代时候使用的别名,也就是代表集合中的一个成员。
  • index:当集合是list或者数组的时候,index就是指的元素的序号,当集合是map时,指的是键。
  • open:集合中元素拼接开始符号。
  • separator:也是进行字符串拼接使用的,拼接每个元素时的分隔符。
  • close:和open对应,拼接字符串的结尾符号。
  • collection:循环迭代 的对象,这个属性稍微复杂以下,分为以下几种情况:如果是单参数,传入对象为List类型时,collection的值为list。如果是单参数,传入对象为数组时,collection的值为array。如果是一个map参数,需要迭代的对象是map中的一个值时,collection的值为对应的键。如果是一个JavaBean对象参数,collection的值为bean中集合的变量名称。

示例一:单参数,List类型对象

List<UserDO> selectListByCriteria1(List<String> names);
<select id="selectListByCriteria1" parameterType="list" resultType="com.test.UserDO">
    select id, name, phone
    from user
    where name in
    <foreach collection="list" separator="," index="" item="name" open="(" close=")">
        #{name}
    </foreach>
</select>

示例二:单参数,数组

List<UserDO> selectListByCriteria1(String[] names);
<select id="selectListByCriteria1"  resultType="com.test.UserDO">
    select id, name, phone
    from user
    where name in
    <foreach collection="array" separator="," index="" item="name" open="(" close=")">
        #{name}
    </foreach>
</select>

示例三:map

List<UserDO> selectListByCriteria1(Map<String,Object> map);

//在调用selectListByCriteria1方法时,将参数放入list,并将list放入Map中,map的键为names
map.put("names",list);
<select id="selectListByCriteria1" parameterType="map" resultType="com.test.UserDO">
    select id, name, phone
    from user
    where name in
    <foreach collection="names" separator="," index="" item="name" open="(" close=")">
        #{name}
    </foreach>
</select>

示例四:JavaBean

List<UserDO> selectListByCriteria1(TestDTO test);
//TestDTO中有一个属性 nameList
private List nameList;
<select id="selectListByCriteria1" parameterType="com.test.TestDTO" resultType="com.test.UserDO">
    select id, name, phone
    from user
    where name in
    <foreach collection="nameList" separator="," index="" item="name" open="(" close=")">
        #{name}
    </foreach>
</select>



相关推荐

得物可观测平台架构升级:基于GreptimeDB的全新监控体系实践

一、摘要在前端可观测分析场景中,需要实时观测并处理多地、多环境的运行情况,以保障Web应用和移动端的可用性与性能。传统方案往往依赖代理Agent→消息队列→流计算引擎→OLAP存储...

warm-flow新春版:网关直连和流程图重构

本期主要解决了网关直连和流程图重构,可以自此之后可支持各种复杂的网关混合、多网关直连使用。-新增Ruoyi-Vue-Plus优秀开源集成案例更新日志[feat]导入、导出和保存等新增json格式支持...

扣子空间体验报告

在数字化时代,智能工具的应用正不断拓展到我们工作和生活的各个角落。从任务规划到项目执行,再到任务管理,作者深入探讨了这款工具在不同场景下的表现和潜力。通过具体的应用实例,文章展示了扣子空间如何帮助用户...

spider-flow:开源的可视化方式定义爬虫方案

spider-flow简介spider-flow是一个爬虫平台,以可视化推拽方式定义爬取流程,无需代码即可实现一个爬虫服务。spider-flow特性支持css选择器、正则提取支持JSON/XML格式...

solon-flow 你好世界!

solon-flow是一个基础级的流处理引擎(可用于业务规则、决策处理、计算编排、流程审批等......)。提供有“开放式”驱动定制支持,像jdbc有mysql或pgsql等驱动,可...

新一代开源爬虫平台:SpiderFlow

SpiderFlow:新一代爬虫平台,以图形化方式定义爬虫流程,不写代码即可完成爬虫。-精选真开源,释放新价值。概览Spider-Flow是一个开源的、面向所有用户的Web端爬虫构建平台,它使用Ja...

通过 SQL 训练机器学习模型的引擎

关注薪资待遇的同学应该知道,机器学习相关的岗位工资普遍偏高啊。同时随着各种通用机器学习框架的出现,机器学习的门槛也在逐渐降低,训练一个简单的机器学习模型变得不那么难。但是不得不承认对于一些数据相关的工...

鼠须管输入法rime for Mac

鼠须管输入法forMac是一款十分新颖的跨平台输入法软件,全名是中州韵输入法引擎,鼠须管输入法mac版不仅仅是一个输入法,而是一个输入法算法框架。Rime的基础架构十分精良,一套算法支持了拼音、...

Go语言 1.20 版本正式发布:新版详细介绍

Go1.20简介最新的Go版本1.20在Go1.19发布六个月后发布。它的大部分更改都在工具链、运行时和库的实现中。一如既往,该版本保持了Go1的兼容性承诺。我们期望几乎所...

iOS 10平台SpriteKit新特性之Tile Maps(上)

简介苹果公司在WWDC2016大会上向人们展示了一大批新的好东西。其中之一就是SpriteKitTileEditor。这款工具易于上手,而且看起来速度特别快。在本教程中,你将了解关于TileE...

程序员简历例句—范例Java、Python、C++模板

个人简介通用简介:有良好的代码风格,通过添加注释提高代码可读性,注重代码质量,研读过XXX,XXX等多个开源项目源码从而学习增强代码的健壮性与扩展性。具备良好的代码编程习惯及文档编写能力,参与多个高...

Telerik UI for iOS Q3 2015正式发布

近日,TelerikUIforiOS正式发布了Q32015。新版本新增对XCode7、Swift2.0和iOS9的支持,同时还新增了对数轴、不连续的日期时间轴等;改进TKDataPoin...

ios使用ijkplayer+nginx进行视频直播

上两节,我们讲到使用nginx和ngixn的rtmp模块搭建直播的服务器,接着我们讲解了在Android使用ijkplayer来作为我们的视频直播播放器,整个过程中,需要注意的就是ijlplayer编...

IOS技术分享|iOS快速生成开发文档(一)

前言对于开发人员而言,文档的作用不言而喻。文档不仅可以提高软件开发效率,还能便于以后的软件开发、使用和维护。本文主要讲述Objective-C快速生成开发文档工具appledoc。简介apple...

macOS下配置VS Code C++开发环境

本文介绍在苹果macOS操作系统下,配置VisualStudioCode的C/C++开发环境的过程,本环境使用Clang/LLVM编译器和调试器。一、前置条件本文默认前置条件是,您的开发设备已...