CustomViewEngine.cs 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core.Service;
  7. public class CustomViewEngine : ViewEngineModel
  8. {
  9. private readonly ISqlSugarClient _db;
  10. public CustomViewEngine()
  11. {
  12. }
  13. public CustomViewEngine(ISqlSugarClient db)
  14. {
  15. _db = db;
  16. }
  17. /// <summary>
  18. /// 库定位器
  19. /// </summary>
  20. public string ConfigId { get; set; } = SqlSugarConst.MainConfigId;
  21. public string AuthorName { get; set; }
  22. public string BusName { get; set; }
  23. public string NameSpace { get; set; }
  24. public string ClassName { get; set; }
  25. public string ProjectLastName { get; set; }
  26. public string LowerClassName
  27. {
  28. get
  29. {
  30. return ClassName[..1].ToLower() + ClassName[1..]; // 首字母小写
  31. }
  32. }
  33. public bool IsJoinTable { get; set; }
  34. public bool IsUpload { get; set; }
  35. public string PrintType { get; set; }
  36. public string PrintName { get; set; }
  37. public List<CodeGenConfig> QueryWhetherList { get; set; }
  38. public List<CodeGenConfig> TableField { get; set; }
  39. private List<ColumnOuput> ColumnList { get; set; }
  40. public string GetColumnNetType(object tbName, object colName)
  41. {
  42. if (tbName == null || colName == null) return null;
  43. var config = App.GetOptions<DbConnectionOptions>().ConnectionConfigs.FirstOrDefault(u => u.ConfigId.ToString() == ConfigId);
  44. ColumnList = GetColumnListByTableName(tbName.ToString());
  45. var col = ColumnList.Where(c => (config.DbSettings.EnableUnderLine
  46. ? CodeGenUtil.CamelColumnName(c.ColumnName, Array.Empty<string>())
  47. : c.ColumnName) == colName.ToString()).FirstOrDefault();
  48. return col.NetType;
  49. }
  50. public List<ColumnOuput> GetColumnListByTableName(string tableName)
  51. {
  52. // 多库代码生成切换库
  53. var provider = _db.AsTenant().GetConnectionScope(ConfigId != SqlSugarConst.MainConfigId ? ConfigId : SqlSugarConst.MainConfigId);
  54. // 获取实体类型属性
  55. var entityType = provider.DbMaintenance.GetTableInfoList().FirstOrDefault(u => u.Name == tableName);
  56. // 因为ConfigId的表通常也会用到主库的表来做连接,所以这里如果在ConfigId中找不到实体也尝试一下在主库中查找
  57. if (ConfigId == SqlSugarConst.MainConfigId && entityType == null) return null;
  58. if (ConfigId != SqlSugarConst.MainConfigId)
  59. {
  60. provider = _db.AsTenant().GetConnectionScope(SqlSugarConst.MainConfigId);
  61. entityType = provider.DbMaintenance.GetTableInfoList().FirstOrDefault(u => u.Name == tableName);
  62. if (entityType == null) return null;
  63. }
  64. // 按原始类型的顺序获取所有实体类型属性(不包含导航属性,会返回null)
  65. return provider.DbMaintenance.GetColumnInfosByTableName(entityType.Name).Select(u => new ColumnOuput
  66. {
  67. ColumnName = u.DbColumnName,
  68. ColumnKey = u.IsPrimarykey.ToString(),
  69. DataType = u.DataType.ToString(),
  70. NetType = CodeGenUtil.ConvertDataType(u, provider.CurrentConnectionConfig.DbType),
  71. ColumnComment = u.ColumnDescription
  72. }).ToList();
  73. }
  74. }