Mybatis:Mybatis中特殊Sql执行(6)

news2025/1/12 20:05:06

特殊Sql执行

  • 1. 模糊查询
  • 2. 批量删除
  • 3. 动态设置表名
  • 4. 添加功能获取自增的主键
  • 5. 整体代码

1. 模糊查询

  /**
     * 根据用户名进行模糊查询
     * @param moHu
     * @return
     */
    List<User> getUserByLike(@Param("moHu") String moHu);
   <!--List<User> getUserByLike(@Param("hoHu") String moHu);-->
    <select id="getUserByLike" resultType="User">
<!--        select * from t_user where username like '%${moHu}%'-->
<!--        select * from t_user where username like concat('%',#{moHu},'%')-->
        select * from t_user where username like "%"#{moHu}"%"
    </select>

注意:‘${name}’ = ‘name’, #{name} = name, 一个加引号,一个不加,要求sql功底一定要好,知道哪些添加引号,哪些不可以添加。

测试方法

 @Test
    public void testGetUserByLike(){
        SqlSession sqlSession = SqlSessionFactoryUtils.getSqlSession();
        SqlMapper sqlMapper = sqlSession.getMapper(SqlMapper.class);
        List<User> userList = sqlMapper.getUserByLike("sm");
        for(User user : userList){
            System.out.println(user);
        }
        sqlSession.close();
    }

在这里插入图片描述

2. 批量删除

只能使用${},如果使用#{},则解析后的sql语句为delete from t_user where id in ('1,2,3'),这样是将1,2,3看做是一个整体,只有id为1,2,3的数据会被删除。正确的语句应该是delete from t_user where id in (1,2,3),或者delete from t_user where id in ('1','2','3')

 /**
     * 根据id进行批量删除
     * @param ids
     * @return
     */
    int deleteMore(@Param("ids") String ids);
    <!--int deleteMore(@Param("ids") String ids);-->
    <delete id="deleteMore">
<!--        连续删除错误写法1:delete from t_user where id in (#{ids}), 原因在于#{ids}解析出来会自动添加引号'ids',导致出错-->
<!--        连续删除错误写法2:delete from t_user where id in ('${ids}'),不能添加引号,要不然sql语句报错-->
<!--        存在sql注入,会把数据库中的所有数据删除:delete from t_user where id in (${ids}) or '1' = '1'-->
        delete from t_user where id in (${ids})
    </delete>

测试方法

    @Test
    public void testDeleteMore() throws IOException {
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        SqlMapper sqlMapper = sqlSession.getMapper(SqlMapper.class);
        int count = sqlMapper.deleteMore("22, 23, 24");
        System.out.println("影响行数:" + count);
        sqlSession.close();
    }

在这里插入图片描述

3. 动态设置表名

只能使用${},因为表名不能加单引号

    /**
     * 查询指定表中的数据
     * @param tableName
     * @return
     */
    List<User> getUserByTable(@Param("tableName") String tableName);
    <!--List<User> getUserByTable(@Param("tableName") String tableName);-->
    <select id="getUserByTable" resultType="User">
        select * from ${tableName}
    </select>

测试方法

 @Test
    public void testGetUserByTable() throws IOException {
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        SqlMapper sqlMapper = sqlSession.getMapper(SqlMapper.class);
        // 查询t_user表的数据
        List<User> userList = sqlMapper.getUserByTable("t_user");
        for(User user : userList){
            System.out.println(user);
        }
        sqlSession.close();
    }

在这里插入图片描述

4. 添加功能获取自增的主键

功能:获取插入数据自增主键的id,便于后续程序的操作

  • 在mapper.xml中设置两个属性

  • useGeneratedKeys:设置使用自增的主键

  • keyProperty:因为增删改有统一的返回值是受影响的行数,因此只能将获取的自增的主键放在传输的参数user对象的某个属性中

    /**
     * 添加用户信息
     * @param user
     */
    void insert(User user);
    <!--
        void insertUser(User user) ;
        useGeneratedKeys :设置当前标签中的sql使用了自增的主键
        keyProperty:将自增的值主键的赋值给传输到映射文件中参数的某个属性
    -->
    <insert id="insert" useGeneratedKeys="true" keyProperty="id">
        insert into t_user values(null, #{username}, #{password}, #{age}, #{sex}, #{email})
    </insert>

测试方法

    @Test
    public void testInsert(){
        SqlSession sqlSession = SqlSessionFactoryUtils.getSqlSession();
        SqlMapper mapper = sqlSession.getMapper(SqlMapper.class);
        // 可以获取插入数据的id
        User user = new User(null, "Tom", "123", 23, "男", "1235@qq.com");
        mapper.insert(user);
        System.out.println(user);
        sqlSession.close();
    }

在这里插入图片描述

进入数据库中进行查看

在这里插入图片描述

5. 整体代码

SqlMapper接口

package com.atguigu.mapper;

import com.atguigu.pojo.User;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * @Author Mr.Lu
 * @Date 2022/12/2 15:20
 * @ClassName SqlMapper
 * @Version 1.0
 */
public interface SqlMapper {

    /**
     * 根据用户名进行模糊查询
     * @param moHu
     * @return
     */
    List<User> getUserByLike(@Param("moHu") String moHu);

    /**
     * 根据id进行批量删除
     * @param ids
     * @return
     */
    int deleteMore(@Param("ids") String ids);


    /**
     * 查询指定表中的数据
     * @param tableName
     * @return
     */
    List<User> getUserByTable(@Param("tableName") String tableName);

    /**
     * 添加用户信息
     * @param user
     */
    void insert(User user);
}

SqlMapper接口对应的SqlMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.atguigu.mapper.SqlMapper">
    <!--List<User> getUserByLike(@Param("hoHu") String moHu);-->
    <select id="getUserByLike" resultType="User">
        select * from t_user where username like '%${moHu}%'
<!--        select * from t_user where username like concat('%',#{moHu},'%')-->
<!--        select * from t_user where username like "%"#{moHu}"%"-->
    </select>

    <!--int deleteMore(@Param("ids") String ids);
				delete from t_user where id in (1, 2, 3): 如果数据表t_user存在主键id = 1或2或3,删除该条数据
		-->
    <delete id="deleteMore">
<!--        连续删除错误写法1:delete from t_user where id in (#{ids})-->
<!--        连续删除错误写法2:delete from t_user where id in ('${ids}')-->
<!--        存在sql注入,会把数据库中的所有数据删除:delete from t_user where id in (${ids}) or '1' = '1'-->
        delete from t_user where id in (${ids})
    </delete>

    <!--List<User> getUserByTable(@Param("tableName") String tableName);-->
    <select id="getUserByTable" resultType="User">
        select * from ${tableName}
    </select>

    <!--
        void insertUser(User user) ;
        功能:获取新增数据的主键,方便后续程序编写
        useGeneratedKeys :设置当前标签中的sql使用了自增的主键
        keyProperty:将自增的值主键的赋值给传输到映射文件中参数的某个属性
    -->
    <insert id="insert" useGeneratedKeys="true" keyProperty="id">
        insert into t_user values(null, #{username}, #{password}, #{age}, #{sex}, #{email})
    </insert>

</mapper>

MybatisSqlTest测试类

package com.atguigu.test;

import com.atguigu.mapper.SqlMapper;
import com.atguigu.pojo.User;
import com.atguigu.util.SqlSessionFactoryUtils;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

/**
 * @Author Mr.Lu
 * @Date 2022/12/2 15:21
 * @ClassName MybatisSqlTest
 * @Version 1.0
 */
public class MybatisSqlTest {
    @Test
    public void testGetUserByLike(){
        SqlSession sqlSession = SqlSessionFactoryUtils.getSqlSession();
        SqlMapper sqlMapper = sqlSession.getMapper(SqlMapper.class);
        List<User> userList = sqlMapper.getUserByLike("sm");
        for(User user : userList){
            System.out.println(user);
        }
        sqlSession.close();
    }


    @Test
    public void testDeleteMore() throws IOException {
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        SqlMapper sqlMapper = sqlSession.getMapper(SqlMapper.class);
        int count = sqlMapper.deleteMore("7,8,9");
        System.out.println("影响行数:" + count);
        sqlSession.close();
    }

    @Test
    public void testGetUserByTable() throws IOException {
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
        SqlSession sqlSession = sqlSessionFactory.openSession(true);
        SqlMapper sqlMapper = sqlSession.getMapper(SqlMapper.class);
        List<User> userList = sqlMapper.getUserByTable("t_user");
        for(User user : userList){
            System.out.println(user);
        }
        sqlSession.close();
    }

    @Test
    public void testInsert(){
        SqlSession sqlSession = SqlSessionFactoryUtils.getSqlSession();
        SqlMapper mapper = sqlSession.getMapper(SqlMapper.class);
        // 可以获取插入数据的id
        User user = new User(null, "ton", "123", 23, "男", "1235@qq.com");
        mapper.insert(user);
        System.out.println(user);
        sqlSession.close();
    }
}

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

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

相关文章

Java多线程之相关拓展(静态代理和Lamda表达式演变)

Java多线程拓展之静态代理和Lamda表达式演变一、静态代理1、概念2、优点3、样例二、Lamda表达式&#xff08;演变过程展示&#xff09;1、定义一个函数式接口并实现类&#xff08;最初状态&#xff09;2、静态内部类&#xff08;状态演变2&#xff09;3、局部内部类&#xff08…

英国G5生物医学类专业IB成绩要求多高?

生物医学类专业一向是申请热门。最近几年&#xff0c;由于新冠疫情的原因&#xff0c;相关专业申请竞争更加激烈了。英国G5生物医学类专业IB成绩要求多高&#xff1f;话说&#xff0c;IB申请英国的生物医学类专业&#xff0c;需要做好哪些准备&#xff1f;英国大学的生物医学类…

Spring Data JPA使用Pageable 参数Thymeleaf 视图进行分页

在上一个教程中&#xff0c;我们看到了如何在Spring MVC控制器方法中使用参数。以下示例显示了如何将 Spring 数据分页与 Thymeleaf 视图一起使用。我们还将使用注释来更改默认页面大小。PageablePageableDefault 例 实体 package com.example;import jakarta.persistence.E…

VS系列多通道振弦温度采发仪的选型与开机操作

VS A B C D E VS&#xff1a;无线型振弦传感器采发仪 A&#xff1a;内嵌核心测量模块数量&#xff08;1~4 个&#xff09; B&#xff1a;两位数字表示的振弦通道数量&#xff08;02、04、08、16&#xff09; C&#xff1a;T 表示带有温度测量通道 D&#xff1a;是否有…

【能效管理】电力监控系统在移动某分公司配电系统中的应用分析

安科瑞 李亚俊 壹捌柒贰壹零玖捌柒伍柒 概述 在社会科技发展越来越快捷和便利的现在&#xff0c;对用电设施的管理和实时监视越来越重要。在用电过程中经常发生漏电、过流等现象。甚至照成断电现象&#xff0c;而及时查询故障并解决问题恢复用电也越发重要。 中国移动通信集…

LeetCode 278. 第一个错误的版本

&#x1f308;&#x1f308;&#x1f604;&#x1f604; 欢迎来到茶色岛独家岛屿&#xff0c;本期将为大家揭晓本LeetCode 278. 第一个错误的版本&#xff0c;做好准备了么&#xff0c;那么开始吧。 &#x1f332;&#x1f332;&#x1f434;&#x1f434; 一、题目名称 LeetC…

Python基础(十):列表的详细讲解

文章目录 列表的详细讲解 一、列表的应用场景 二、列表的格式 三、列表的常用操作 1、查找 2、增加 3、删除 4、修改 5、复制 四、列表的循环遍历 1、while 2、for 五、列表嵌套 六、总结 列表的详细讲解 一、列表的应用场景 思考&#xff1a;有⼀个⼈的姓名(TO…

菜狗杯Misc迅疾响应wp

一、原题 之前没接触过这种题型&#xff0c;所以记录一下 打开题目附件压缩包是一个图片&#xff0c;一看就不是常见的那种二维码&#xff08;甚至看起来有点不适……呜呜&#xff09;果然微信扫一扫也扫不出来。 二、工具和解题步骤 后来去看了官方wp&#xff0c;知道了一…

【Matplotlib绘制图像大全】(十七):散点图

前言 大家好,我是阿光。 本专栏整理了《Matplotlib绘制图像大全》,内包含了各种常见的绘图方法,以及Matplotlib各种内置函数的使用方法,帮助我们快速便捷的绘制出数据图像。 正在更新中~ ✨ 🚨 我的项目环境: 平台:Windows10语言环境:python3.7编译器:PyCharmMatp…

防火墙dmz实验

♥️作者&#xff1a;小刘在C站 ♥️每天分享云计算网络运维课堂笔记&#xff0c;一起努力&#xff0c;共赴美好人生&#xff01; ♥️夕阳下&#xff0c;是最美的&#xff0c;绽放。 ciscoasa> en Password: ciscoasa# conf t ciscoasa(config)# int e0/0 ciscoasa(co…

线程的概念+线程函数API

C线程 有关线程的简单实现 #include<stdio.h> #include<stdlib.h> #include<unistd.h> //定义线程函数&#xff08;固定&#xff09;--void * void *pth_fun(void *pth_arg){while(1){printf("pthread\n");sleep(1);}return NULL; } int main(){…

k8s学习笔记-完整版

文章目录第一章 kubernetes介绍应用部署方式演变kubernetes简介kubernetes组件kubernetes概念第二章 集群环境搭建环境规划集群类型安装方式主机规划环境搭建主机安装环境初始化安装docker安装kubernetes组件准备集群镜像集群初始化安装网络插件服务部署第三章 资源管理资源管理…

docker入门级使用

文章目录dockerdocker概述出现原因官网虚拟化与容器化docker架构图docker安装阿里云镜像加速底层原理Docker常用命令帮助命令镜像命令容器命令常用其他命令安装nginx安装Tomcatdocker 越学习越觉得自己的无知 谦卑,不傲慢,厚积而薄发 docker概述 出现原因 一次编译,到处报错开…

跨境电商如何减少客户流失率:成功的5种保留策略

关键词&#xff1a;跨境电商、客户流失率 经营一家跨境电商企业常常感觉就像一个漏水的容器。无论您在顶部倾注了多少客户&#xff0c;这始终是一个不断耗尽底部的百分比。 这被称为客户流失——它使可持续增长成为品牌面临的主要挑战。 客户流失与客户满意度密切相关。如果您的…

常见七大SMD器件布局基本要求,你掌握了几点?

SMD器件布局的一般要求 细间距器件推荐布置在PCB同一面&#xff0c;也就是引脚间距不大于0.65mm的表面组装器件&#xff1a;也指长X宽不大于1.6mmX0.8mm(尺寸编码为1608)的表面组装元件。 SMD器件的回流焊接器件布局要求 同种贴片器件间距要求≥12mil&#xff08;焊盘间&…

HTML+CSS大作业:旅游网页设计与实现——旅游风景网站6页HTML+CSS+JavaScript实训大作业 HTML+CSS大作业 HTML期末大作业

&#x1f468;‍&#x1f393;静态网站的编写主要是用 HTML DⅣV CSSJS等来完成页面的排版设计&#x1f469;‍&#x1f393;&#xff0c;一般的网页作业需要融入以下知识点&#xff1a;div布局、浮动定位、高级css、表格、表单及验证、js轮播图、音频视频Fash的应用、uli、下拉…

[LINUX]linux基本指令大总结

&#x1f941;作者&#xff1a; 华丞臧. &#x1f4d5;​​​​专栏&#xff1a;【LINUX】 各位读者老爷如果觉得博主写的不错&#xff0c;请诸位多多支持(点赞收藏关注)。如果有错误的地方&#xff0c;欢迎在评论区指出。 推荐一款刷题网站 &#x1f449; LeetCode刷题网站 文…

塔望3W消费战略全案丨绿力冬瓜茶 三十年饮料老品牌,两年复兴战全国

绿力 冬瓜茶 客户&#xff1a;台湾味丹食品 上海皇品食品有限公司 品牌&#xff1a;绿力 服务&#xff1a;3W消费战略 绿力冬瓜茶品牌全案 &#xff08;2019、2020、2021、2022年度全案&#xff09; 项目背景 1992年台湾味丹食品建立上海味丹食品有限公司&#xff0c;后更…

Cadence Allegro PCB设计88问解析(二十) 之 Allegro中格点设置(一)

一个学习信号完整性仿真的layout工程师 布局是PCB设计中比较重要的一步&#xff0c;一个好的布局&#xff0c;不仅看起来美观而且也方便后期的走线&#xff0c;避免了一些信号完整性问题。在布局时就会涉及到格点设置&#xff0c;一个好的格点设置有利于器件的摆放和走线方便。…

Android—百度地图的简单使用

目录百度地图创建应用获取开发版SHA1获取发布版SHA1设置包名获得一个应用创建模块下载SKDHelloBaiDuMap1.配置AndroidManifest.xml文件2.在布局文件中添加地图容器3.地图初始化4.创建地图Activity&#xff0c;管理MapView生命周期切换地图类型百度地图 百度地图 Android SDK是…