|
export default class SettingUtils {
|
/**
|
* @description 生成页面查询语句
|
* @return {String} scripts 自定义脚本
|
* @return {String} searches 搜索条件
|
* @return {Object} setting 页面设置
|
* @return {Array} columns 显示字段
|
*/
|
static getDebugSql (setting, scripts, columns, searches = [], defSearch, timestamp) {
|
let sql = ''
|
let error = ''
|
let _dataresource = ''
|
let _customScript = ''
|
let arr_field = columns.map(item => item.field).join(',')
|
|
if (scripts.length > 0) {
|
scripts.forEach(item => {
|
_customScript += `
|
${item.sql}
|
`
|
})
|
}
|
|
if (!arr_field) {
|
arr_field = '*'
|
}
|
|
if (setting.interType === 'system' && setting.execute !== 'false') {
|
_dataresource = setting.dataresource || ''
|
}
|
|
if (window.GLOB.funcs && window.GLOB.funcs.length > 0) {
|
window.GLOB.funcs.forEach(item => {
|
let reg = new RegExp('\\$ex@' + item.func_code + '@ex\\$', 'ig')
|
_dataresource = _dataresource.replace(reg, `/*$ex@${item.func_code}-begin*/\n${item.key_sql}\n/*@ex$-end*/`)
|
_customScript = _customScript.replace(reg, `/*$ex@${item.func_code}-begin*/\n${item.key_sql}\n/*@ex$-end*/`)
|
})
|
}
|
|
// if (/\$ex@.{1,50}@ex\$/.test(_dataresource)) {
|
// error = '系统函数' + _dataresource.match(/\$ex@.{1,50}@ex\$/g)[0].replace(/\$ex@|@ex\$/g, '') + '未定义'
|
// } else if (/\$ex@.{1,50}@ex\$/.test(_customScript)) {
|
// error = '系统函数' + _customScript.match(/\$ex@.{1,50}@ex\$/g)[0].replace(/\$ex@|@ex\$/g, '') + '未定义'
|
// }
|
|
_dataresource = _dataresource.replace(/@(BID|ID|LoginUID|SessionUid|UserID|Appkey|time_id|datam|upid)@/ig, `'${timestamp}'`)
|
_customScript = _customScript.replace(/@(BID|ID|LoginUID|SessionUid|UserID|Appkey|time_id|datam|upid)@/ig, `'${timestamp}'`)
|
|
_dataresource = _dataresource.replace(/@\$|\$@/ig, '')
|
_customScript = _customScript.replace(/@\$|\$@/ig, '')
|
_dataresource = _dataresource.replace(/@select\$|\$select@/ig, '')
|
_customScript = _customScript.replace(/@select\$|\$select@/ig, '')
|
// _dataresource = _dataresource.replace(/@sum\$|\$sum@/ig, '')
|
_customScript = _customScript.replace(/@sum\$|\$sum@/ig, '')
|
|
_dataresource = _dataresource.replace(/\$sum@/ig, '/*$sum@')
|
_dataresource = _dataresource.replace(/@sum\$/ig, '@sum$*/')
|
|
if (_customScript) {
|
_customScript = `declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@RoleID nvarchar(512),@mk_departmentcode nvarchar(512),@mk_organization nvarchar(512),@mk_user_type nvarchar(20),@mk_nation nvarchar(50),@mk_province nvarchar(50),@mk_city nvarchar(50),@mk_district nvarchar(50),@mk_address nvarchar(100) select @ErrorCode='',@retmsg =''
|
${_customScript}
|
`
|
}
|
|
// 外联数据库替换
|
if (window.GLOB.externalDatabase !== null) {
|
_dataresource = _dataresource.replace(/@db@/ig, window.GLOB.externalDatabase)
|
_customScript = _customScript.replace(/@db@/ig, window.GLOB.externalDatabase)
|
}
|
|
if (window.GLOB.urlFields) {
|
window.GLOB.urlFields.forEach(field => {
|
let reg = new RegExp('@' + field + '@', 'ig')
|
_dataresource = _dataresource.replace(reg, `'0'`)
|
_customScript = _customScript.replace(reg, `'0'`)
|
})
|
}
|
|
// 正则替换
|
let _regoptions = []
|
let _fields = []
|
|
searches.forEach(item => {
|
if (!item.field) return
|
if (item.datefield) {
|
_regoptions.push({
|
var: new RegExp('@' + item.datefield, 'ig'),
|
reg: new RegExp('@' + item.datefield + '@', 'ig')
|
})
|
_regoptions.push({
|
var: new RegExp('@' + item.datefield + '1', 'ig'),
|
reg: new RegExp('@' + item.datefield + '1@', 'ig')
|
})
|
}
|
if (['dateweek', 'datemonth', 'daterange', 'range'].includes(item.type)) {
|
_regoptions.push({
|
var: new RegExp('@' + item.field, 'ig'),
|
reg: new RegExp('@' + item.field + '@', 'ig')
|
})
|
_regoptions.push({
|
var: new RegExp('@' + item.field + '1', 'ig'),
|
reg: new RegExp('@' + item.field + '1@', 'ig')
|
})
|
} else if (item.type === 'date') {
|
if (_fields.includes(item.field)) {
|
_regoptions.push({
|
var: new RegExp('@' + item.field + '1', 'ig'),
|
reg: new RegExp('@' + item.field + '1@', 'ig')
|
})
|
} else {
|
_fields.push(item.field)
|
_regoptions.push({
|
var: new RegExp('@' + item.field, 'ig'),
|
reg: new RegExp('@' + item.field + '@', 'ig')
|
})
|
}
|
} else if (item.type === 'text' || item.type === 'select') {
|
item.field.split(',').forEach(field => {
|
_regoptions.push({
|
var: new RegExp('@' + field, 'ig'),
|
reg: new RegExp('@' + field + '@', 'ig')
|
})
|
})
|
} else {
|
_regoptions.push({
|
var: new RegExp('@' + item.field, 'ig'),
|
reg: new RegExp('@' + item.field + '@', 'ig')
|
})
|
}
|
})
|
|
let _search = defSearch
|
|
if (_dataresource) {
|
_regoptions.forEach(item => {
|
_dataresource = _dataresource.replace(item.reg, '0')
|
})
|
|
_search = ''
|
}
|
|
let originscript = _customScript
|
|
if (_customScript) {
|
_regoptions.push({
|
reg: new RegExp('@orderBy@', 'ig'),
|
}, {
|
reg: new RegExp('@UserName@', 'ig'),
|
}, {
|
reg: new RegExp('@FullName@', 'ig'),
|
})
|
if (setting.laypage === 'true') {
|
_regoptions.push({
|
reg: new RegExp('@pageSize@', 'ig'),
|
}, {
|
reg: new RegExp('@pageIndex@', 'ig'),
|
})
|
}
|
_regoptions.forEach(item => {
|
_customScript = _customScript.replace(item.reg, '0')
|
originscript = originscript.replace(item.reg, '0')
|
})
|
}
|
|
let sumSql = ''
|
|
if (_dataresource && /\/\*\$sum@/ig.test(_dataresource)) {
|
let _sql = _dataresource.replace(/\/\*\$sum@|@sum\$\*\//ig, '')
|
_sql = `/*system_query*/${_sql} ${_search}`
|
if (_customScript) {
|
sumSql = `/* sql sum验证 */
|
${_customScript}
|
${_sql}
|
aaa:
|
if @ErrorCode!=''
|
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select '${timestamp}',@ErrorCode, @retmsg,'${timestamp}'
|
`
|
} else {
|
sumSql = `/* sql sum验证 */
|
declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@RoleID nvarchar(512),@mk_departmentcode nvarchar(512),@mk_organization nvarchar(512),@mk_user_type nvarchar(20),@mk_nation nvarchar(50),@mk_province nvarchar(50),@mk_city nvarchar(50),@mk_district nvarchar(50),@mk_address nvarchar(100) select @ErrorCode='',@retmsg =''
|
${_sql}`
|
}
|
}
|
|
// 数据源处理, 存在显示列时
|
if (_dataresource) {
|
if (/\s/.test(_dataresource)) {
|
_dataresource = '(' + _dataresource + ') tb'
|
}
|
|
if (setting.order) {
|
_dataresource = `/*system_query*/select${setting.laypage === 'true' ? ' top 10' : ''} ${arr_field} from (select ${arr_field} ,ROW_NUMBER() over(order by ${setting.order}) as rows from ${_dataresource} ${_search}) tmptable ${setting.laypage === 'true' ? 'where rows > 0' : ''} order by tmptable.rows`
|
} else {
|
_dataresource = `/*system_query*/select${setting.laypage === 'true' ? ' top 10' : ''} ${arr_field} from ${_dataresource} ${_search}`
|
}
|
}
|
|
if (_customScript) {
|
sql = `/* sql 验证 */
|
${_customScript}
|
${_dataresource}
|
aaa:
|
if @ErrorCode!=''
|
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select '${timestamp}',@ErrorCode, @retmsg,'${timestamp}'
|
`
|
} else {
|
sql = `/* sql 验证 */
|
declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@RoleID nvarchar(512),@mk_departmentcode nvarchar(512),@mk_organization nvarchar(512),@mk_user_type nvarchar(20),@mk_nation nvarchar(50),@mk_province nvarchar(50),@mk_city nvarchar(50),@mk_district nvarchar(50),@mk_address nvarchar(100) select @ErrorCode='',@retmsg =''
|
${_dataresource}`
|
}
|
sql = sql.replace(/\n\s{8}/ig, '\n')
|
|
console.info(sql)
|
|
let errors = []
|
|
if (/@[0-9a-zA-Z_]+@/ig.test(sql)) {
|
let arr = sql.match(/@[0-9a-zA-Z_]+@/ig)
|
|
arr.forEach(item => {
|
let reg = new RegExp(item, 'ig')
|
if (reg.test(_dataresource)) {
|
errors.push(`数据源中存在未替换值${item}`)
|
}
|
scripts && scripts.forEach(script => {
|
if (reg.test(script.sql)) {
|
errors.push(`自定义脚本(${script.$index || ''})存在未替换值${item}`)
|
}
|
})
|
})
|
}
|
|
if (sumSql) {
|
sumSql = sumSql.replace(/\n\s{10}/ig, '\n')
|
|
console.info(sumSql)
|
sumSql = sumSql.replace(/\n/g, ' ')
|
}
|
sql = sql.replace(/\n/g, ' ')
|
|
return { error, sql, sumSql, errors: errors.join(';') }
|
}
|
}
|