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