|
export default class SettingUtils {
|
static getDebugSql (setting, columns, scripts, declareSql, timestamp) {
|
let sql = ''
|
let _dataresource = setting.dataresource || ''
|
|
let _customScript = ''
|
scripts && 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),@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 =''
|
${declareSql}
|
${_customScript}
|
`
|
}
|
|
if (setting.defaultSql === 'false') {
|
_dataresource = ''
|
}
|
|
_dataresource = _dataresource.replace(/@(BID|ID|LoginUID|SessionUid|UserID|Appkey|time_id|datam|typename)@/ig, `'${timestamp}'`)
|
_customScript = _customScript.replace(/@(BID|ID|LoginUID|SessionUid|UserID|Appkey|time_id|datam|typename)@/ig, `'${timestamp}'`)
|
_dataresource = _dataresource.replace(/@\$|\$@/ig, '')
|
_customScript = _customScript.replace(/@\$|\$@/ig, '')
|
|
// 外联数据库替换
|
if (window.GLOB.externalDatabase !== null) {
|
_dataresource = _dataresource.replace(/@db@/ig, window.GLOB.externalDatabase)
|
_customScript = _customScript.replace(/@db@/ig, window.GLOB.externalDatabase)
|
}
|
|
let arr_field = columns.map(col => col.field)
|
arr_field = arr_field.join(',')
|
|
if (!arr_field) {
|
arr_field = '*'
|
}
|
|
// 数据源处理, 存在显示列时
|
if (_dataresource) {
|
if (/\s/.test(_dataresource)) {
|
_dataresource = '(' + _dataresource + ') tb'
|
}
|
|
if (setting.order) {
|
_dataresource = `/*system_query*/select ${arr_field} from (select ${arr_field} ,ROW_NUMBER() over(order by ${setting.order}) as rows from ${_dataresource}) tmptable order by tmptable.rows`
|
} else {
|
_dataresource = `/*system_query*/select ${arr_field} from ${_dataresource}`
|
}
|
}
|
|
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 验证 */
|
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 =''
|
${declareSql}
|
${_dataresource}`
|
}
|
sql = sql.replace(/\n\s{8}/ig, '\n')
|
console.info(sql)
|
sql = sql.replace(/\n/g, ' ')
|
|
return sql
|
}
|
}
|