利用Java如何獲取Mybatis動態(tài)生成的sql接口實現(xiàn)
前言
如果你有使用 JDBC 或其他類似框架的經(jīng)驗,你就能體會到根據(jù)不同條件拼接 SQL 語句有多么痛苦。拼接的時候要確保不能忘了必要的空格,還要注意省掉列名列表最后的逗號。利用動態(tài) SQL 這一特性可以徹底擺脫這種痛苦。通常使用動態(tài) SQL 不可能是獨立的一部分,MyBatis 當(dāng)然使用一種強大的動態(tài) SQL 語言來改進這種情形,這種語言可以被用在任意的 SQL 映射語句中。
目的:利用mybatis動態(tài)生成sql的能力返回可執(zhí)行的sql,但并不會執(zhí)行。
場景:需要生成復(fù)雜的sql供其他程序執(zhí)行
1、編寫xml: SqlGenarate.mapper.xml
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.jason.bi.data.sql.generate"> <select id="getSql"> SELECT a, b FROM `table_name` WHERE field1 = #{field1Value} AND field2 = #{field2Value} </select> </mapper>
2、定義接口
import io.swagger.annotations.ApiOperation; import java.util.Map; /** * @author: jason * @Date: 2022-01-04 */ public interface SqlService { @ApiOperation(value = "動態(tài)生成sql") String generate(String sqlId, Map<String, Object> paramMap); }
3、實現(xiàn)接口
sqlId = namespace + ‘.’ + id
如SqlGenarate.mapper.xml中g(shù)etSql對應(yīng)的sqlId即為:com.jason.bi.data.sql.generate.getSql
paramMap為參數(shù),paramMap.put(“field1Value”,“abc”),paramMap.put(“field2Value”,“efg”)
,
import org.apache.ibatis.mapping.BoundSql; import org.apache.ibatis.mapping.MappedStatement; import org.apache.ibatis.mapping.ParameterMapping; import org.apache.ibatis.session.Configuration; import org.apache.ibatis.session.SqlSessionFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.List; import java.util.Map; /** * @author: jason * @Date: 2022-01-04 */ @Service public class SqlServiceImpl implements SqlService { @Autowired private SqlSessionFactory sqlSessionFactory; @Override public String generate(String sqlId, Map<String, Object> paramMap) { //獲取執(zhí)行sql Configuration con = sqlSessionFactory.getConfiguration(); //傳xml文件中的 需要執(zhí)行的id編號,如: com.jason.bi.data.sql.generate.getSql MappedStatement s = con.getMappedStatement(sqlId); BoundSql bSql = s.getBoundSql(paramMap); //獲取到sql中封裝的參數(shù)的數(shù)量 List<ParameterMapping> paramValues = bSql.getParameterMappings(); return getExecuteSql(bSql.getSql(), paramValues, paramMap); } /** * 生成可執(zhí)行sql * * @param sql 獲取的sql * @param paramValues 動態(tài)參key * @param map 動態(tài)參valur * @return */ private String getExecuteSql(String sql, List<ParameterMapping> paramValues, Map map) { while (sql.indexOf("?") != -1 && paramValues.size() > 0) { String paramName = paramValues.get(0).getProperty(); String paramValue = map.get(paramName).toString(); String value = ""; if (paramValue instanceof String) { value = "'" + paramValue + "'"; } sql = sql.replaceFirst("\\?", value); paramValues.remove(0); } return sql; } }
總結(jié)
到此這篇關(guān)于利用Java如何獲取Mybatis動態(tài)生成sql接口實現(xiàn)的文章就介紹到這了,更多相關(guān)Java獲取Mybatis動態(tài)生成sql接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis多層嵌套resultMap及返回自定義參數(shù)詳解
這篇文章主要介紹了mybatis多層嵌套resultMap及返回自定義參數(shù)詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12Java開發(fā)環(huán)境配置及Vscode搭建過程
今天通過圖文并茂的形式給大家介紹Java開發(fā)環(huán)境配置及Vscode搭建過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-07-07關(guān)于MyBatis通用Mapper@Table注解使用的注意點
這篇文章主要介紹了關(guān)于MyBatis通用Mapper@Table注解使用的注意點,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11SpringBoot 使用@WebMvcTest測試MVC Web Controller
這篇文章主要介紹了SpringBoot 使用@WebMvcTest測試MVC Web Controller,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11Spring boot集成Go-FastDFS實現(xiàn)圖片上傳刪除等功能實現(xiàn)
這篇文章主要介紹了Spring boot集成Go-FastDFS實現(xiàn)圖片上傳刪除等功能實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04