在 MyBatis 中,可以使用相同的 SQL 映射语句进行批量删除和单个删除。

这篇具有很好参考价值的文章主要介绍了在 MyBatis 中,可以使用相同的 SQL 映射语句进行批量删除和单个删除。。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前端代码: 

后端代码:

controller

 service层接口

service接口的实现

mapper层接口

xml

sql

效果:(点击操作列的删除,可删除一行数据。勾选多个多选框再点击批量删除,可删除多个) 

在 MyBatis 中,可以使用相同的 SQL 映射语句进行批量删除和单个删除。,Vue,mySQL,SpringBoot,mybatis,sql,数据库 

前端代码: 

<el-input placeholder="请输入姓名" v-model="keyWord" style="width: 400px">
  <el-button slot="append" icon="el-icon-search" @click="selectAllUser()"></el-button>
</el-input>
<el-button type="primary" @click="batchDeleteUser()">批量删除</el-button>
<el-table :data="tableData" border style="width: 100%" @selection-change="handleSelectionChange">
  <el-table-column type="selection" width="55"></el-table-column>
  <el-table-column prop="name" label="姓名" width="180"></el-table-column>
  <el-table-column prop="phone" label="电话" width="180"></el-table-column>
  <el-table-column prop="grades" label="班级" width="180"></el-table-column>
  <el-table-column prop="operate" label="操作" align="center" fixed="right">
    <template slot-scope="scope">
      <!-- (scope.row.userId)用于获取当前行数据对象中的用户ID(或其他字段) -->
      <el-button size="mini" type="text" @click="openDialog(scope.row)">编辑</el-button>
      <el-button size="mini" type="text" @click="deleteOneUser(scope.row)">删除</el-button>
    </template>
  </el-table-column>
</el-table>
export default {
  data() {
    return {
      tableData: [],
      selectedIds: [], // 存储选中行的ID的数组
      
    }
  },
  methods: {
     //判断用户选择了什么
    handleSelectionChange(selection) {
      this.selectedIds = selection.map(item => item.id);
    },
    //删除用户(删除多个)
    batchDeleteUser() {
      this.deleteUser(this.selectedIds)
    },
    //删除用户(删除单个)
    deleteOneUser(row) {
      let selectIdArray = [];
      selectIdArray.push(row.id);
      this.deleteUser(selectIdArray)
    },
    //删除用户逻辑
    deleteUser(selectIdArray) {
      this.$confirm('确认删除?')
        .then(() => {
          //点击确定后的逻辑
          this.$axios({
            method: "post",
            url: "http://localhost:8080/api/user/deleteUser",
            data: selectIdArray
          }).then((res) => {
            if (res.data.code === '200') {
              this.$message({
                message: res.data.message,
                type: "success"
              });
              this.selectAllUser();
            } else {
              this.$message({
                message: res.data.message,
                type: "failed"
              });
            }
          })
        })
        .catch(() => {});
    }
  }
}

后端代码:

  • controller

@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    UserService userService;

    //删除用户
    @PostMapping("/deleteUser")
    public Result deleteUser(@RequestBody String[] userArray){
        return  userService.deleteUser(Arrays.asList(userArray));
    }
  
}
  •  service层接口
public interface UserService {

    Result deleteUser(List<String> UserList);
}
  • service接口的实现
public Result deleteUser(List<String> userList) {
    // 判断userList是否为空
    if (CollectionUtils.isEmpty(userList)) {
        // 如果是空,则返回删除成功信息和删除数量为0
        return Result.succeed("删除成功", 0);
    }

    // 调用userMapper.deleteUser方法来删除指定的用户
    int count = userMapper.deleteUser(userList);

    // 判断删除是否成功
    if (count == userList.size()) {
        // 如果全部删除成功,则返回删除成功信息和删除的用户数量
        return Result.succeed("删除成功", count);
    } else {
        // 如果只有部分删除成功,则返回部分删除成功信息和删除的用户数量
        return Result.succeed("删除部分成功", count);
    }
}
  • mapper层接口
public interface UserMapper {

    int deleteUser(List<String> userList);

}
  • xml
    <update id="deleteUser">
        update user
        set
        status='0'
        where id in
        <foreach collection="list" item="item" open="(" close=")" separator=",">
            #{item}
        </foreach>
    </update>

数据库

在 MyBatis 中,可以使用相同的 SQL 映射语句进行批量删除和单个删除。,Vue,mySQL,SpringBoot,mybatis,sql,数据库 文章来源地址https://www.toymoban.com/news/detail-827581.html

  • sql
/*
 Navicat Premium Data Transfer

 Source Server         : database
 Source Server Type    : MySQL
 Source Server Version : 80029
 Source Host           : localhost:3306
 Source Schema         : score_management_db

 Target Server Type    : MySQL
 Target Server Version : 80029
 File Encoding         : 65001

 Date: 18/02/2024 13:52:16
*/

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user`  (
  `userId` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '账号',
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '姓名',
  `password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '密码',
  `phone` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '手机号',
  `grades` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '班级',
  `sex` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '性别',
  `age` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '年龄',
  `address` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '地址',
  `status` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT '1' COMMENT '状态',
  `id` int NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 11 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES ('zhangsan', '张三', '1234', '1778299200', '软件一班', '男', '341', '广西1', '1', 1);
INSERT INTO `user` VALUES ('zhangsi', '张四', '1234', '1778299200', '软件一班', '男399999', '3嗯嗯嗯', '广v', '1', 2);
INSERT INTO `user` VALUES ('liuliu', '刘六', '1234', '1778299200', '软件二班', '男', '34', '广西', '1', 3);
INSERT INTO `user` VALUES ('1', '陈万祥222', '1', '55566777888', '软件二班', NULL, NULL, NULL, '0', 10);
INSERT INTO `user` VALUES ('laoxiaming', '劳霞明', 'laoxiaming', '4646436', '软件二班', NULL, NULL, NULL, '1', 11);

SET FOREIGN_KEY_CHECKS = 1;

到了这里,关于在 MyBatis 中,可以使用相同的 SQL 映射语句进行批量删除和单个删除。的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL:想实现sql语句进行批量删除数据库或表,而引发的熬夜探究

    因为在自测过程中,创建了很多数据库,一个个手动删除属实有点对不起程序员这个身份,那么有没有简单的sql语句操作来进行批量删除数据库呢?于是便有了本篇文章 上面图片是AI创作,未经允许,不可商用哦! 删库跑路需谨慎, 放弃一切亦不易。 了解到数据库或表的信

    2024年01月16日
    浏览(58)
  • Mybatis学习笔记,包含mybatis基本使用、关系映射、动态SQL、分页插件等等

    😀😀😀创作不易,各位看官点赞收藏. 简介:MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain

    2024年02月15日
    浏览(46)
  • MyBatis案例 | 使用映射配置文件实现CRUD操作——动态SQL优化条件查询

    本专栏主要是记录学习完JavaSE后学习JavaWeb部分的一些知识点总结以及遇到的一些问题等,如果刚开始学习Java的小伙伴可以点击下方连接查看专栏 本专栏地址:🔥JavaWeb Java入门篇: 🔥Java基础学习篇 Java进阶学习篇(持续更新中):🔑Java进阶学习篇 本系列文章会将讲述有关

    2024年02月02日
    浏览(83)
  • 在mybatis-plus项目中自带要编写sql语句,@select注解的使用

    提示:在mybatisplus中编写sql语句有两种方法,我重点使用@select注释这种方法,还有一种是增加mapper.xml文件配置,这里不做讲解 现在mybatis-plus中已经封装了绝大部分简单sql,只用一部分负责sql需要自行编写,所以用@select的方式可以减少开发量,减少项目的复杂性。 @select是myb

    2023年04月12日
    浏览(47)
  • Mybatis映射.动态sql.分页

    动态SQL是MyBatis提供的一种动态生成SQL语句的方式,可以根据不同的条件生成不同的SQL语句,从而实现更加灵活的查询和操作。 在MyBatis的映射文件中,可以通过使用if、choose、when、otherwise、foreach等标签来实现动态SQL。下面以if和foreach为例,介绍如何在MyBatis映射文件中使用动

    2024年02月11日
    浏览(42)
  • 在IDEA中配置MySQL数据库连接以及在使用mybatis时设置sql语句的代码提示功能

    在IDEA中配置MySQL数据库连接以及在使用mybatis 时设置 sql语句的代码提示功能 一:在IDEA中配置MySQL数据库连接 第一步:在IDEA右侧区域有database选项,点击进去 第二步:database  - data soucre - mysql   第三步:配置连接信息,连接数据库   第四步:显示的数据库以及表的信息  第

    2024年02月14日
    浏览(46)
  • MyBatis动态SQL、模糊查询与结果映射

    目录 前言 一、MyBatis动态SQL 1.动态SQL是什么 2.动态SQL的作用 3.常用动态SQL元素 1. where + if 元素 2. set + if 元素 3. choose + when + otherwise 元素 4. 自定义 trim 元素  1. 自定义 trim 元素改写上面的 where + if 语句 2. 自定义 trim 元素改写上面的 set + if 语句 5. foreach 元素 6.SQL片段重用 二、

    2024年02月11日
    浏览(37)
  • Excel拼接sql语句,批量导入数据

    如下示例图: 参考链接:excel拼接sql

    2024年02月12日
    浏览(39)
  • mybatis配置批量执行SQL

    foreach 标签插入数据量大时,明显影响效率,个人倾向以下配置  applicationcontext 配置文件 Java代码 mybatis文件没什么可说的,就是普通单条插入的insert 标签即可

    2024年02月12日
    浏览(40)
  • 设置代码模板创建sql映射文件、Mybatis主配置文件

    目录 1、Sql映射(Sql  Mapper)文件的介绍 2、Mybatis的主配置文件的介绍 3、通过代码模板创建Sql映射文件 4、通过代码模板创建Mybatis主配置文件 创建主配置文件:名称为 mybatis.xml 支持中文的 url 同理:

    2024年01月23日
    浏览(60)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包