|
import { formatSearch, getSearchRegs, joinMainSearchkey } from '@/utils/utils-custom.js'
|
|
export default class SettingUtils {
|
/**
|
* @description 生成页面查询语句
|
*/
|
static getDebugSql (verify, scripts, searches) {
|
let sql = ''
|
let _dataresource = verify.dataresource || ''
|
let _search = formatSearch(searches)
|
let regoptions = getSearchRegs(_search)
|
|
_search = joinMainSearchkey(_search)
|
|
let arr_field = []
|
verify.columns.forEach(item => {
|
if (item.output === 'false' || item.Column === '$Index') return
|
|
arr_field.push(item.Column)
|
})
|
arr_field = arr_field.join(',')
|
|
if (!arr_field) {
|
arr_field = '*'
|
}
|
|
let _customScript = ''
|
let _tailScript = ''
|
scripts && scripts.forEach(script => {
|
if (script.status === 'false') return
|
if (script.position !== 'back') {
|
_customScript += `
|
${script.sql}
|
`
|
} else {
|
_tailScript += `
|
${script.sql}
|
`
|
}
|
})
|
|
let declare = `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 ='',@UserName='', @FullName='', @RoleID='', @mk_departmentcode='', @mk_organization='', @mk_user_type='', @mk_nation='', @mk_province='', @mk_city='', @mk_district='', @mk_address=''`
|
|
if (verify.defaultSql === 'false') {
|
_dataresource = ''
|
}
|
|
let custompage = false
|
|
if (/order\s+by\s+sort_id\s*$/i.test(_dataresource)) {
|
custompage = true
|
} else if (/@pageSize@|@orderBy@|@mk_total/i.test(_dataresource + _customScript)) {
|
custompage = true
|
}
|
|
if (/\s/.test(_dataresource)) {
|
_dataresource = '(' + _dataresource + ') tb'
|
}
|
|
// 正则替换
|
regoptions.push({
|
reg: new RegExp('@orderBy@', 'ig'),
|
value: verify.order
|
}, {
|
reg: new RegExp('@pageSize@', 'ig'),
|
value: 10
|
}, {
|
reg: new RegExp('@pageIndex@', 'ig'),
|
value: 1
|
}, {
|
reg: /@datam@/ig,
|
value: `''`
|
}, {
|
reg: /@typename@/ig,
|
value: `'debug'`
|
}, {
|
reg: /@\$|\$@/ig,
|
value: ''
|
})
|
|
if (window.GLOB.process) {
|
regoptions.push({reg: /@works_flow_code@/ig, value: `'mk_flow_code'`})
|
}
|
|
regoptions.forEach(item => {
|
_dataresource = _dataresource.replace(item.reg, item.value)
|
_customScript = _customScript.replace(item.reg, item.value)
|
_tailScript = _tailScript.replace(item.reg, item.value)
|
})
|
|
if (verify.queryType === 'statistics' && _dataresource) {
|
_search = ''
|
}
|
|
// 数据源处理, 存在显示列时
|
if (_dataresource) {
|
if (custompage || !verify.order) {
|
_dataresource = `/*system_query*/select ${arr_field} from ${_dataresource} ${_search}`
|
} else {
|
_dataresource = `/*system_query*/select ${arr_field} from (select ${arr_field} ,ROW_NUMBER() over(order by ${verify.order}) as rows from ${_dataresource} ${_search}) tmptable order by tmptable.rows `
|
}
|
}
|
|
if (_customScript) {
|
sql = `${declare}
|
${_customScript}
|
${_dataresource}
|
${_tailScript}
|
aaa:
|
if @ErrorCode!=''
|
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select @time_id@,@ErrorCode, @retmsg,'1949-10-01 15:00:00'
|
`
|
} else if (_tailScript) {
|
sql = `${declare}
|
${_dataresource}
|
${_tailScript}
|
aaa:
|
if @ErrorCode!=''
|
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select @time_id@,@ErrorCode, @retmsg,'1949-10-01 15:00:00'
|
`
|
} else {
|
sql = `${declare}
|
${_dataresource}`
|
}
|
|
return sql
|
}
|
}
|