我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mybatis条件语句中带数组参数的处理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mybatis条件语句中带数组参数的处理

mybatis条件语句中带数组参数

如题,在mybatis编写sql语句的时候,可能会遇到in这样的关键字,我们知道in后面需要接上('a','b','c')这样的一个结构。它像一个数组,但是是用括号()包裹的,参数之间还有逗号隔开。

这里因为数组参数是变量,直接通过拼接的方式不可行。

这里需要一个标签foreach,标签可以有item,collection,open,close,separator等属性,分别表示变量,变量集合,开始符号,结束符号,分隔符。

这里给出一个示例

定义返回对象


<resultMap type="com.xxx.springmybatis.domain.User" id="UserResult">
  <id column="id" jdbcType="BIGINT" property="id"/>
  <result column="name" jdbcType="VARCHAR" property="name"/>
  <result column="email" jdbcType="VARCHAR" property="email"/>
</resultMap>

编写sql语句


<select id="findByIds" resultMap="UserResult" parameterType="list">
     select * from users
     where id in
     <foreach collection="list" item="id" open="(" close=")" separator=",">
      #{id,jdbcType=BIGINT}
     </foreach>
</select>

定义dao方法:


package com.xxx.springmybatis.dao;
import java.util.List;
import com.xxx.springmybatis.domain.User;
public interface UserMapper {
    User getById(Integer id);
    User getByName(String name);
    void save(User user);    
    List<User> findByIds(List<Integer> ids);
}

以上的示例,是通过id数组来查询对应的用户集合。我们传入的用户ID,最终在sql中会通过拼接的方式组成where id in (3,4)的条件。

如下所示,如果要查询id为3,4的用户,那么打印的sql语句可以看出拼接的样子:

这里有必要说明的是foreach标签中的collection属性

1、List集合,默认使用list代表入参,数组,默认使用array作为入参。

2、如果传入的参数是一个对象,对象User有个属性List ids,那么就使用ids作为入参。

3、如果接口声明的地方通过注解@Param("xx")指定了入参,那么list,array这种默认的参数就失效,这时候需要指定xx为入参。

本例中因为使用的是List集合传入,所以默认就使用了list作为collection入参的键。

mybatis多参数传递(其中包括数组)

mapper接口


public void batchDelete(@Param(value = "activityId") Integer activityId, @Param(value = "userIds") Integer[] userIds);

mapper.xml的配置


<insert id="batchDelete">
     delete from T_ACT_USERS where ACTIVITY_ID = #{activityId}
     and USER_ID in
     <foreach collection="userIds" item="item" index="index" open="(" separator="," close=")">
            #{item}
     </foreach>
</insert>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mybatis条件语句中带数组参数的处理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MyBatis ORM的SQL语句条件参数化

MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和
MyBatis ORM的SQL语句条件参数化
2024-09-16

MyBatis ORM的SQL语句条件参数绑定优化

MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。在 MyBatis 中,我们可以使用动态 SQL 来实现条件参数绑定,从而优化 SQL 语句的执行性能。以下是一些建议和技巧,可以帮助你优化 MyBati
MyBatis ORM的SQL语句条件参数绑定优化
2024-09-11

MyBatis ORM的SQL语句条件异常处理

MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。在 MyBatis 中,你可以使用动态 SQL 来处理不同的条件,以实现更灵活的查询。要处理 MyBatis ORM 的 SQL 语句条件异常,你可以采用
MyBatis ORM的SQL语句条件异常处理
2024-09-11

MyBatis ORM的SQL语句条件函数使用

MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。在 MyBatis 中,你可以使用动态 SQL 来实现条件查询。动态 SQL 允许你根据不同的条件生成不同的 SQL 语句。MyBatis 提供了一些内置
MyBatis ORM的SQL语句条件函数使用
2024-09-11

MyBatis ORM的SQL语句条件复杂查询处理

MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。在 MyBatis 中,你可以编写复杂的 SQL 语句来满足各种查询需求。以下是一些建议和技巧,帮助你更好地处理 MyBatis ORM 中的 SQL 语句
MyBatis ORM的SQL语句条件复杂查询处理
2024-09-11

如何使用C++中的条件语句函数?

如何使用C++中的条件语句函数?条件语句函数是C++编程中常用的一种函数类型,它根据给定的条件执行不同的代码块。条件语句函数包括if语句、switch语句和三元运算符等,它们在实际的编程过程中非常有用。本文将介绍如何在C++中使用条件语句函
如何使用C++中的条件语句函数?
2023-11-18

Mybatis和orcale update语句中接收参数为对象的实例代码

Mybatis的 mapper.xml 中 update 语句使用 if 标签判断对像属性是否为空值。 UserDTO是传过来参数的类型,userDTO是在mapperDao接口中给更新方法的参数起的别名。 mapperDao.jav
2023-05-31

Go语言中路由参数的处理方法

Go语言中路由参数的处理方法在Web开发中,路由参数的处理是一项必须掌握的技能。在Go语言中,我们可以使用gorilla/mux包来处理路由参数,它是一个强大的路由库,提供了许多处理路由的方法。首先,让我们先来了解一下什么是路由参数。在We
Go语言中路由参数的处理方法
2023-12-17

如何使用关于C#事件处理函数中的参数

本篇内容介绍了“如何使用关于C#事件处理函数中的参数”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、是事件源,表示触发事件的那个组件如(b
2023-06-15

C++ 函数异常处理中的 throw 和 rethrow 语句的作用是什么?

异常处理中的 throw 语句用于抛出异常,rethrow 语句用于在捕获的异常中再次抛出相同的异常。throw 语句的语法为:throw exception_object; rethrow 语句的语法为:rethrow; throw 和
C++ 函数异常处理中的 throw 和 rethrow 语句的作用是什么?
2024-04-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录