CodeGenConfig.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core.Service;
  7. /// <summary>
  8. /// 代码生成详细配置参数
  9. /// </summary>
  10. public class CodeGenConfig
  11. {
  12. /// <summary>
  13. /// 主键Id
  14. /// </summary>
  15. public long Id { get; set; }
  16. /// <summary>
  17. /// 代码生成主表ID
  18. /// </summary>
  19. public long CodeGenId { get; set; }
  20. /// <summary>
  21. /// 数据库字段名
  22. /// </summary>
  23. public string ColumnName { get; set; }
  24. /// <summary>
  25. /// 主外键
  26. /// </summary>
  27. public string ColumnKey { get; set; }
  28. /// <summary>
  29. /// 实体属性名
  30. /// </summary>
  31. public string PropertyName { get; set; }
  32. /// <summary>
  33. /// 字段数据长度
  34. /// </summary>
  35. public int ColumnLength { get; set; }
  36. /// <summary>
  37. /// 数据库字段名(首字母小写)
  38. /// </summary>
  39. public string LowerPropertyName => string.IsNullOrWhiteSpace(PropertyName) ? null : PropertyName[..1].ToLower() + PropertyName[1..];
  40. /// <summary>
  41. /// 字段描述
  42. /// </summary>
  43. public string ColumnComment { get; set; }
  44. /// <summary>
  45. /// .NET类型
  46. /// </summary>
  47. public string NetType { get; set; }
  48. /// <summary>
  49. /// 数据库中类型(物理类型)
  50. /// </summary>
  51. public string DataType { get; set; }
  52. /// <summary>
  53. /// 可空.NET类型
  54. /// </summary>
  55. public string NullableNetType => Regex.IsMatch(NetType ?? "", "(.*?Enum|bool|char|int|long|double|float|decimal)[?]?") ? NetType.TrimEnd('?') + "?" : NetType;
  56. /// <summary>
  57. /// 作用类型(字典)
  58. /// </summary>
  59. public string EffectType { get; set; }
  60. /// <summary>
  61. /// 外键库标识
  62. /// </summary>
  63. public string FkConfigId { get; set; }
  64. /// <summary>
  65. /// 外键实体名称
  66. /// </summary>
  67. public string FkEntityName { get; set; }
  68. /// <summary>
  69. /// 外键表名称
  70. /// </summary>
  71. public string FkTableName { get; set; }
  72. /// <summary>
  73. /// 外键实体名称(首字母小写)
  74. /// </summary>
  75. public string LowerFkEntityName => string.IsNullOrWhiteSpace(FkEntityName) ? null : FkEntityName[..1].ToLower() + FkEntityName[1..];
  76. /// <summary>
  77. /// 外键链接字段
  78. /// </summary>
  79. public string FkLinkColumnName { get; set; }
  80. /// <summary>
  81. /// 外键显示字段
  82. /// </summary>
  83. [Newtonsoft.Json.JsonIgnore]
  84. [System.Text.Json.Serialization.JsonIgnore]
  85. public string FkDisplayColumns { get; set; }
  86. /// <summary>
  87. /// 外键显示字段
  88. /// </summary>
  89. public List<string> FkDisplayColumnList { get; set; }
  90. /// <summary>
  91. /// 外键显示字段(首字母小写)
  92. /// </summary>
  93. public List<string> LowerFkDisplayColumnsList => FkDisplayColumnList?.Select(name => name[..1].ToLower() + name[1..]).ToList();
  94. /// <summary>
  95. /// 外键显示字段.NET类型
  96. /// </summary>
  97. public string FkColumnNetType { get; set; }
  98. /// <summary>
  99. /// 父级字段
  100. /// </summary>
  101. public string PidColumn { get; set; }
  102. /// <summary>
  103. /// 字典code
  104. /// </summary>
  105. public string DictTypeCode { get; set; }
  106. /// <summary>
  107. /// 查询方式
  108. /// </summary>
  109. public string QueryType { get; set; }
  110. /// <summary>
  111. /// 是否是查询条件
  112. /// </summary>
  113. public string WhetherQuery { get; set; }
  114. /// <summary>
  115. /// 列表是否缩进(字典)
  116. /// </summary>
  117. public string WhetherRetract { get; set; }
  118. /// <summary>
  119. /// 是否必填(字典)
  120. /// </summary>
  121. public string WhetherRequired { get; set; }
  122. /// <summary>
  123. /// 是否可排序(字典)
  124. /// </summary>
  125. public string WhetherSortable { get; set; }
  126. /// <summary>
  127. /// 列表显示
  128. /// </summary>
  129. public string WhetherTable { get; set; }
  130. /// <summary>
  131. /// 增改
  132. /// </summary>
  133. public string WhetherAddUpdate { get; set; }
  134. /// <summary>
  135. /// 导入
  136. /// </summary>
  137. public string WhetherImport { get; set; }
  138. /// <summary>
  139. /// 是否是通用字段
  140. /// </summary>
  141. public string WhetherCommon { get; set; }
  142. /// <summary>
  143. /// 排序
  144. /// </summary>
  145. public int OrderNo { get; set; }
  146. /// <summary>
  147. /// 获取外键显示值语句
  148. /// </summary>
  149. /// <param name="tableAlias">表别名</param>
  150. /// <param name="separator">多字段时的连接符</param>
  151. /// <returns></returns>
  152. public string GetDisplayColumn(string tableAlias, string separator = "-") => string.Join(separator, FkDisplayColumnList.Select(name => $"{{{tableAlias}.{name}}}"));
  153. }