欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis解決模糊查詢包含特殊字符問題

 更新時間:2023年02月07日 16:33:41   作者:在奮斗的大道  
這篇文章主要介紹了MyBatis解決模糊查詢包含特殊字符問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

MyBatis解決模糊查詢包含特殊字符

第一塊:MyBatis 實現(xiàn)模糊查詢方式

1.1  sql中字符串拼接

SELECT * FROM 表名 WHERE 字段名 LIKE CONCAT(CONCAT('%', #{參數(shù)}), '%');

1 2. 使用 ${...} 代替 #{...}

SELECT * FROM 表名 WHERE 字段名 LIKE '%${參數(shù)}%';?

注意:($不能防止sql注入, #{}---> 可以防止sql注入的問題)

1.3 程序中拼接

Java 代碼

String searchText = new StringBuilder("%").append(text).append("%").toString();?
parameterMap.put("text", searchText);

Mapper 映射文件

SELECT * FROM 表名 WHERE 字段名 LIKE #{參數(shù)};

第二塊:MyBatis 實現(xiàn)特殊字符處理之<![CDATA[ ]]>

2.1 <![CDATA[ ]]> 簡介

它的全稱為character data,以"<![CDATA[ "開始,以" ]]>" 結(jié)束,在兩者之間嵌入不想被解析程序解析的原始數(shù)據(jù),解析器不對CDATA區(qū)中的內(nèi)容進行解析,而是將這些數(shù)據(jù)原封不動地交給下游程序處理。

2.2 MyBatis 自動轉(zhuǎn)義特殊字符表

特殊字符替代符號
&&amp;
<&lt;
>&gt;
"&quot;
'&apos;

2.3 <![CDATA[ ]]> 特殊字符

xml 中表示:   <= 小于等于、    >= 大于等于 需加  這樣的標記:     <![CDATA[   ]]>      xml中有&的符號,需要

  • <![CDATA[&]]>這樣表示&
  • <= 小于等于 :<![CDATA[ <= ]]>
  • >= 大于等于:<![CDATA[  >=  ]]>

第三塊:模糊查詢包含特殊字符

解決辦法:使用 ${...} + <![CDATA[ ]]>

模板:

? <select id="searchAll" parameterType="map" resultType="map">
?? ?SELECT?
?? ??? ?*
? ? FROM ?表名 P
? ?? ?WHERE 1=1?
?? ?<if test="參數(shù) != null and 參數(shù) != ''">
?? ??? ?<![CDATA[ AND P.字段名 LIKE '%${參數(shù)}%']]>
?? ?</if>

MyBatis模糊查詢時對特殊字符"%"和"_"的處理

問題

輸入"%“或”_",查詢結(jié)果為全部數(shù)據(jù),且無法查詢到帶有"%"或者下劃線 的數(shù)據(jù)。

解決

對特殊字符轉(zhuǎn)義

例如查詢字段為 name

若name中含有"%“或 “_” 轉(zhuǎn)為”/%" “/ _”

public void setName(String name) {
? ? ? ? this.name = StringUtils.isBlank(name) ? null : EscapeUtil.escapeChar(name);
? ? }
package com.xpf.util;

import org.apache.commons.lang3.StringUtils;

/**
?* @Title:EscapeUtil
?* @Package:com.xpf.util
?* @Author: xiapf
?* @Date:2019/9/20
?* @Descrption:
?*/
public class EscapeUtil {
? ? /**
? ? ?* mysql的模糊查詢時特殊字符轉(zhuǎn)義
? ? ?*/
? ? public static String escapeChar(String before){
? ? ? ? if(StringUtils.isNotBlank(before)){
? ? ? ? ? ? before = before.replaceAll("_", "/_");
? ? ? ? ? ? before = before.replaceAll("%", "/%");
? ? ? ? }
? ? ? ? return before.trim() ;
? ? }
}

mapper中模糊查詢語句

name like CONCAT('%',#{name},'%') ESCAPE '/'

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring boot通過AOP防止API重復請求代碼實例

    Spring boot通過AOP防止API重復請求代碼實例

    這篇文章主要介紹了Spring boot通過AOP防止API重復請求代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12
  • SpringBoot項目攔截器獲取Post方法的請求body實現(xiàn)

    SpringBoot項目攔截器獲取Post方法的請求body實現(xiàn)

    本文主要介紹了SpringBoot項目攔截器獲取Post方法的請求body,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • IDEA設置maven修改settings.xml配置文件無法加載倉庫的解決方案

    IDEA設置maven修改settings.xml配置文件無法加載倉庫的解決方案

    這篇文章主要介紹了IDEA設置maven修改settings.xml配置文件無法加載倉庫的解決方案,幫助大家更好的利用IDEA進行JAVA的開發(fā)學習,感興趣的朋友可以了解下
    2021-01-01
  • Hibernate Validation自定義注解校驗的實現(xiàn)

    Hibernate Validation自定義注解校驗的實現(xiàn)

    這篇文章主要介紹了Hibernate Validation自定義注解校驗的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Java實現(xiàn)字符數(shù)組全排列的方法

    Java實現(xiàn)字符數(shù)組全排列的方法

    這篇文章主要介紹了Java實現(xiàn)字符數(shù)組全排列的方法,涉及Java針對字符數(shù)組的遍歷及排序算法的實現(xiàn)技巧,需要的朋友可以參考下
    2015-12-12
  • java中mybatis和hibernate的用法總結(jié)

    java中mybatis和hibernate的用法總結(jié)

    在本篇文章里小編給大家整理的是一篇關(guān)于java中mybatis和hibernate的用法總結(jié)內(nèi)容,有興趣的朋友們可以學習參考下。
    2021-01-01
  • java實現(xiàn)俄羅斯方塊

    java實現(xiàn)俄羅斯方塊

    這篇文章主要為大家詳細介紹了java實現(xiàn)俄羅斯方塊,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • 詳解Spring框架注解掃描開啟之配置細節(jié)

    詳解Spring框架注解掃描開啟之配置細節(jié)

    本篇文章主要介紹了詳解Spring框架注解掃描開啟之配置細節(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Java如何在 Word 中設置上、下標

    Java如何在 Word 中設置上、下標

    這篇文章主要介紹了Java如何在 Word 中設置上、下標,幫助大家更好的利用Java處理文檔,感興趣的朋友可以了解下
    2020-09-09
  • java獲取properties屬性文件示例

    java獲取properties屬性文件示例

    Properties類表示了一個持久的屬性集。Properties可保存在流中或從流中加載。屬性列表中每個鍵及其對應值都是一個字符串。本文使用java讀取這些屬性,看下面詳細介紹吧
    2014-01-01

最新評論