2 Star 14 Fork 4

ZaleJ/JS-mybatis-log-plugin

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
js-mybatis-log-plugin.html 4.11 KB
一键复制 编辑 原始数据 按行查看 历史
Evan 提交于 2021-10-26 11:06 . 添加一键复制功能
<!DOCTYPE html>
<html lang="ch-zn">
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
function multiTransefer(inputText) {
// 将传入的字符串根据MyBatis的标识拆分成数组
var mybatisSQLTexts = [];
while (inputText.lastIndexOf('Preparing: ') > -1) {
// 因为是从尾部截取,所以需要从数组的头部添加
mybatisSQLTexts.unshift(inputText.substring(inputText.lastIndexOf('Preparing: ')));
inputText = inputText.substring(0, inputText.lastIndexOf('Preparing: '));
}
console.log(mybatisSQLTexts);
// 将数组中的字符串挨个处理,以数组形式返回
for (var i = 0; i < mybatisSQLTexts.length; i++) {
parseSql(mybatisSQLTexts[i]);
}
}
// 单句的问号生成SQL
function parseSql(textVa) {
// 获取带问号的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" || typeStr === "Date") {
statementStr = statementStr.replace("?", "'" + tempStr.trim() + "'");
} else {
// 数值类型
statementStr = statementStr.replace("?", tempStr.trim());
}
}
// console.log(statementStr);
document.getElementById("logAfterId").value += '\n\n\n';
document.getElementById("logAfterId").value += statementStr;
return textVa;
}
function clearContent() {
document.getElementById('logBeforeId').value = '';
document.getElementById('logAfterId').value = '';
}
function copy2() {
var logAfter=document.getElementById("logAfterId");
logAfter.select(); // 选择对象
document.execCommand("Copy"); // 执行浏览器复制命令
}
</script>
</head>
<body>
<textarea style="width:40%;" name="logBefore" id="logBeforeId" rows="40" placeholder="转换前的log"></textarea>
<button style="width:60px" type="submit" onclick="multiTransefer(document.getElementById('logBeforeId').value)">转换</button>
<button style="width:60px" type="input" onclick="clearContent()">清除</button>
<button style="width:60px" type="input" onclick="copy2()">复制</button>
<textarea style="width:40%;" name="logAfter" id="logAfterId" rows="40" placeholder="转换后的SQL"></textarea>
</body>
</html>
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/ZaleJ/JS-mybatis-log-plugin.git
git@gitee.com:ZaleJ/JS-mybatis-log-plugin.git
ZaleJ
JS-mybatis-log-plugin
JS-mybatis-log-plugin
develop

搜索帮助