MyBatis查询接收数据 批量删除

news2024/11/18 6:01:44

MyBatis查询接收数据 批量删除

  • 查询出的数据只有一条
    • 通过实体类对象接收
    • 通过List集合接收
    • 通过map集合接收
  • 查询出的数据有多条
    • 通过list集合接收
    • 通过map类型的list集合接收
    • @MapKey注解
  • 模糊查询
  • 批量删除
  • ${}和#{}的区别


查询出的数据只有一条

通过实体类对象接收

mapper接口代码:

在这里插入图片描述

映射文件:

    <!--TUser getUserById(@Param("id") Integer id);-->
    <select id="getUserById" resultType="tUser">
        select * from t_user where id = #{id}
    </select>

通过List集合接收

mapper接口代码:

在这里插入图片描述

映射文件:

 <!--List<TUser> getUserById(@Param("id") Integer id);-->
    <select id="getUserById" resultType="tUser">
        select * from t_user where id = #{id}
    </select>

resultType属性里面此时是想将接收过来的数据库取来的字段转换成对应实体类的名称,但既然要转换成实体类对象,那肯定是有前提的,这个前提就是字段名与实体类属性一一对应


那么问题来了?
如果此时我们没有创建实体类来接收数据,那么接收数据该由谁来完成呢

通过map集合接收

mapper接口代码:

在这里插入图片描述

映射文件:

    <!--   Map<String,Object> getUserByIdToMap();-->
    <select id="getUserByIdToMap" resultType="java.util.Map">
        select * from t_user where id = #{id}
    </select>

查询出的数据有多条

通过list集合接收

mapper接口代码:

在这里插入图片描述

映射文件:

<!--List<TUser> getAllUser();-->
    <select id="getAllUser" resultType="tUser">
        select * from t_user
    </select>

通过map类型的list集合接收

mapper接口代码:

在这里插入图片描述

映射文件:

 <!--List<Map<String,Object>> getAllUserToMap();-->
    <select id="getAllUserToMap" resultType="map">
        select * from t_user;
    </select>

看到这里不知道大家有没有发现什么问题
在这里插入图片描述
我们明明没有在配置文件里面给Map类的全类名设置别名,为什么可以直接给这写成map呢?
MyBatis中设置了默认的类型别名

java.lang.Integer-->int,integer
int-->_int,_Integer
Map-->map
String-->string

@MapKey注解

如果接受多个数据时,我们没有实体类也不想用list集合
可以在mapper接口的方法上添加@MapKey注解,此时就可以将每条数据转换的map集合作为值,以某个字段的值作为键,放在同一个map集合中

mapper接口:

在这里插入图片描述

映射文件:

  <!--Map<String,Object> getAllUserToMap();-->
    <select id="getAllUserToMap" resultType="map">
        select * from t_user;
    </select>

模糊查询

mapper接口:

在这里插入图片描述

映射文件:

    <!--List<TUser> getUserByLike(@Param("username")String username);-->
    <select id="getUserByLike" resultType="com.yc.mybatis.pojo.TUser">
        select * from t_user where username like '%${username}%'
       <!-- select * from t_user where username like concat('%',#{username},'%')-->
       <!--select * from t_user where username like "%"#{username}"%"-->
    </select>

批量删除

mapper接口:

在这里插入图片描述

映射文件:

    <!--int deleteMore(@Param("ids") String ids);-->
    <delete id="deleteMore">
        delete from t_user where id in(${ids})
    </delete>

${}和#{}的区别

#{}相当于事先给sql语句形成占位符,之后将占位符拿参数依次替换掉占位符
${}就可以想象成我们最开始学JDBC的时候sql语句拼接一样
所以为了防止SQL注入,一般都会选择#{}
但在模糊查询和批量删除的时候,却选择的时在这里插入图片描述
因为
在这里插入图片描述
如果是#{}那sql语句会先变成’%?%‘,但在?被’‘包裹着,所以就起不到占位符的作用了
在这里插入图片描述
如果是#{}那么value值就会变为’1,2,3’,不符合参数条件

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

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

相关文章

Lr 12 ACR 15:传统蒙版工具

在 Lr 或 ACR 中&#xff0c;可以用各种不同的方式创建或添加蒙版。其中主题、天空、背景、对象及人物&#xff08;若照片上有&#xff09;都是由 AI 技术提供支持。画笔、线性渐变、径向渐变、范围等是传统的蒙版工具。画笔Brush手动绘制要选择的区域。创建一个画笔&#xff1…

C#,图像二值化(24)——局部阈值算法的NiBlack算法及源程序

1、局部阈值算法的NiBlack算法摘要-医学图像的处理最为复杂人和计算机。磁性捐赠的脑组织共振成像&#xff08;MRI&#xff09;在许多领域是非常重要的问题例如手术和治疗。最常见的分割图像的最简单方法是使用阈值。在这项工作中&#xff0c;我们提出了一个有效的实现阈值&…

SpringBoot整合Mybatis和MybatisPlus

目录 一、整合MyBatis操作 1、配置模式 2、注解模式 3、混合模式 二、整合 MyBatis-Plus 完成CRUD 1、什么是MyBatis-Plus 2、整合MyBatis-Plus 3、CRUD功能 一、整合MyBatis操作 官网&#xff1a;MyBatis GitHub SpringBoot官方的Starter&#xff1a;spring-boot-st…

兼容东西,贯通南北:超聚变的“四水归堂”

四水归堂&#xff0c;是中国建筑艺术中的一种独特形式。这种形式下&#xff0c;由四面房屋围出一个天井&#xff0c;房屋内侧坡向天井内倾斜&#xff0c;下雨时雨水会从东西南北四方流入天井&#xff0c;从而起到收集水源&#xff0c;防涝护屋的作用&#xff0c;寓意水聚天心&a…

每日一问-ChapGPT-20230114-关于小年

文章目录每日一问-ChapGPT系列起因每日一问-ChapGPT-20230114-关于小年腊月每天都做些什么的歌谣为什么现在的年味淡了很多&#xff0c;感觉不到过年为什么春节放假要调休&#xff0c;不能多放几天吗说说现在世界上极端气候&#xff0c;以及多少年后&#xff0c;地球存在不适宜…

Asp.Net项目的部署到Linux中(Linux + Jexus+Nginx )

因为老项目用的Asp.Net Web API技术开发部署到Window系统上&#xff0c;而新项目用的是.Net Core部署到Ubuntu系统中&#xff0c;所以在管理切换上有些不便。于是决定将老项目的测试服部署到Ubuntu中&#xff0c;试试水。 一、简述 要实现Asp.Net项目部署到Linux中&#xff0c…

C语言入门教程|| C语言 程序结构|| C语言 基本语法

在我们学习 C 语言的基本构建块之前&#xff0c;让我们先来看看一个最小的 C 程序结构&#xff0c;在接下来的章节中可以以此作为参考。 C 程序主要包括以下部分&#xff1a; 预处理器指令函数变量语句 & 表达式注释 让我们看一段简单的代码&#xff0c;可以输出单词 &qu…

Anfis-基于模糊推理的自适应神经网络程序(免费分享)

输出结果展示&#xff1a;完整代码&#xff1a;clear;close all;gamma0.75;%设定惯性因子eps10.005;%设定停止训练的条件参数m18;%设定隶属函数个数m28;a-1;b1;w0a(b-a)*rand(1,m1*m2);%初始化权值阵for i1:2switch icase 1,beta0.75;%设定学习率otherwise,beta0.25;endc[2/7*(…

ESP-IDF:链表例程实现创建,增加,打印数据成员,释放链表空间等功能

链表例程&#xff1a; typedef struct LISTNODE { void *data_p; LISTNODE *next; } mlistnode; typedef struct MYLIST { int size; mlistnode *head; } mylist; mylist *initial_mylist() { mylist *p (mylist *)malloc(sizeof(mylist)); p->size 0; p->head (ml…

下载指定的tomcat版本和配置

如何下载指定的tomcat版本 tomcat官网:https://archive.apache.org/ tomcat指定版本下载地址&#xff1a;https://archive.apache.org/dist/tomcat/ 找到指定的版本&#xff0c;例如这里要找到tomcat8.0.1 bin是二进制文件&#xff0c;src是源码文件 配置tomcat环境变量 t…

Paddle进阶实战系列(二):智慧交通预测系统

✨写在前面&#xff1a;强烈推荐给大家一个优秀的人工智能学习网站&#xff0c;内容包括人工智能基础、机器学习、深度学习神经网络等&#xff0c;详细介绍各部分概念及实战教程&#xff0c;通俗易懂&#xff0c;非常适合人工智能领域初学者及研究者学习。➡️点击跳转到网站。…

[ 环境搭建篇 ] 安装python环境并配置环境变量(附python3.10.3安装包)

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

力扣刷题记录——496. 下一个更大元素 I、500. 键盘行、506. 相对名次

本专栏主要记录力扣的刷题记录&#xff0c;备战蓝桥杯&#xff0c;供复盘和优化算法使用&#xff0c;也希望给大家带来帮助&#xff0c;博主是算法小白&#xff0c;希望各位大佬不要见笑&#xff0c;今天要分享的是——《496. 下一个更大元素 I、500. 键盘行、506. 相对名次》。…

Acwing4700. 何以包邮?(DP,01背包)

新学期伊始&#xff0c;适逢顿顿书城有购书满 x 元包邮的活动&#xff0c;小 P 同学欣然前往准备买些参考书。 一番浏览后&#xff0c;小 P 初步筛选出 n 本书加入购物车中&#xff0c;其中第 i 本&#xff08;1≤i≤n&#xff09;的价格为 ai 元。 考虑到预算有限&#xff0…

【大厂高频真题100题】《删除无效的括号》 真题练习第24题 持续更新~

删除无效的括号 给你一个由若干括号和字母组成的字符串 s ,删除最小数量的无效括号,使得输入的字符串有效。 返回所有可能的结果。答案可以按 任意顺序 返回。 示例 1: 输入:s = "()())()" 输出:["(())()","()()()"] 示例 2: 输入:…

1.初识React

React是用于构建用户界面的JavaScript库&#xff0c;可以应用于web&#xff0c;app(react-native),VR(react 360) 目录 1 安装React 2 简单使用 2.1 在页面上创建一个元素 2.2 React.createElement() 2.3 ReactDom.render() 3 React脚手架 3.1 初始化项目 3.2 …

国际人才考试中级的一点备考经验

在学英语的过程中&#xff0c;考证算是一件检验自己学习成果不错的方法&#xff0c;一开始是考虑了考雅思的&#xff0c;但综合自己幼儿园水平的听力&#xff0c;打算先放一放&#xff0c;考一考国才试试水。 国才考试近几年才有&#xff0c;知名度稍差&#xff0c;不过它不限制…

【Nginx】Nginx原理及优化参数配置

1. master和worker2. worker如何进行工作3. 一个master和多个woker有好处4. 设置多少个worker合适5. 连接数worker_connection 1. master和worker 2. worker如何进行工作 3. 一个master和多个woker有好处 首先&#xff0c;对于每个 worker 进程来说&#xff0c;独立的进程&am…

读书:《有无之境:王阳明哲学的精神》

《有无之境&#xff1a;王阳明哲学的精神》 王阳明晚年的时候&#xff0c;把他的哲学概括成了四句话&#xff0c;即四句教&#xff1a; 无善无恶心之体&#xff1b; 有善有恶意之动&#xff1b; 知善知恶是良知&#xff1b; 为善去恶是格物。 第一句&#xff1a;无善无恶心…

Trino源码分析:sql字段解析

业务中需要对Trino查询语句中涉及的字段进行处理&#xff0c;所以对这一段源码进行追踪分析&#xff0c;记录如下。 源码追踪是从QueuedStatementResource类开始的。 QueuedStatementResource类与ExecutingStatementResource类&#xff0c;提供用户执行查询相关的Restful接口。…