Spring Mybatis Mapper模糊查詢的幾種方法
在Spring結(jié)合Mybatis進(jìn)行開發(fā)時,實(shí)現(xiàn)模糊查詢是一個常見需求。在Mybatis中,LIKE
查詢可以通過多種方式實(shí)現(xiàn),這取決于你的查詢參數(shù)如何傳遞給Mybatis的SQL映射器。以下是實(shí)現(xiàn)模糊查詢的幾種常見方法:
1. 在Mapper接口中直接使用#{}進(jìn)行拼接
這種方法直接在Mapper的XML文件中使用LIKE關(guān)鍵字,然后通過#{}
傳遞參數(shù),你可以在傳遞參數(shù)之前,在Java代碼中拼接好模糊查詢所需的百分比符號(%
)。
Mapper接口XML示例:
<select id="findByName" resultType="com.example.YourModel"> SELECT * FROM your_table WHERE name LIKE #{name} </select>
Java代碼中調(diào)用:
// 假設(shè)有一個Mapper接口方法叫findByName List<YourModel> results = yourMapper.findByName("%" + name + "%");
2. 在XML中使用CONCAT函數(shù)
如果你不想在Java代碼中拼接字符串,你可以在XML映射文件中使用SQL的CONCAT
函數(shù)來拼接百分比符號和參數(shù)。
Mapper接口XML示例:
<select id="findByName" resultType="com.example.YourModel"> SELECT * FROM your_table WHERE name LIKE CONCAT('%', #{name}, '%') </select>
3. 使用<bind>標(biāo)簽
Mybatis提供了<bind>
標(biāo)簽,允許你在XML文件中創(chuàng)建一個變量,用于拼接字符串或執(zhí)行其他邏輯操作。這樣可以在不修改Java代碼的情況下實(shí)現(xiàn)字符串的拼接。
Mapper接口XML示例:
<select id="findByName" resultType="com.example.YourModel"> <bind name="pattern" value="'%' + name + '%'" /> SELECT * FROM your_table WHERE name LIKE #{pattern} </select>
4. 使用${}進(jìn)行拼接(不推薦)
雖然可以使用${}
進(jìn)行字符串拼接以實(shí)現(xiàn)LIKE查詢,但這種方法容易導(dǎo)致SQL注入攻擊,因此不推薦使用。
Mapper接口XML示例(不推薦):
<select id="findByName" resultType="com.example.YourModel"> SELECT * FROM your_table WHERE name LIKE '%${name}%' </select>
5. 使用MyBatis的動態(tài)SQL choose、when、otherwise
雖然不是專門用于LIKE
查詢,但choose
、when
、otherwise
標(biāo)簽可以用于構(gòu)建復(fù)雜的查詢邏輯,包括根據(jù)條件選擇是否執(zhí)行模糊查詢。
Mapper接口XML示例:
<select id="findByNameOrEmail" resultType="com.example.YourModel"> SELECT * FROM your_table <where> <choose> <when test="name != null"> name LIKE CONCAT('%', #{name}, '%') </when> <when test="email != null"> email LIKE CONCAT('%', #{email}, '%') </when> <otherwise> 1=1 </otherwise> </choose> </where> </select>
另外還有在調(diào)用層代碼一些處理方式
6. 在Java代碼中拼接模糊查詢的條件
你也可以在調(diào)用Mapper接口的方法之前,就已經(jīng)將參數(shù)值處理成模糊查詢所需的格式。
public interface YourMapper { List<YourModel> findByName(@Param("name") String name); } // 調(diào)用Mapper的地方 String searchName = "%" + name + "%"; List<YourModel> result = yourMapper.findByName(searchName);
7. 使用@Select注解進(jìn)行模糊查詢
在使用Mybatis Spring時,可以直接在Mapper接口的方法上使用@Select注解來定義SQL語句,從而實(shí)現(xiàn)模糊查詢。
public interface YourMapper { @Select("SELECT * FROM your_table WHERE name LIKE CONCAT('%', #{name}, '%')") List<YourModel> findByName(@Param("name") String name); }
以上是實(shí)現(xiàn)Mybatis中LIKE模糊查詢的一些常見方法。選擇合適的方法取決于具體的應(yīng)用場景和個人偏好。在實(shí)際使用中,要注意防止SQL注入的風(fēng)險,尤其是在直接拼接字符串構(gòu)造查詢條件時。
到此這篇關(guān)于Spring Mybatis Mapper模糊查詢的幾種方法的文章就介紹到這了,更多相關(guān)Spring Mybatis Mapper模糊查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaMail實(shí)現(xiàn)發(fā)送超文本(html)格式郵件的方法
這篇文章主要介紹了JavaMail實(shí)現(xiàn)發(fā)送超文本(html)格式郵件的方法,實(shí)例分析了java發(fā)送超文本文件的相關(guān)技巧,需要的朋友可以參考下2015-05-05SpringBoot自定義對象參數(shù)實(shí)現(xiàn)自動類型轉(zhuǎn)換與格式化
SpringBoot 通過自定義對象參數(shù),可以實(shí)現(xiàn)自動類型轉(zhuǎn)換與格式化,并可以級聯(lián)封裝,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-09-09Mybatis之collection標(biāo)簽中javaType和ofType屬性的區(qū)別說明
這篇文章主要介紹了Mybatis之collection標(biāo)簽中javaType和ofType屬性的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12java文件/圖片的上傳與下載以及MultipartFile詳解
文章介紹了MultipartFile類的使用,包括獲取文件名、文件類型、文件大小等方法,以及如何處理多文件上傳和文件大小限制,同時提供了文件上傳和下載的示例代碼2025-02-02Java編程實(shí)現(xiàn)軌跡壓縮算法開放窗口實(shí)例代碼
這篇文章主要介紹了Java編程實(shí)現(xiàn)軌跡壓縮算法開放窗口實(shí)例代碼,具有一定借鑒價值,需要的朋友可以參考下。2017-11-11Java開發(fā)中synchronized的定義及用法詳解
這篇文章主要介紹了Java開發(fā)中synchronized的定義及用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07java實(shí)現(xiàn)優(yōu)酷視頻地址解析示例代碼分享
最近做了一個在線視頻的下載器,需要解析youku的視頻,獲得真正的視頻地址,現(xiàn)在把解析過程記錄下來以供參考2014-01-01java8新特性 stream流的方式遍歷集合和數(shù)組操作
這篇文章主要介紹了java8新特性 stream流的方式遍歷集合和數(shù)組操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08