Mybatis中条件传入多个参数时,如何处理

entity:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {private Integer id;private String username;private String password;private String phone;private String address;
}

dao接口:

public interface UserDAO {List<User> selectAllByNameAndPhone(String username,String phone);List<User> selectAllByDTO(UserDTO userDTO);List<User> selectByMap(Map<String,String> map);User selectById(Integer id);List<User> selectByName(String username);List<User> orderByColumn(String column);}

mapper.xml映射文件:

<!--    <select id="selectAllByNameAndPhone" resultType="user">-->
<!--        <include refid="baseQuery"/> where username like concat('%',#{username},'%') and phone like concat('%',#{phone},'%')-->
<!--    </select>--><select id="selectAllByNameAndPhone" resultType="user"><include refid="baseQuery"/> where username like concat('%',#{arg0},'%') and phone like concat('%',#{arg1},'%')</select><!--    <select id="selectAllByNameAndPhone" resultType="user">-->
<!--        <include refid="baseQuery"/> where username like concat('%',#{param1},'%') and phone like concat('%',#{param2},'%')-->
<!--    </select>--><!--    <select id="selectAllByNameAndPhone" resultType="user">-->
<!--        <include refid="baseQuery"/> where username like concat('%',#{arg0},'%') and phone like concat('%',#{param2},'%')-->
<!--    </select>-->

测试类:

    @Testpublic void selectAllByNameAndPhone(){List<User> userList = userDAO.selectAllByNameAndPhone("sm", "4");userList.forEach(System.out::println);}@Testpublic void selectAllByDTO(){List<User> userList = userDAO.selectAllByDTO(new UserDTO("sm","4"));userList.forEach(System.out::println);}@Testpublic void selectByMap(){Map<String,String> map = new HashMap<>(2);map.put("username","smith");map.put("phone","1");List<User> userList = userDAO.selectByMap(map);userList.forEach(System.out::println);}

测试结果:

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

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

相关文章

C++ 如何去认识模板

引言: C模板是泛型编程的基石,允许程序员定义可与任何数据类型协作的函数和类。这种机制极大地增加了代码的灵活性和复用性,是C最强大的特性之一。本文将深入探讨C模板的概念、优势以及使用方法,帮助读者掌握这一重要的编程工具。 文章目录 模板简介模板的优势一、模板基础1.1…

基于vue+element+springboot+uniapp开发的智慧城管源码,java智慧城市管理综合执法系统源码

智慧城管源码&#xff0c;智慧执法&#xff0c;数字化城市管理综合执法系统源码 智慧城管系统充分利用物联网、云计算、信息融合、网络通讯、数据分析与挖掘等技术&#xff0c;对城市管理进行全方位覆盖。它通过建立城市综合管理平台&#xff0c;将城市的信息和管理资源有机结合…

Qt_day5:2024/3/26

作业&#xff1a;实现闹钟 代码&#xff1a; 头文件&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTimerEvent> //定时器事件 #include <QTime> //时间类 #include <QtTextToSpeech> //文本转语音类 #include <…

hgvs中的[数字]是什么意思

hgvs中的[数字],例如NM_144670.6(A2ML1):c.462+9GGA[5]中的[5]详细解释: Repeated Sequences# Repeated sequence: a sequence where, compared to a reference sequence, a segment of one or more nucleotides (the repeat unit) is present several times, one after the…

错误 LNK1104 无法打开文件“mfc140.lib”

如图&#xff0c;编译一个别人已有的项目&#xff0c;我的编译报错为&#xff1a; 但是我所有文件夹全局搜索了一下&#xff0c;这个文件是存在的。但是当前项目访问不到。 更改方法&#xff1a;项目->属性->配置属性->VC目录->库目录 全局搜索找到mfc140.lib的…

【LeetCode 算法专题突破】定长滑动窗口

文章目录 前言[1456. 定长子串中元音的最大数目](https://leetcode.cn/problems/maximum-number-of-vowels-in-a-substring-of-given-length/)题目描述&#xff1a;难度分1263代码与解题思路代码复盘 [2269. 找到一个数字的 K 美丽值](https://leetcode.cn/problems/find-the-k…

如何在pycharm中使用anaconda的虚拟环境

https://blog.csdn.net/weixin_43486940/article/details/123229290

MySQL: 数据类型

数值类型 整型类型 TINYINT&#xff1a;8位SMALLINT&#xff1a;16位MEDIUMINT&#xff1a;24位INT 或 INTEGER&#xff1a;32位BIGINT: 64位 浮点类型 FLOAT&#xff1a;单精度浮点数DOUBLE 或 REAL&#xff1a;双精度浮点数 字符串类型 定长字符串类型 CHAR(size)&…

NAT---网络地址转换技术

Network Address Translation 1、起源&#xff1a;ip地址不够用 2、作用&#xff1a;让私网地址映射成公网地址&#xff0c;进而访问网络。 3、私网Ip地址的范围&#xff1a; A类&#xff1a;10.0.0.0-10.255.255.255 B类&#xff1a;172.16.0.0-172.31.255.255 C类&…

10本程序员必看的书籍

以下是10本程序员必看的书籍推荐&#xff1a; **1.《代码大全》&#xff1a;**史蒂夫迈克康奈尔著。这本书是编程最佳实践指南之一&#xff0c;它详细讲解了如何编写整洁、高效的代码&#xff0c;对于提升编程技能和代码质量有很大帮助。 **2.《深入理解计算机系统》&#xff1…

码垛机与人工搬运:效率与安全性的比较分析

在现代包装行业中&#xff0c;泡沫箱因其轻便和保温特性被广泛用于商品的包装与运输。随着自动化技术的不断发展&#xff0c;码垛机成为提升泡沫箱生产效率、降低劳动强度的关键技术。本文旨在比较码垛机与人工码垛在泡沫箱生产中的优势&#xff0c;并探讨自动化码垛的未来发展…

代码随想录算法训练营DAY3| C++链表Part.1|LeetCode:203.移除链表元素、707.设计链表、206.反转链表

文章目录 203.移除链表元素直接操作原链表虚拟头结点 707.设计链表定义链表结构体MyLinkedList() 初始化 MyLinkedList 对象。int get(int index)void addAtHead(int val)void addAtTail(int val)void addAtIndex(int index, int val)void deleteAtIndex(int index)void printL…

Python程序设计 模块和包

1. 模块和包 1.1 模块&#xff1a; 一个 py 文件&#xff0c;就是一个模块&#xff0c;文件中包括定义的函数和类等信息。 尽管可以 import 多次&#xff0c;实际上模块只导入一次 模块搜索路径内存中已经加载的模块 -> 内置模块 -> sys.path路径&#xff08;导模块的…

Springboot快速整合bootstrap-table使用,接口对接

这个表格加持还是不错了&#xff0c;自带了全局搜索&#xff0c;分页&#xff0c;数据导出&#xff0c;卡片视图&#xff0c;等&#xff0c;本次整合添加了数据添加弹窗和编辑数据回显弹窗&#xff0c;附完整页面代码&#xff0c;只需要拿过来替换自己实际的接口即可。 效果图 …

鸿蒙实战开发-如何通过拖动滑块调节应用内字体大小

介绍 本篇Codelab将介绍如何使用基础组件Slider&#xff0c;通过拖动滑块调节应用内字体大小。要求完成以下功能&#xff1a; 实现两个页面的UX&#xff1a;主页面和字体大小调节页面。拖动滑块改变字体大小系数&#xff0c;列表页和调节页面字体大小同步变化。往右拖动滑块字…

ppp验证实验

实际操作图 1&#xff0c;IP划分分配 [r1]interface Serial 4/0/0 [r1-Serial4/0/0]ip add 192.168.1.1 24 [r2]interface Serial 4/0/0 [r2-Serial4/0/0]ip address 192.168.1.2 24 [r2]int Mp-group 0/0/0 [r2-Mp-group0/0/0]ip add 192.168.2.1 24 [r3]int Mp-group 0/…

Xcode Launching “XXX“ is taking longer than expected

文章目录 1.问题2.如何进入iOS DeviceSupport目录3.解决方法4.参考博客 1.问题 LLDB is likely reading from device memory to resolve symbols 2.如何进入iOS DeviceSupport目录 3.解决方法 进入iOS DeviceSupport目录&#xff0c;删除该真机对应的架构文件&#xff08;比如…

QT作业day3

1、使用手动连接&#xff0c;将登录框中的取消按钮使用qt4版本的连接到自定义的槽函数中&#xff0c;在自定义的槽函数中调用关闭函数 将登录按钮使用qt5版本的连接到自定义的槽函数中&#xff0c;在槽函数中判断ui界面上输入的账号是否为"admin"&#xff0c;密码是…

JMeter 如何并发执行 Python 脚本

要在JMeter中并发执行Python脚本&#xff0c;可以使用Jython脚本或通过调用外部Python脚本的方式实现。 使用Jython脚本并发执行Python脚本的步骤&#xff1a; 1、创建一个线程组&#xff1a;在JMeter界面中&#xff0c;右键点击测试计划&#xff0c;选择 “添加” -> “线…

c语言文件操作(下)

目录 1.文件的随机读写1.1 fseek1.2 ftell1.3 rewind 2. 文件结束的判定2.1 文本文件读取结束的判断2.2 二进制文件读取结束的判断 3. 文件缓冲区 1.文件的随机读写 1.1 fseek 根据⽂件指针的位置和偏移量来定位⽂件指针。 函数原型&#xff1a; int fseek (FILE * stream,…