export default class Utils { /** * @description 删除存储过程sql * @return {String} name 存储过程名称 */ static dropfunc (name) { return `IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID('${name}') AND type in (N'P', N'PC')) mdrpk PROCEDURE ${name}` } /** * @description 创建页面存储过程 * @return {String} */ static getTableFunc (param, menu, config) { let form = '' let formParam = '' let _vars = ['bid', 'pageindex', 'pagesize', 'ordercol', 'ordertype', 'exceltype', 'septmenuno', 'lang', 'debug', 'loginuid', 'sessionuid', 'userid', 'errorcode', 'retmsg'] let _columns = [] let primaryKey = config.setting.primaryKey || 'ID' if (!_vars.includes(primaryKey.toLowerCase())) { _vars.push(primaryKey.toLowerCase()) formParam = `mchr13k@${primaryKey} nvarchar(50)='',` } if (config.search && config.search.length > 0) { let _fields = new Map() config.search.forEach(item => { if (item.field) { let type = '' if (item.type.match(/date/ig)) { type = 'datetime=null' } else { type = 'nvarchar(50)=\'\'' } item.field.split(',').forEach(cell => { let _f = cell if (_fields.has(cell)) { _f = _f + '1' } _fields.set(cell, true) if (!_vars.includes(_f.toLowerCase())) { _vars.push(_f.toLowerCase()) formParam = formParam + `mchr13k@${_f} ${type},` } }) } }) } if (config.columns && config.columns.length > 0) { config.columns.forEach(item => { if (item.field) { _columns.push(`${item.field} as ${item.label}`) } }) form = ` declare @dc table (${_columns.join(',')}) @tableid ='${menu.MenuID}' ` } let Ltext = `create proc ${param.innerFunc} ( /*${menu.MenuName}*/ @appkey nvarchar(50)='', @BID nvarchar(50)='',${formParam} @PageIndex nvarchar(50)='', @PageSize nvarchar(50)='', @OrderCol nvarchar(50)='', @OrderType nvarchar(50)='', @exceltype nvarchar(50)='', @sEPTMenuNo nvarchar(50)='${menu.MenuNo}', @lang nvarchar(50)='', @debug nvarchar(50)='', @LoginUID nvarchar(50)='', @SessionUid nvarchar(50)='', @UserID nvarchar(50), @ErrorCode nvarchar(50) out, @retmsg nvarchar(4000) out ) as begin declare @BegindateTest datetime,@EnddateTest datetime select @BegindateTest=getdate() set @ErrorCode='' set @retmsg='' BEGIN TRY /*事务操作*/ BEGIN TRAN /*具体业务操作*/ /* select top 10 * from sProcExcep order by id desc declare @UserName nvarchar(50),@FullName nvarchar(50) select @UserName=UserName,@FullName=FullName from SUsers where UID=@UserID ${form} if 1=2 begin set @ErrorCode='E' set @retmsg='在此写报错' goto GOTO_RETURN end insert into sNote (remark,createuserid,CreateUser,CreateStaff) select '在此写日志',@UserID,@UserName,@FullName */ COMMIT TRAN SET NOCOUNT ON RETURN END TRY BEGIN CATCH /*错误处理*/ ROLLBACK TRAN DECLARE @ErrorMessage NVARCHAR(4000); DECLARE @ErrorSeverity INT; DECLARE @ErrorState INT; /*把自定义的友好的错误信息提示加上*/ set @ErrorCode=cast(ERROR_NUMBER() as nvarchar(50)) SET @retmsg=ERROR_MESSAGE(); SELECT @ErrorMessage=ERROR_MESSAGE(), @ErrorSeverity=ERROR_SEVERITY(), @ErrorState=ERROR_STATE(); RAISERROR(@ErrorMessage, /*-- Message text.*/ @ErrorSeverity, /*-- Severity.*/ @ErrorState /*-- State.*/ ); END CATCH GOTO_RETURN: ROLLBACK TRAN END` Ltext = Ltext.replace(/\n\s{4}/ig, 'mchr13k') return Ltext } /** * @description 创建存储过程 * @return {String} */ static getfunc (param, btn, menu, config) { let form = '' let formParam = '' let _vars = ['bid', 'septmenuno', 'lang', 'debug', 'loginuid', 'sessionuid', 'userid', 'errorcode', 'retmsg'] let columns = config.columns let primaryKey = config.setting.primaryKey || 'ID' if (!_vars.includes(primaryKey.toLowerCase())) { _vars.push(primaryKey.toLowerCase()) let _type = '50' if (btn.Ot === 'requiredOnce') { // 多行拼接时,主键设为max _type = 'max' } formParam = `mchr13k@${primaryKey} nvarchar(${_type})='',` } if (param.fields && param.fields.length > 0) { let _fields = [] param.fields.forEach(item => { if (item.field) { let type = '' if (item.type.match(/date/ig)) { type = 'datetime=null' } else if (item.type === 'number') { type = `decimal(18,${item.decimal})=0` } else { type = 'nvarchar(50)=\'\'' } if (!_vars.includes(item.field.toLowerCase())) { _vars.push(item.field.toLowerCase()) formParam = formParam + `mchr13k@${item.field} ${type},` } _fields.push(item.field) } }) let field1 = _fields.join(',') let field2 = _fields.join(',@') let field3 = _fields.map(cell => { return cell + '=@' + cell }) field2 = field2 ? '@' + field2 : '' field3 = field3.join(',') form = ` insert into ${param.name} (${field1},createuserid) select ${field2},@UserID update ${param.name} set ${field3},modifydate=getdate(),modifyuserid=@UserID ` } else if (btn.OpenType === 'prompt' || btn.OpenType === 'exec') { form = ` update ${param.name} set ModifyDate=getdate(),ModifyUserID=@UserID where ${primaryKey}=@${primaryKey} ` } if (columns) { let _col = [] let _field = [] columns.forEach(col => { if (col.field) { if (col.type === 'number') { _col.push(col.field + ' decimal(18,2)') } else { _col.push(col.field + ' nvarchar(50)') } _field.push(col.field) } }) _col = _col.join(',') _field = _field.join(',') form = form + ` declare @dc table (${_col}) insert into @dc (${_field}) @tableid ='${menu.MenuID}' ` } // 打印自定义模板字段提示 let _printRemark = '' if (btn.funcType === 'print') { _printRemark = '/* 自定义数据打印模板时,请使用TemplateID字段 */' } let Ltext = `create proc ${param.funcName} ( /*${menu.MenuName} ${btn.label}*/ @appkey nvarchar(50)='', @BID nvarchar(50)='',${formParam} @sEPTMenuNo nvarchar(50)='${param.menuNo}', @lang nvarchar(50)='', @debug nvarchar(50)='', @LoginUID nvarchar(50)='', @SessionUid nvarchar(50)='', @UserID nvarchar(50), @ErrorCode nvarchar(50) out, @retmsg nvarchar(4000) out ) as begin declare @BegindateTest datetime,@EnddateTest datetime select @BegindateTest=getdate() set @ErrorCode='' set @retmsg='' BEGIN TRY /*事务操作*/ BEGIN TRAN /*具体业务操作*/ ${_printRemark} /* select top 10 * from sProcExcep order by id desc declare @UserName nvarchar(50),@FullName nvarchar(50) select @UserName=UserName,@FullName=FullName from SUsers where UID=@UserID ${form} if 1=2 begin set @ErrorCode='E' set @retmsg='在此写报错' goto GOTO_RETURN end insert into sNote (remark,createuserid,CreateUser,CreateStaff) select '在此写日志',@UserID,@UserName,@FullName */ COMMIT TRAN SET NOCOUNT ON RETURN END TRY BEGIN CATCH /*错误处理*/ ROLLBACK TRAN DECLARE @ErrorMessage NVARCHAR(4000); DECLARE @ErrorSeverity INT; DECLARE @ErrorState INT; /*把自定义的友好的错误信息提示加上*/ set @ErrorCode=cast(ERROR_NUMBER() as nvarchar(50)) SET @retmsg=ERROR_MESSAGE(); SELECT @ErrorMessage=ERROR_MESSAGE(), @ErrorSeverity=ERROR_SEVERITY(), @ErrorState=ERROR_STATE(); RAISERROR(@ErrorMessage, /*-- Message text.*/ @ErrorSeverity, /*-- Severity.*/ @ErrorState /*-- State.*/ ); END CATCH GOTO_RETURN: ROLLBACK TRAN END` Ltext = Ltext.replace(/\n\s{4}/ig, 'mchr13k') return Ltext } /** * @description 创建导入存储过程 * @return {String} */ static getexcelInfunc (param, btn, menu) { let _verify = btn.verify let _uniquesql = '' if (_verify.uniques && _verify.uniques.length > 0) { _verify.uniques.forEach(unique => { if (unique.status === 'false') return let _fields = unique.field.split(',') let _fields_ = _fields.map(_field => { return `a.${_field}=b.${_field}` }) _fields_ = _fields_.join(' and ') if (unique.verifyType !== 'physical') { _fields_ += ' and b.deleted=0' } _uniquesql += ` Set @tbid='' Select top 1 @tbid=${_fields.join('+\' \'+')} from (select 1 as n,${unique.field} from @${btn.sheet} ) a group by ${unique.field} having sum(n)>1 If @tbid!='' Begin select @ErrorCode='${unique.errorCode}',@retmsg=@tbid+' 重复' goto aaa end Set @tbid='' Select top 1 @tbid=${_fields.join('+\' \'+')} from @${btn.sheet} a Inner join ${btn.sheet} b on ${_fields_} If @tbid!='' Begin select @ErrorCode='${unique.errorCode}',@retmsg=@tbid+' 与已有数据重复' goto aaa end ` }) if (_uniquesql) { _uniquesql = ` Declare @tbid Nvarchar(512) ${_uniquesql}` } } let declarefields = [] let fields = [] _verify.columns.forEach(col => { declarefields.push(`${col.Column} ${col.type}`) fields.push(col.Column) }) fields = fields.join(',') let _sql = `declare @${btn.sheet} table (${declarefields.join(',')},jskey nvarchar(50)) Declare @UserName nvarchar(50),@FullName nvarchar(50) select @UserName=UserName,@FullName=FullName from SUsers where UID=@UserID Insert into @${btn.sheet} (${fields},jskey) exec s_KeyWords_Replace @LText=@LText, @BID=@BID,@LoginUID=@LoginUID,@SessionUid=@SessionUid,@UserID=@UserID,@ID=@ID ${_uniquesql} Insert into ${btn.sheet} (${fields},createuserid,createuser,createstaff,bid) Select ${fields},@userid,@username,@fullname,@BID From @${btn.sheet} Delete @${btn.sheet}` let Ltext = `create proc ${param.funcName} ( /*${menu.MenuName} ${btn.label}*/ @appkey nvarchar(50)='', @ID nvarchar(50)='', @BID nvarchar(50)='', @Ltext nvarchar(max)='', @sEPTMenuNo nvarchar(50)='${param.menuNo}', @secretkey nvarchar(50)='', @timestamp nvarchar(50)='', @lang nvarchar(50)='', @LoginUID nvarchar(50)='', @SessionUid nvarchar(50)='', @UserID nvarchar(50), @ErrorCode nvarchar(50) out, @retmsg nvarchar(4000) out ) as begin declare @BegindateTest datetime,@EnddateTest datetime select @BegindateTest=getdate() set @ErrorCode='' set @retmsg='' BEGIN TRY /*事务操作*/ BEGIN TRAN /*具体业务操作*/ /* ${_sql} */ COMMIT TRAN SET NOCOUNT ON RETURN END TRY BEGIN CATCH /*错误处理*/ ROLLBACK TRAN DECLARE @ErrorMessage NVARCHAR(4000); DECLARE @ErrorSeverity INT; DECLARE @ErrorState INT; /*把自定义的友好的错误信息提示加上*/ set @ErrorCode=cast(ERROR_NUMBER() as nvarchar(50)) SET @retmsg=ERROR_MESSAGE(); SELECT @ErrorMessage=ERROR_MESSAGE(), @ErrorSeverity=ERROR_SEVERITY(), @ErrorState=ERROR_STATE(); RAISERROR(@ErrorMessage, /*-- Message text.*/ @ErrorSeverity, /*-- Severity.*/ @ErrorState /*-- State.*/ ); END CATCH GOTO_RETURN: ROLLBACK TRAN END` Ltext = Ltext.replace(/\n\s{4}/ig, 'mchr13k') return Ltext } }