• 开发工具分享 - Mybatis SQL日志格式化H5


    一、 序言

    平时通过IDEA开发,可以直接装相关MybatisLogFormat的插件直接对控制台里的Mybatis SQL日志进行格式化。一旦离开本地环境,到了测试或者线上,就得自己手动拼参数了。

    简单的SQL还好,复杂点或者查询条件多的SQL简直让人怀疑人生,今天分享一个简单的SQL格式化H5,从此解放拼接的双手。


    二、代码示例

    DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>title>
        <script type="text/javascript">
            function f(obj) {
                var textVa = obj.value;
                // 获取带问号的SQL语句
                var statementStartIndex = textVa.indexOf('Preparing: ');
                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;
                return textVa;
            }
    
            function copySQL() {
                var SQL = document.getElementById("d1");
                SQL.select(); // 选择对象
                document.execCommand("Copy"); // 执行浏览器复制命令
                var msg = document.getElementById("msg");
                msg.innerHTML = "已复制到剪切板";
                setTimeout(function () {
                    msg.innerHTML = "";
                }, 3000);
    
            }
    
            function clearLog(obj) {
                obj.select();
                obj.value = "";
            }
    
        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="submit"
                onclick="f(document.getElementById('sqlLog'))">
            解析SQL
        button>
    div>
    
    <h2><font color="#32cd32">解析为可执行SQL:font>h2>
    
    <textarea id="d1" 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="copySQL()">复制SQLbutton>
    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>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101

    三、部署至Nginx

    接下来我们直接将该静态文件扔到Nginx中就好了,部署也很简单,方便易用,配置如下:

    location /h5/sql-formatter {
      alias h5/mybatis-log-formatter;
    }
    
    • 1
    • 2
    • 3

    备注:我部署的文件路径为/opt/appl/nginx/h5/mybatis-log-formatter

    打开浏览器,访问http://localhost/h5/sql-formatter/sql.html,点击解析SQL就可以解析出拼接好条件的SQL,如下:
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    线程池创建和简单使用
    react-native渲染富文本的几种方案
    【星穹杂谈】为什么寰宇蝗灾难到折磨玩家却令玩家一致好评?
    DES 加解密--JAVA 实现
    经济下行基建托底,偶数湖仓一体打造坚实新基建数字底座
    ZCC5429 异步升压芯片
    理德外汇:美长债收益率再次向5%迈进 提振美元同时压制股市
    5.Nginx负载均衡实例
    C++Primer 16.1定义模板 习题总结
    【JavaScript-进阶】详解数据类型,内存分配,API元素对象获取
  • 原文地址:https://blog.csdn.net/lingbomanbu_lyl/article/details/133888522