NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name Bi Enhance V2 // @namespace http://tampermonkey.net/ // @version 2024-05-17 // @description 自动生成select*语句,自动进行时间戳转换,自动再where语句中增加一个时间范围查询组件判断条件。定时添加按钮,避免多个tab没有按钮的情况 // @author qinzhanqiang // @match https://bi.sankuai.com/sql/edit* // @icon  // @grant none // @license MIT // ==/UserScript== function addButton() { return function () { // select * 按钮 const selectAllBtnArray = createSelectAllBtn(); let beforeEle = document.querySelector("#app > div > div.sidebar-container > div > div.ms-sidebar-main > div > div.router-view > div > div > div.mtd-tabs-content > div > div > div.control-buttons > div > span > button"); // 遍历按钮数组 selectAllBtnArray.forEach(function (btn) { // 设置按钮样式,这里可以根据需要设置 btn.style.cssText = 'display: inline-block;color:#fff;background:#0a70f5;white-space:nowrap;cursor:pointer;outline:0;text-align:center;font-weight:400;user-select:none;position:relative;transition:all.3s;border-radius:4px;min-width:32px;height:32px;font-size:14px;border-style:none;margin-right:10px;'; // 将按钮插入到页面中的指定位置 beforeEle.parentElement.insertBefore(btn, beforeEle); }); }; } (function() { 'use strict'; setTimeout(addButton(),1000); setTimeout(function (){ const mtdTabAdd = document.querySelector('.mtd-tabs-action.mtd-tabs-add'); mtdTabAdd.addEventListener('click', () => { console.log('Button was clicked.'); setTimeout(addButton(),150); }); }, 2000) })(); /** * 代码格式化按钮 * */ const beautify = function(){ const matchingElement = document.querySelector("#app > div > div.sidebar-container > div > div.ms-sidebar-main > div > div.router-view > div > div > div.mtd-tabs-content > div > div > div.sql-item-main > div.editor-controls > div.editor-control-button-groups > div.format-control.control-item > button"); matchingElement.click() }; /** * 获取选中的表名称 * */ const getTableName = function(){ return document.getElementsByClassName("table-line show-column")[0].childNodes[1].childNodes[0].title; }; /** * 获取表所有的行 * */ const getColsName = function(){ const tableCols = []; const table = document.getElementsByClassName("column-list")[0]; const rows = table.rows; for(let i=1; i < rows.length; i++){ const row = rows[i]; const colName = row.cells[0].title;//获取具体单元格 tableCols.push(colName); } return tableCols; }; /** * 创建select*按钮 * */ function createSelectAllBtn() { let selectAllBtnList = []; const cmList = document.getElementsByClassName("CodeMirror cm-s-ms-light CodeMirror-wrap"); for (let i = 0; i < cmList.length; i++) { let elementsByClassName = document.getElementsByClassName("BiEnhance" + [i]); if (elementsByClassName.length > 0){ continue; } let selectAllBtn = document.createElement("button"); selectAllBtn.innerText = "select *"; selectAllBtn.className = "BiEnhance" + [i] selectAllBtn.onclick = (function (index) { return function () { const cm = cmList[index].CodeMirror; const tableName = getTableName(); let colsName = getColsName(); let tableColsStr = getTableColsStr(colsName); let createTimeWhere = getCreateTimeWhereStr(colsName); // 拼写最终的sql const finalSql = "select " + tableColsStr + " from " + tableName + " where (1=1) " + createTimeWhere + " order by id desc limit 100"; cm.setValue(finalSql); beautify(); } })(i); selectAllBtnList.push(selectAllBtn); } return selectAllBtnList; } /** * 获取表所有的行拼接成字符串,如果发现有"ctime", "utime", "optime", "create_time", "modify_time" 自动加一行转换成正常时间格式 * */ const getTableColsStr = function (tableCols) { let result = ""; for (let i=0;i<tableCols.length;i++){ if (result.length > 0){ result += ", "; } result += "`" + tableCols[i] + "`"; if (tableCols[i].includes("time")){ result += ", FROM_UNIXTIME(`" + tableCols[i] + "`/1000)"; } } return result; } /** * 获取创建时间where条件,如果字符中包含["ctime", "optime", "create_time"]字段自动加上根据这个字段组件查询条件 * */ const getCreateTimeWhereStr= function (tableCols) { let timeList = ["ctime", "optime", "create_time"]; for (let i=0;i<tableCols.length;i++){ if (timeList.includes(tableCols[i])){ return "and ("+ tableCols[i] +" BETWEEN UNIX_TIMESTAMP(\"$$begindate 00:00:00\") * 1000 and UNIX_TIMESTAMP(\"$$enddate 23:59:59\") * 1000)"; } } return ""; }