Mybatis SQL日志如何轉換為可執(zhí)行sql
更新時間:2023年09月22日 11:18:54 作者:nacrt
這篇文章主要介紹了Mybatis SQL日志如何轉換為可執(zhí)行sql問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
Mybatis SQL日志轉換為可執(zhí)行sql
mybatis log --> sql
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script type="text/javascript"> function f(obj) { getSql(obj.value); } function getSql(textVa) { // 獲取帶問號的SQL語句 var statementStartIndex = textVa.indexOf('Preparing: '); if (statementStartIndex < 0) return; var statementEndIndex = textVa.length - 1; for (var i = statementStartIndex; i < textVa.length; i++) { if (textVa[i] == "\n") { statementEndIndex = i; break; } } var statementStr = textVa.substring(statementStartIndex + "Preparing: ".length, statementEndIndex); console.log(statementStr); //獲取參數 var parametersStartIndex = textVa.indexOf('Parameters: '); var parametersEndIndex = textVa.length - 1; for (var i = parametersStartIndex; i < textVa.length; i++) { if (textVa[i] == "\n") { parametersEndIndex = i; break; } else { console.log(textVa[i]); } } var parametersStr = textVa.substring(parametersStartIndex + "Parameters: ".length, parametersEndIndex); parametersStr = parametersStr.split(","); console.log(parametersStr); for (var i = 0; i < parametersStr.length; i++) { // 如果數據中帶括號將使用其他邏輯 tempStr = parametersStr[i].substring(0, parametersStr[i].indexOf("(")); // 獲取括號中內容 typeStr = parametersStr[i].substring(parametersStr[i].indexOf("(") + 1, parametersStr[i].indexOf(")")); // 如果為字符類型或時間 加'' if (typeStr == "String" || typeStr == "Timestamp") { statementStr = statementStr.replace("?", "'" + tempStr.trim() + "'"); } else { // 數值類型 statementStr = statementStr.replace("?", tempStr.trim()); } } console.log(statementStr); document.getElementById("d1").innerHTML += statementStr + "\n-- ---------------------------------------------------------------------------------------------------------------------\n"; var newText = textVa.substring(parametersStartIndex + parametersStr.length); if (newText <= 0) return; getSql(newText); } function copySQL() { var SQL = document.getElementById("d1"); SQL.select(); // 選擇對象 document.execCommand("Copy"); // 執(zhí)行瀏覽器復制命令 var msg = document.getElementById("msg"); msg.innerHTML = "已復制到剪切板"; setTimeout(function () { msg.innerHTML = ""; }, 3000); } function clearLog(obj) { obj.select(); obj.value = ""; } function clearOut(obj) { obj.innerHTML = ""; } </script> </head> <body> <h2><font color="#00bfff"> 輸入Mybatis SQL日志:</font></h2> <textarea id="sqlLog" rows="13" cols="140" style="font-size:20px"></textarea> <div style="border:0px deepskyblue solid;width:1425px;height:50px;text-align:right"> <button style="color:mediumblue;width:100px;height:60px" type="button" onclick="clearLog(document.getElementById('sqlLog'))"> 清空輸入 </button> <button style="color:mediumblue;width:100px;height:60px" type="button" onclick="clearOut(document.getElementById('d1'))"> 清空輸出 </button> <button style="color:mediumblue;width:100px;height:60px" type="submit" onclick="f(document.getElementById('sqlLog'))"> 解析SQL </button> </div> <h2><font color="#32cd32">解析為可執(zhí)行SQL:</font></h2> <textarea id="d1" rows="13" cols="140" style="font-size:20px" readonly></textarea> <div style="border:0px deepskyblue solid;width:1425px;height:50px;text-align:right"> <button style="color:mediumblue;width:100px;height:60px" type="button" onclick="copySQL()">復制SQL</button> </div> <div id="msg" style="color:cornflowerblue;border:0px black solid;width:800px;height:20px;text-align:right;font-style: initial;font-size: large"> </div> </body> </html>
效果如圖:
ssm框架中,mybatis的sql語句日志輸出
mybatis-config.xml配置
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration ? ? ? ? PUBLIC "-//mybatis.org//DTD Config 3.0//EN" ? ? ? ? "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> ? ? <settings> ? ? ? ? ?<!--打印查詢語句--> ? ? ? ? <setting name="logImpl" value="STDOUT_LOGGING"/> ? ? </settings> </configuration>
注意:
在增加mybatis-config.xml后,需要在spring與mybatis的整合配置文件(spring-mybatis.xml)中增加映射才可生效,
如下:
<!-- spring和MyBatis整合--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> ? ? <property name="dataSource" ref="dataSource" /> ? ? <!-- 自動掃描mybatis配置文件 --> ? ? <property name="configLocation" value="classpath:mybatis-config.xml"></property> ? ? <!-- 自動掃描mapping.xml文件 --> ? ? <property name="mapperLocations" value="classpath:com/merch/mapping/*.xml"></property> </bean>
log4j.properties
#log4j.rootLogger=DEBUG,CONSOLE,A #log4j.addivity.org.apache=false #log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender #log4j.appender.CONSOLE.Threshold=DEBUG #log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyy-MM-dd HH\:mm\:ss} -%-4r [%t] %-5p ?%x - %m%n #log4j.appender.CONSOLE.Target=System.out #log4j.appender.CONSOLE.Encoding=UTF-8 #log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout #log4j.appender.A=org.apache.log4j.DailyRollingFileAppender ##log4j.appender.A.File=D:/logs/log.log4j #log4j.appender.A.DatePattern=yyyy-MM-dd'.log' #log4j.appender.A.layout=org.apache.log4j.PatternLayout #log4j.appender.A.layout.ConversionPattern=[FH_sys] ?%d{yyyy-MM-dd HH\:mm\:ss} %5p %c{1}\:%L \: %m%n # 這是更簡單的配置 , 忽略debug信息 , 只專注于業(yè)務 log4j.rootLogger = WARN,C ## console ### log4j.appender.C = org.apache.log4j.ConsoleAppender log4j.appender.C.Target = System.out # override the ?value of rootLogger log4j.appender.C.Threshold =DEBUG log4j.appender.C.layout = org.apache.log4j.PatternLayout log4j.appender.C.layout.ConversionPattern = [%p][%-d{yyyy-MM-dd HH:mm:ss}] %C.%M(%L) | %m%n
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Java中redisTemplate注入失敗NullPointerException異常問題解決
這篇文章主要介紹了Java中redisTemplate注入失敗NullPointerException異常問題解決,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2023-08-08解決JPA?save()方法null值覆蓋掉mysql預設的默認值問題
這篇文章主要介紹了解決JPA?save()方法null值覆蓋掉mysql預設的默認值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11