| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- namespace Admin.NET.Core.Service;
- /// <summary>
- /// 系统代码生成配置服务
- /// </summary>
- [ApiDescriptionSettings(Order = 149)]
- public class SysCodeGenConfigService : IDynamicApiController, ITransient
- {
- private readonly ISqlSugarClient _db;
- public SysCodeGenConfigService(ISqlSugarClient db)
- {
- _db = db;
- }
- /// <summary>
- /// 代码生成详细配置列表
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [HttpGet("/sysCodeGenConfig/list")]
- public async Task<List<CodeGenConfig>> List([FromQuery] CodeGenConfig input)
- {
- return await _db.Queryable<SysCodeGenConfig>()
- .Where(u => u.CodeGenId == input.CodeGenId && u.WhetherCommon != YesNoEnum.Y.ToString())
- .Select<CodeGenConfig>().ToListAsync();
- }
- /// <summary>
- /// 删除
- /// </summary>
- /// <param name="codeGenId"></param>
- /// <returns></returns>
- [NonAction]
- public async Task Delete(long codeGenId)
- {
- await _db.Deleteable<SysCodeGenConfig>().Where(u => u.CodeGenId == codeGenId).ExecuteCommandAsync();
- }
- /// <summary>
- /// 更新
- /// </summary>
- /// <param name="inputList"></param>
- /// <returns></returns>
- [HttpPost("/sysCodeGenConfig/update")]
- public async Task Update(List<CodeGenConfig> inputList)
- {
- if (inputList == null || inputList.Count < 1) return;
- await _db.Updateable(inputList.Adapt<List<SysCodeGenConfig>>()).ExecuteCommandAsync();
- }
- /// <summary>
- /// 详情
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- [HttpGet("/sysCodeGenConfig/detail")]
- public async Task<SysCodeGenConfig> Detail([FromQuery] CodeGenConfig input)
- {
- return await _db.Queryable<SysCodeGenConfig>().FirstAsync(u => u.Id == input.Id);
- }
- /// <summary>
- /// 批量增加
- /// </summary>
- /// <param name="tableColumnOuputList"></param>
- /// <param name="codeGenerate"></param>
- [NonAction]
- public void AddList(List<ColumnOuput> tableColumnOuputList, SysCodeGen codeGenerate)
- {
- if (tableColumnOuputList == null) return;
- var codeGenConfigs = new List<SysCodeGenConfig>();
- foreach (var tableColumn in tableColumnOuputList)
- {
- var codeGenConfig = new SysCodeGenConfig();
- var YesOrNo = YesNoEnum.Y.ToString();
- if (Convert.ToBoolean(tableColumn.ColumnKey))
- {
- YesOrNo = YesNoEnum.N.ToString();
- }
- if (CodeGenUtil.IsCommonColumn(tableColumn.ColumnName))
- {
- codeGenConfig.WhetherCommon = YesNoEnum.Y.ToString();
- YesOrNo = YesNoEnum.N.ToString();
- }
- else
- {
- codeGenConfig.WhetherCommon = YesNoEnum.N.ToString();
- }
- codeGenConfig.CodeGenId = codeGenerate.Id;
- codeGenConfig.ColumnName = tableColumn.ColumnName;
- codeGenConfig.ColumnComment = tableColumn.ColumnComment;
- codeGenConfig.NetType = CodeGenUtil.ConvertDataType(tableColumn.DataType);
- codeGenConfig.WhetherRetract = YesNoEnum.N.ToString();
- codeGenConfig.WhetherRequired = YesNoEnum.N.ToString();
- codeGenConfig.QueryWhether = YesOrNo;
- codeGenConfig.WhetherAddUpdate = YesOrNo;
- codeGenConfig.WhetherTable = YesOrNo;
- codeGenConfig.ColumnKey = tableColumn.ColumnKey;
- codeGenConfig.DataType = tableColumn.DataType;
- codeGenConfig.EffectType = CodeGenUtil.DataTypeToEff(codeGenConfig.NetType);
- codeGenConfig.QueryType = "=="; // QueryTypeEnum.eq.ToString();
- codeGenConfigs.Add(codeGenConfig);
- }
- // 多库代码生成---这里要切回主库
- var provider = _db.AsTenant().GetConnectionScope(SqlSugarConst.ConfigId);
- provider.Insertable(codeGenConfigs).ExecuteCommand();
- }
- }
|