java直接獲取MyBatis將要執行的動態sql命令(不是攔截器方式)

目錄

前言

一. 準備數據

1. 傳輸過來的json條件數據

2. mybatis 配置的動態sql

3. 想要的最終會執行的sql并返回給頁面展示

二. 實現方式

三. 最終代碼


前言

        1.在平常開發過程中,MyBatis使用時非常多的,一般情況下我們只需要在控制臺看看MyBatis輸出的日志,要不就是實現 MyBatis 提供的接口 Interceptor 來攔截,對執行前進行一些操作。

        2.但是有這么一種需求,將 MyBatis 的 sql 都配置到數據庫里,相當于一個字符串,通過傳輸的 json 參數獲取 MyBatis 解析 動態sql 獲取最終sql,并返回給頁面展示,是不是很小眾的需求。

MappedStatement ms = configuration.getMappedStatement("com.路徑.類名.方法名");
BoundSql boundSql = ms.getBoundSql(map);
String sql = boundSql.getSql();
System.out.println(sql);

        3.網上也沒有太多案例,大部分都是此類只能解析靜態sql的案例,很少有解析動態sql的案例,今天就遇到了,所以今天記錄下是怎么實現的。

一. 準備數據

比方說我們有這么一組數據

1. 傳輸過來的json條件數據

{"id": "17484150668118547d7bd2c539749a378d8a69dfa26d","serialNum": 1,"courseId": "2024-2025-2-D571061023-075212","orderNum": 2,"list1": ["362D8FD7F24DABACE065020C29BC0833"],"name": "啦啦","way": "1","list2": [{"orderNum": 3,"id": "1748415080498a2142926e7e22c483e1f6e7a84b48387","name": "3哈3"},{"orderNum": 4,"id": "17484150985463b22fcccb983ead6a6bc8e4f11fdadcd6","name": "4哈4"}]
}

2. mybatis 配置的動態sql

BEGINinsert into t_aaaaaaa (id, course_id, name, serial_num, way, order_num, create_date, update_date)  values(#{id}, #{courseId}, #{name} , #{serialNum} ,  #{way} , #{orderNum}, sysdate, sysdate);<foreach collection="list1" item="item" index="index" >insert into t_bbbbbbbb (id, host_id, ass_id)values (sys_guid(), #{id}, #{item});</foreach><if test="list2 != null and list2.size > 0"><foreach collection="list2" item="item" index="index" >insert into t_cccccccc (id, course_id, host_id, order_num, create_date, update_date, name)values (sys_guid(), #{courseId}, #{id}, #{item.orderNum}, sysdate, sysdate, #{item.name});</foreach></if>
END;

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/85308.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/85308.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/85308.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

機器學習算法-決策樹

今天我們用一個 「相親決策」 的例子來講解決策樹算法&#xff0c;保證你輕松理解原理和實現&#xff01; &#x1f333; 決策樹是什么&#xff1f; 決策樹就像玩 「20個問題」猜謎游戲&#xff1a; 你心里想一個東西&#xff08;比如「蘋果」&#xff09; 朋友通過一系列問題…

2025——》VSCode Windows 最新安裝指南/VSCode安裝完成后如何驗證是否成功?2025最新VSCode安裝配置全攻略

1.VSCode Windows 最新安裝指南: 以下是 2025 年 Windows 系統下安裝 Visual Studio Code(VSCode)的最新指南,結合官方文檔與實際操作經驗整理而成: 一、下載官方安裝包: 1.訪問官網: 打開瀏覽器,進入 VSCode 官方下載頁面https://code.visualstudio.com/Download 2…

【Elasticsearch】suggest

在Elasticsearch中&#xff0c;suggest 是一個非常強大的功能&#xff0c;用于實現自動補全、拼寫糾錯和模糊搜索等功能。它可以幫助用戶更快地找到他們想要的內容&#xff0c;同時提升搜索體驗。以下是關于 suggest 的詳細使用方法和常見場景。 1\. Suggest 的基本概念 sugges…

[SAP] 如何查詢當前屏幕的Tcode?

事務代碼Tcode是SAP中到達特定屏幕的快捷路徑 如何查詢以下屏幕的事務碼Tcode&#xff1f; 要瀏覽當前所使用的屏幕的事務碼&#xff0c;可以選擇System | Status 這里的事務代碼是[VA22]&#xff0c;它是Change Quotation的事務代碼

PostgreSQL的擴展 dblink

PostgreSQL的擴展 dblink dblink 是 PostgreSQL 的一個核心擴展&#xff0c;允許在當前數據庫中訪問其他 PostgreSQL 數據庫的數據&#xff0c;實現跨數據庫查詢功能。 一、dblink 擴展安裝與啟用 1. 安裝擴展 -- 使用超級用戶安裝 CREATE EXTENSION dblink;2. 驗證安裝 -…

ADB推送文件到指定路徑解析

您執行的命令 adb push ota.zip /sdcard/Download 中&#xff0c;目標路徑 /sdcard/Download 是您顯式指定的&#xff0c;因此 ADB 會直接將文件推送到此位置。具體過程如下&#xff1a; 1. 命令結構解析 adb push&#xff1a;ADB 的推送指令。ota.zip&#xff1a;本地計算機上…

Linux 內核中 skb_orphan 的深度解析:從版本差異到核心機制

引言 在 Linux 內核網絡子系統中,struct sk_buff(簡稱 skb)是管理網絡數據包的核心數據結構。skb_orphan 作為其生命周期管理的關鍵函數,負責切斷 skb 與所屬 socket 的關聯,確保數據包在復雜處理流程中的獨立性。本文將從代碼實現、版本差異、使用場景等多個維度,深入解…

03.MySQL表的操作詳解

MySQL表的操作詳解 MySQL 表的操作概述創建表 2.1 創建表的基本語法查看表結構修改表 4.1 新增列 4.2 修改列屬性 4.3 修改列名 4.4 修改表名 4.5 刪除列刪除表 1. MySQL表的操作概述 MySQL表的操作是數據庫開發和管理中的核心內容&#xff0c;主要涉及**數據定義語言&#…

Flink系列文章列表

把寫的文章做一個匯總&#xff0c;會陸續更新的。 Flink流處理原理與實踐&#xff1a;狀態管理、窗口操作與容錯機制-CSDN博客

【目標檢測】【AAAI-2022】Anchor DETR

Anchor DETR&#xff1a; Query Design for Transformer-Based Object Detection 錨點DETR&#xff1a;基于Transformer的目標檢測查詢設計 論文鏈接 代碼鏈接 摘要 在本文中&#xff0c;我們提出了一種基于Transformer的目標檢測新型查詢設計。此前的Transformer檢測器中&am…

apptrace 的優勢以及對 App 的價值

官網地址&#xff1a;AppTrace - 專業的移動應用推廣追蹤平臺 apptrace 的優勢以及對 App 的價值? App 拉起作為移動端深度鏈接技術的關鍵應用&#xff0c;能實現從 H5 網頁到 App 的無縫跳轉&#xff0c;并精準定位到 App 內指定頁面。apptrace 憑借專業的技術與豐富的經驗…

16-前端Web實戰(Tlias案例-部門管理)

在前面的課程中&#xff0c;我們學習了Vue工程化的基礎內容、TS、ElementPlus&#xff0c;那接下來呢&#xff0c;我們要通過一個案例&#xff0c;加強大家對于Vue項目的理解&#xff0c;并掌握Vue項目的開發。 這個案例呢&#xff0c;就是我們之前所做的Tlias智能學習輔助系統…

Python爬蟲實戰:研究Goutte庫相關技術

1. 引言 1.1 研究背景與意義 隨著互聯網信息的爆炸式增長,如何高效、準確地獲取和分析 Web 數據成為重要研究課題。網絡爬蟲作為自動獲取網頁內容的關鍵技術,在搜索引擎優化、輿情分析、市場調研等領域具有廣泛應用。然而,現代網站越來越多地采用 JavaScript 動態渲染技術…

Python----目標檢測(《基于區域提議網絡的實時目標檢測方法》和Faster R-CNN)

一、《基于區域提議網絡的實時目標檢測方法》 1.1、基本信息 標題&#xff1a;Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks 作者&#xff1a;任少卿&#xff08;中國科學技術大學、微軟研究院&#xff09;、何凱明&#xff08;微軟研究…

吳恩達講解MCP基礎概念

簡介 MCP 是一個開放協議 標準化了您的語言模型應用如何獲取工具和數據資源的上下文。基于客戶端-服務器架構,它定義了您的語言模型應用中的MCP客戶端與MCP服務器之間的通信方式,MCP服務器提供工具 數據資源和提示模板給您的應用,自Anthropic于2024年11月推出MCP以來,MCP生…

Git入門到精通:30分鐘掌握核心技巧

目錄 一、基礎理論片 Git簡介 Git安裝 Git倉庫 Git基本命令用法 倉庫別名 二、實操命令篇 遠程分支 分支的新建和合并 實操演示 1 本地新建倉庫 2 gitee新建倉庫 3 建立關系 4 新建分支 5 開發新功能 6 推送新分支 7 合并新分支到主分支 三、可視化工具篇 G…

零基礎設計模式——結構型模式 - 代理模式

第三部分&#xff1a;結構型模式 - 代理模式 (Proxy Pattern) 在學習了享元模式如何通過共享對象來優化資源使用后&#xff0c;我們來探討結構型模式的最后一個模式——代理模式。代理模式為另一個對象提供一個替身或占位符以控制對這個對象的訪問。 核心思想&#xff1a;為其…

【OSS】 前端如何直接上傳到OSS 上返回https鏈接,如果做到OSS圖片資源加密訪問

使用阿里云OSS&#xff08;對象存儲服務&#xff09;進行前端直接上傳并返回HTTPS鏈接&#xff0c;同時實現圖片資源的加密訪問&#xff0c;可以通過以下步驟實現&#xff1a; 前端直接上傳到OSS并返回HTTPS鏈接 設置OSS Bucket&#xff1a; 確保你的OSS Bucket已創建&#xf…

TDenigne 集群可視化管理

可視化管理工具 為方便用戶更高效地使用和管理 TDengine&#xff0c;TDengine 3.0 版本推出了一個全新的可視化組件 taosExplorer。這個組件旨在幫助用戶在不熟悉 SQL 的情況下&#xff0c;也能輕松管理 TDengine 集群。通過 taosExplorer&#xff0c;用戶可以輕松查看 TDengi…

Centos7安裝gitlab

環境準備&#xff1a; 操作系統&#xff1a;Centos7 內存&#xff1a;2G以上 磁盤&#xff1a;50G 安全&#xff1a;關閉防火墻&#xff0c;selinux 1、安裝GitLab所需依賴 yum -y install policycoreutils openssh-server openssh-clients postfix 2、設置postfix開機自啟…