Solve the splicing problem of deleting conditions in myBatis

Solve the splicing problem of deleting conditions in myBatis

I just learned mybatis today and did some simple additions, deletions, modifications and queries on the database. When performing a deletion operation, it is very simple to delete a single record, but it is a bit troublesome to splice the deletion conditions when deleting in batches. The following is a record of the method.

In SQL statements, when the deletion condition is not unique, we have two types of deletion SQL statements. One is to use or to concatenate the conditions in where, such as delete from table name where condition 1 or condition 2, and the other is to use in, such as delete from table name where element in ()

Use the first deletion statement to splice in mapping.xml in mybatis:

Use the second deletion statement to splice in mapping.xml in mybatis:

The above deletion operation is basically completed. However, there is a defect. When there is no element in the query condition idList, the records in the entire table ac01 will be deleted. Therefore, we need to improve the above method.

The second delete statement is improved:

After the first delete statement is improved:

At this point, the deletion operation is completed perfectly.

Additional knowledge: Pay attention to the and splicing conditions when querying myBatis

<!-- Add a condition-->

<sql id="queryjiachaAllPageId">
 <where>
  <if test="danweimc !=null and danweimc !=''">
  and jcb.danweimc like '%${danweimc}%'
  </if>
  <if test="ge_jianchaks !=null and ge_jianchaks !=''">
  and DATE_FORMAT(jcb.jianchaks, '%Y-%m-%d') >= #{ge_jianchaks}
  </if>
  <if test="le_jianchaks != null and le_jianchaks != ''">
  and DATE_FORMAT(jcb.jianchaks, '%Y-%m-%d') &lt;= #{le_jianchaks}
  </if>
  
  <if test="jiancharxm !=null and jiancharxm !=''">
  and jcb.jiancharxm like '%${jiancharxm}%'
  </if>
  <if test="zhuangtai !=null and zhuangtai !=''">
  and yhb.zhuangtai = ${zhuangtai}
  </if>
  <if test="danweilb !=null and danweilb !=''">
  and yhb.yinhuanmc like '${danweilb}%'
  </if>
  <if test="jiedao != null and jiedao !='' and jiedao !='110105000000'">
  and jcb.jiedao=#{jiedao}
  </if>
  <if test="danweimcs != null and danweimcs !=''">
  and jcb.danweimc = #{danweimcs}
  </if>
 </where>
 </sql>

For example, the appeal questions either have "and" or "no" added. Please note that if there is an "and" or "no" query, an error will be reported.

The above article on solving the splicing problem of deleting conditions in myBatis is all the content that the editor shares with you. I hope it can give you a reference, and I also hope that you will support 123WORDPRESS.COM.

You may also be interested in:
  • Mybatis-plus uses Condition to concatenate SQL statements
  • MyBatis dynamically concatenates SQL strings
  • MybatisPlus implements reverse concatenation of strings

<<:  Vue implements websocket customer service chat function

>>:  HTML form_PowerNode Java Academy

Recommend

How to quickly build an FTP file service using FileZilla

In order to facilitate the storage and access of ...

Detailed explanation of Nginx rewrite jump application scenarios

Application scenario 1: Domain name-based redirec...

Example code of vue + element ui to realize player function

The display without the effect picture is just em...

Detailed explanation of Javascript string methods

Table of contents String length: length charAt() ...

JavaScript countdown to close ads

Using Javascript to implement countdown to close ...

Detailed explanation of MySQL user and permission management

This article uses examples to describe the manage...

In-depth explanation of binlog in MySQL 8.0

1 Introduction Binary log records SQL statements ...

MySQL joint index effective conditions and index invalid conditions

Table of contents 1. Conditions for joint index f...

Detailed tutorial on installing Docker and nvidia-docker on Ubuntu 16.04

Table of contents Docker Installation Nvidia-dock...

MySQL dual-master (master-master) architecture configuration solution

In enterprises, database high availability has al...

Detailed explanation of common commands in MySQL 8.0+

Enable remote access Enable remote access rights ...

How to convert rows to columns in MySQL

MySQL row to column operation The so-called row-t...

Detailed explanation of the use of Vue.js draggable text box component

Table of contents Registering Components Adding C...

JavaScript canvas to achieve raindrop effect

This article example shares the specific code for...