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)義特殊字符表
特殊字符 | 替代符號 |
& | & |
< | < |
> | > |
" | " |
' | ' |
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)文章
SpringBoot項目攔截器獲取Post方法的請求body實現(xiàn)
本文主要介紹了SpringBoot項目攔截器獲取Post方法的請求body,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01IDEA設置maven修改settings.xml配置文件無法加載倉庫的解決方案
這篇文章主要介紹了IDEA設置maven修改settings.xml配置文件無法加載倉庫的解決方案,幫助大家更好的利用IDEA進行JAVA的開發(fā)學習,感興趣的朋友可以了解下2021-01-01Hibernate Validation自定義注解校驗的實現(xiàn)
這篇文章主要介紹了Hibernate Validation自定義注解校驗的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-04-04java中mybatis和hibernate的用法總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于java中mybatis和hibernate的用法總結(jié)內(nèi)容,有興趣的朋友們可以學習參考下。2021-01-01