|
export default class SettingUtils {
|
/**
|
* @description 生成页面查询语句
|
* @return {String} arr_field 显示列字段
|
* @return {String} search 搜索条件
|
* @return {Object} setting 页面设置
|
* @return {Array} regoptions 搜索条件正则替换
|
*/
|
static getDebugSql (setting, scripts, arr_field, regoptions, search) {
|
let sql = ''
|
let _dataresource = setting.dataresource || ''
|
let _customScript = ''
|
scripts && scripts.forEach(script => {
|
_customScript += `
|
${script.sql}
|
`
|
})
|
|
if (_customScript) {
|
_customScript = `declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@login_city nvarchar(50) select @ErrorCode='',@retmsg =''
|
${_customScript}
|
`
|
}
|
|
if (setting.default === 'false') {
|
_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*/`)
|
})
|
}
|
|
_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, '')
|
|
// 外联数据库替换
|
if (window.GLOB.externalDatabase !== null) {
|
_dataresource = _dataresource.replace(/@db@/ig, window.GLOB.externalDatabase)
|
_customScript = _customScript.replace(/@db@/ig, window.GLOB.externalDatabase)
|
}
|
|
// 正则替换
|
let _regoptions = regoptions.map(item => {
|
return {
|
reg: new RegExp('@' + item.key + '@', 'ig'),
|
value: `'0'`,
|
type: item.type || ''
|
}
|
})
|
|
_regoptions.push({
|
reg: new RegExp('@login_city@', 'ig'),
|
value: `''`
|
}, {
|
reg: new RegExp('@userName@', 'ig'),
|
value: `''`
|
}, {
|
reg: new RegExp('@fullName@', 'ig'),
|
value: `''`
|
}, {
|
reg: new RegExp('@orderBy@', 'ig'),
|
value: setting.order
|
}, {
|
reg: new RegExp('@pageSize@', 'ig'),
|
value: 10
|
}, {
|
reg: new RegExp('@pageIndex@', 'ig'),
|
value: 1
|
})
|
|
let _search = search
|
|
if (setting.queryType === 'statistics' && _dataresource) {
|
_regoptions.forEach(item => {
|
_dataresource = _dataresource.replace(item.reg, item.value)
|
})
|
_search = ''
|
} else if (_dataresource) {
|
_regoptions.forEach(item => {
|
if (item.type !== 'url') return
|
_dataresource = _dataresource.replace(item.reg, item.value)
|
})
|
}
|
|
if (_customScript) {
|
_regoptions.forEach(item => {
|
_customScript = _customScript.replace(item.reg, item.value)
|
})
|
}
|
|
// 数据源处理, 存在显示列时
|
if (arr_field && _dataresource) {
|
if (/\s/.test(_dataresource)) {
|
_dataresource = '(' + _dataresource + ') tb'
|
}
|
|
_dataresource = `select ${setting.laypage !== 'false' ? 'top 10' : ''} ${arr_field} from (select ${arr_field} ,ROW_NUMBER() over(order by ${setting.order}) as rows from ${_dataresource} ${_search}) tmptable ${setting.laypage !== 'false' ? 'where rows > 0' : ''} order by tmptable.rows`
|
}
|
|
if (_customScript) {
|
sql = `/* sql 验证 */
|
${_customScript}
|
${_dataresource}
|
aaa:
|
if @ErrorCode!=''
|
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select @time_id@,@ErrorCode, @retmsg,@UserID@
|
`
|
} else {
|
sql = `/* sql 验证 */
|
${_dataresource}`
|
}
|
sql = sql.replace(/\n\s{8}/ig, '\n')
|
console.info(sql)
|
|
return sql
|
}
|
|
/**
|
* @description 生成前置或后置语句
|
* @return {String} scripts 脚本
|
* @return {Array} regoptions 搜索条件正则替换
|
*/
|
static getCustomDebugSql (scripts, regoptions) {
|
let sql = ''
|
let _customScript = ''
|
|
scripts.forEach(script => {
|
if (script.status === 'false') return
|
|
_customScript += `
|
${script.sql}
|
`
|
})
|
|
if (_customScript) {
|
_customScript = `declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@login_city nvarchar(50) select @ErrorCode='',@retmsg =''
|
${_customScript}
|
`
|
}
|
|
if (window.GLOB.funcs && window.GLOB.funcs.length > 0) {
|
window.GLOB.funcs.forEach(item => {
|
let reg = new RegExp('\\$ex@' + item.func_code + '@ex\\$', 'ig')
|
_customScript = _customScript.replace(reg, `/*$ex@${item.func_code}-begin*/\n${item.key_sql}\n/*@ex$-end*/`)
|
})
|
}
|
|
_customScript = _customScript.replace(/@\$|\$@/ig, '')
|
_customScript = _customScript.replace(/@userName@|@fullName@|@login_city@/ig, `''`)
|
// 外联数据库替换
|
if (window.GLOB.externalDatabase !== null) {
|
_customScript = _customScript.replace(/@db@/ig, window.GLOB.externalDatabase)
|
}
|
|
// 正则替换
|
if (regoptions) {
|
let _regoptions = regoptions.map(item => {
|
return {
|
reg: new RegExp('@' + item.key + '@', 'ig'),
|
value: `'0'`
|
}
|
})
|
_regoptions.forEach(item => {
|
_customScript = _customScript.replace(item.reg, item.value)
|
})
|
}
|
|
if (_customScript) {
|
sql = `/* sql 验证 */
|
${_customScript}
|
aaa:
|
if @ErrorCode!=''
|
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select @time_id@,@ErrorCode, @retmsg,@UserID@
|
`
|
}
|
sql = sql.replace(/\n\s{8}/ig, '\n')
|
console.info(sql)
|
|
return sql
|
}
|
}
|