MybatisPlus調(diào)用原生SQL的實(shí)現(xiàn)方法
前言
在有些情況下需要用到MybatisPlus查詢原生SQL,MybatisPlus其實(shí)帶有運(yùn)行原生SQL的方法。
方法一
這也是網(wǎng)上流傳最廣的方法,但是我個人認(rèn)為這個方法并不優(yōu)雅,且采用${}的方式代碼審計可能會無法通過,會被作為代碼漏洞
public interface BaseMapper<T> extends com.baomidou.mybatisplus.core.mapper.BaseMapper<T> {
@Select("${nativeSql}")
Object nativeSql(@Param("nativeSql") String nativeSql);
}使用一個自己的BaseMapper去繼承MybatisPlus自己的BaseMapper,然后所有的Mapper去繼承自己寫的BaseMapper即可。那么所有的Mapper都能查詢原生SQL了。
問題在于${nativeSql}可能會被作為代碼漏洞,不是很提倡這種寫法。
方法二
使用SqlRunner的方式執(zhí)行原生SQL。這個方法提倡。
要使用SqlRunner的前提是打開SqlRunner,編輯application.yaml增加配置如下:
mybatis-plus:
global-config:
enable-sql-runner: trueapplication.properties寫法:
mybatis-plus.global-config.enable-sql-runner=true
如果不打開會報
Cause: java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for xxxxxxx
使用方法:
import com.baomidou.mybatisplus.extension.toolkit.SqlRunner;
List<Map<String, Object>> mapList = SqlRunner.db().selectList("select * from test_example limit 1,10");個人比較推薦使用這種方式來查詢原生SQL,既不會污染Mapper,也不會被報出代碼漏洞。
總結(jié)
到此這篇關(guān)于MybatisPlus調(diào)用原生SQL的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)MybatisPlus調(diào)用原生SQL內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java自學(xué)書籍推薦 程序員到架構(gòu)師必看的書
這篇文章主要為大家推薦了Java程序員到架構(gòu)師自學(xué)書籍,幫助大家不斷提高自己的專業(yè)水平,感興趣的小伙伴們可以參考一下2016-09-09
eclipse輸出Hello World的實(shí)現(xiàn)方法
這篇文章主要介紹了eclipse輸出Hello World的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Java?MapStruct優(yōu)雅地實(shí)現(xiàn)對象轉(zhuǎn)換
MapSturct?是一個生成類型安全,高性能且無依賴的?JavaBean?映射代碼的注解處理器,用它可以輕松實(shí)現(xiàn)對象轉(zhuǎn)換,下面就來和大家聊聊具體操作吧2023-06-06
Java利用釘釘機(jī)器人實(shí)現(xiàn)發(fā)送群消息
這篇文章主要為大家詳細(xì)介紹了Java語言如何通過釘釘機(jī)器人發(fā)送群消息通知,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-09-09

