Mybatis-plus刪除操作詳解

一、mybatisplus刪除語句

Mybatis-plus的刪除操作通過使用DeleteWrapper對要刪除的數據進行封裝來實現。DeleteWrapper是Mybatis-plus提供的一個 Wrapper 類, 用於構建要刪除的數據的條件,刪除時只需把它傳遞給 delete 方法即可。
以下是示例代碼:

DeleteWrapper wrapper = new DeleteWrapper();
wrapper.eq("age", 20);
int rows = userMapper.delete(wrapper);

上面代碼中,首先構建了一個DeleteWrapper對象wrapper,它使用eq方法將age等於20作為要刪除的條件。接著將wrapper對象傳遞給userMapper的delete方法,並將受影響的行數賦值給rows變數。

二、mybatisplus刪除返回受影響的行數

在Mybatis-plus的刪除操作中,調用delete方法後會返回受影響的行數。下面是示例代碼:

DeleteWrapper wrapper = new DeleteWrapper();
wrapper.eq("age", 18);
int rows = userMapper.delete(wrapper);
System.out.println("受影響的行數:" + rows);

三、mybatisplus刪除方法

Mybatis-plus提供了多個刪除方法,包括deleteById、deleteByMap、delete等多個方法。具體使用哪個方法,根據實際情況來決定。

以下是deleteById示例代碼:

int rows = userMapper.deleteById(1L);
System.out.println("受影響的行數:" + rows);

以上代碼中,deleteById方法刪除id為1的記錄,並返回受影響的行數。

四、Mybatisplus刪除全表數據

刪除整張表的數據需要在Wrapper中使用無條件構建刪除條件。下面是示例代碼:

DeleteWrapper wrapper = new DeleteWrapper();
int rows = userMapper.delete(wrapper);
System.out.println("受影響的行數:" + rows);

以上代碼中,構建了一個無條件的DeleteWrapper對象wrapper,傳遞給userMapper的delete方法即可刪除整張表的數據,並返回受影響的行數。

五、mybatisplus刪除條件

Mybatis-plus的DeleteWrapper用於構建刪除條件,可以靈活設置條件。以下是示例代碼:

DeleteWrapper wrapper = new DeleteWrapper();
wrapper.eq("age", 20)
    .ne("email", "test@baomidou.com")
    .like("name", "Tom");
int rows = userMapper.delete(wrapper);

以上代碼中,構建了一個DeleteWrapper對象wrapper,通過eq、ne、like等方法設置刪除條件,刪除age等於20,但email不等於test@baomidou.com且name包含Tom的記錄。

六、mybatisplus刪除七天前數據

想要刪除七天以前的數據,需要使用Mybatis-plus提供的時間查詢方法,下面是示例代碼:

DeleteWrapper wrapper = new DeleteWrapper();
wrapper.le("create_time", LocalDateTime.now().minusDays(7));
int rows = userMapper.delete(wrapper);

以上代碼中,構建了一個DeleteWrapper對象wrapper,調用了le方法設置條件,刪除create_time小於等於當前時間減去7天的記錄。

七、mybatisplus刪除數據

Mybatis-plus的刪除操作支持批量刪除,可以用List、Map、Array等方式傳遞多個參數。

以下是示例代碼:

List ids = Arrays.asList(1, 2, 3);
int rows = userMapper.deleteBatchIds(ids);

以上代碼中,構建了一個List對象ids,其中包含了要刪除的記錄的id值。將ids傳遞給userMapper的deleteBatchIds方法,刪除對應的記錄,並返回受影響的行數。

八、mybatisplus刪除不生效

在Mybatis-plus的刪除操作中,如果刪除不生效,可能是由於我們所構建的Wrapper對象中的條件不正確導致的。可以通過列印sql語句,定位到具體的問題,並進行調整。
以下是示例代碼:

DeleteWrapper wrapper = new DeleteWrapper();
wrapper.eq("age", 18);
String sql = "delete from user where age = 19";
int rows = userMapper.delete(wrapper);
System.out.println("受影響的行數:" + rows);
System.out.println("執行的sql語句:" + sql);

在以上代碼中,我們構建了一個DeleteWrapper對象wrapper,並設置了刪除條件刪除age等於18的記錄。但在實際執行中,我們手動編寫了sql語句,刪除了age等於19的記錄。當我們執行程序後,會發現受影響的行數為0,這時候我們可以查看輸出的sql語句,找到問題。

九、mybatisplus刪除拼接的條件

在Mybatis-plus的刪除操作中,如果我們需要對刪除條件進行拼接,可以使用LambdaQueryWrapper的方法進行構建。

以下是示例代碼:

DeleteWrapper wrapper = new DeleteWrapper();
wrapper.and(i -> i.eq("age", 30).or().eq("age", 40));
int rows = userMapper.delete(wrapper);

以上代碼中構建了一個DeleteWrapper對象wrapper,通過and方法拼接了兩個查詢條件,刪除age等於30或等於40的記錄。

總結

通過本文章的介紹,我們可以看到Mybatis-plus提供了多種刪除操作的方法,並且可以通過Wrapper的方法進行靈活的條件設置。但我們在使用過程中需要注意刪除條件的設置和拼接,以免造成意料之外的結果。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/243916.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:59
下一篇 2024-12-12 12:59

相關推薦

  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • Python代碼實現迴文數最少操作次數

    本文將介紹如何使用Python解決一道經典的迴文數問題:給定一個數n,按照一定規則對它進行若干次操作,使得n成為迴文數,求最少的操作次數。 一、問題分析 首先,我們需要了解迴文數的…

    編程 2025-04-29
  • Python磁碟操作全方位解析

    本篇文章將從多個方面對Python磁碟操作進行詳細闡述,包括文件讀寫、文件夾創建、刪除、文件搜索與遍歷、文件重命名、移動、複製、文件許可權修改等常用操作。 一、文件讀寫操作 文件讀寫…

    編程 2025-04-29
  • 理解Mybatis中的SQL Limit用法

    Mybatis是一種非常流行的ORM框架,提供了SQL映射配置文件,可以使用類似於傳統SQL語言的方式編寫SQL語句。其中,SQL的Limit語法是一個非常重要的知識點,能夠實現分…

    編程 2025-04-29
  • Python元祖操作用法介紹

    本文將從多個方面對Python元祖的操作進行詳細闡述。包括:元祖定義及初始化、元祖遍歷、元祖切片、元祖合併及比較、元祖解包等內容。 一、元祖定義及初始化 元祖在Python中屬於序…

    編程 2025-04-29
  • 如何用Python對數據進行離散化操作

    數據離散化是指將連續的數據轉化為離散的數據,一般是用於數據挖掘和數據分析中,可以幫助我們更好的理解數據,從而更好地進行決策和分析。Python作為一種高效的編程語言,在數據處理和分…

    編程 2025-04-29
  • Python列表的讀寫操作

    本文將針對Python列表的讀取與寫入操作進行詳細的闡述,包括列表的基本操作、列表的增刪改查、列表切片、列表排序、列表反轉、列表拼接、列表複製等操作。 一、列表的基本操作 列表是P…

    編程 2025-04-29
  • Python序列的常用操作

    Python序列是程序中的重要工具,在數據分析、機器學習、圖像處理等很多領域都有廣泛的應用。Python序列分為三種:列表(list)、元組(tuple)和字元串(string)。…

    編程 2025-04-28

發表回復

登錄後才能評論