| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189 |
- // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
- //
- // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
- //
- // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
- namespace Admin.NET.Core.Service;
- /// <summary>
- /// 代码生成详细配置参数
- /// </summary>
- public class CodeGenConfig
- {
- /// <summary>
- /// 主键Id
- /// </summary>
- public long Id { get; set; }
- /// <summary>
- /// 代码生成主表ID
- /// </summary>
- public long CodeGenId { get; set; }
- /// <summary>
- /// 数据库字段名
- /// </summary>
- public string ColumnName { get; set; }
-
- /// <summary>
- /// 主外键
- /// </summary>
- public string ColumnKey { get; set; }
- /// <summary>
- /// 实体属性名
- /// </summary>
- public string PropertyName { get; set; }
- /// <summary>
- /// 字段数据长度
- /// </summary>
- public int ColumnLength { get; set; }
- /// <summary>
- /// 数据库字段名(首字母小写)
- /// </summary>
- public string LowerPropertyName => string.IsNullOrWhiteSpace(PropertyName) ? null : PropertyName[..1].ToLower() + PropertyName[1..];
- /// <summary>
- /// 字段描述
- /// </summary>
- public string ColumnComment { get; set; }
- /// <summary>
- /// .NET类型
- /// </summary>
- public string NetType { get; set; }
-
- /// <summary>
- /// 数据库中类型(物理类型)
- /// </summary>
- public string DataType { get; set; }
-
- /// <summary>
- /// 可空.NET类型
- /// </summary>
- public string NullableNetType => Regex.IsMatch(NetType ?? "", "(.*?Enum|bool|char|int|long|double|float|decimal)[?]?") ? NetType.TrimEnd('?') + "?" : NetType;
- /// <summary>
- /// 作用类型(字典)
- /// </summary>
- public string EffectType { get; set; }
- /// <summary>
- /// 外键库标识
- /// </summary>
- public string FkConfigId { get; set; }
- /// <summary>
- /// 外键实体名称
- /// </summary>
- public string FkEntityName { get; set; }
- /// <summary>
- /// 外键表名称
- /// </summary>
- public string FkTableName { get; set; }
- /// <summary>
- /// 外键实体名称(首字母小写)
- /// </summary>
- public string LowerFkEntityName => string.IsNullOrWhiteSpace(FkEntityName) ? null : FkEntityName[..1].ToLower() + FkEntityName[1..];
- /// <summary>
- /// 外键链接字段
- /// </summary>
- public string FkLinkColumnName { get; set; }
-
- /// <summary>
- /// 外键显示字段
- /// </summary>
- [Newtonsoft.Json.JsonIgnore]
- [System.Text.Json.Serialization.JsonIgnore]
- public string FkDisplayColumns { get; set; }
-
- /// <summary>
- /// 外键显示字段
- /// </summary>
- public List<string> FkDisplayColumnList { get; set; }
- /// <summary>
- /// 外键显示字段(首字母小写)
- /// </summary>
- public List<string> LowerFkDisplayColumnsList => FkDisplayColumnList?.Select(name => name[..1].ToLower() + name[1..]).ToList();
- /// <summary>
- /// 外键显示字段.NET类型
- /// </summary>
- public string FkColumnNetType { get; set; }
-
- /// <summary>
- /// 父级字段
- /// </summary>
- public string PidColumn { get; set; }
-
- /// <summary>
- /// 字典code
- /// </summary>
- public string DictTypeCode { get; set; }
-
- /// <summary>
- /// 查询方式
- /// </summary>
- public string QueryType { get; set; }
- /// <summary>
- /// 是否是查询条件
- /// </summary>
- public string WhetherQuery { get; set; }
- /// <summary>
- /// 列表是否缩进(字典)
- /// </summary>
- public string WhetherRetract { get; set; }
- /// <summary>
- /// 是否必填(字典)
- /// </summary>
- public string WhetherRequired { get; set; }
- /// <summary>
- /// 是否可排序(字典)
- /// </summary>
- public string WhetherSortable { get; set; }
- /// <summary>
- /// 列表显示
- /// </summary>
- public string WhetherTable { get; set; }
- /// <summary>
- /// 增改
- /// </summary>
- public string WhetherAddUpdate { get; set; }
-
- /// <summary>
- /// 导入
- /// </summary>
- public string WhetherImport { get; set; }
- /// <summary>
- /// 是否是通用字段
- /// </summary>
- public string WhetherCommon { get; set; }
-
- /// <summary>
- /// 排序
- /// </summary>
- public int OrderNo { get; set; }
-
- /// <summary>
- /// 获取外键显示值语句
- /// </summary>
- /// <param name="tableAlias">表别名</param>
- /// <param name="separator">多字段时的连接符</param>
- /// <returns></returns>
- public string GetDisplayColumn(string tableAlias, string separator = "-") => string.Join(separator, FkDisplayColumnList.Select(name => $"{{{tableAlias}.{name}}}"));
- }
|