1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
| export default class SettingUtils {
| static getDebugSql (setting, columns, scripts, declareSql) {
| let sql = ''
| let _dataresource = setting.dataresource || ''
|
| let _customScript = ''
| let _tailScript = ''
| scripts && scripts.forEach(script => {
| if (script.status === 'false') return
| if (script.position !== 'back') {
| _customScript += `
| ${script.sql}
| `
| } else {
| _tailScript += `
| ${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 ='',@UserName='', @FullName='', @RoleID='', @mk_departmentcode='', @mk_organization='', @mk_user_type='', @mk_nation='', @mk_province='', @mk_city='', @mk_district='', @mk_address=''
| ${declareSql}
| ${_customScript}
| `
| }
|
| if (setting.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'
| }
|
| // 正则替换
| let regoptions = [{
| reg: new RegExp('@orderBy@', 'ig'),
| value: setting.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: ''
| }]
|
| regoptions.forEach(item => {
| _dataresource = _dataresource.replace(item.reg, item.value)
| _customScript = _customScript.replace(item.reg, item.value)
| _tailScript = _tailScript.replace(item.reg, item.value)
| })
|
| let arr_field = columns.map(col => col.field)
| arr_field = arr_field.join(',')
|
| if (!arr_field) {
| arr_field = '*'
| }
|
| // 数据源处理, 存在显示列时
| if (_dataresource) {
| if (custompage || !setting.order) {
| _dataresource = `/*system_query*/select ${arr_field} from ${_dataresource}`
| } else {
| _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`
| }
| }
|
| if (_customScript) {
| sql = `${_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 @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=''
| ${declareSql}
| ${_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 @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=''
| ${declareSql}
| ${_dataresource}`
| }
|
| return sql
| }
| }
|
|