数据类对大数据表生成清理数据方法

This commit is contained in:
大石头 2024-07-07 17:51:26 +08:00
parent f61e62072a
commit 3ae49f1000
51 changed files with 7742 additions and 77 deletions

View File

@ -20,6 +20,9 @@ public class EntityBuilder : ClassBuilder
/// <summary>使用缓存。默认true标记为大数据的表不使用缓存</summary> /// <summary>使用缓存。默认true标记为大数据的表不使用缓存</summary>
public Boolean UsingCache { get; set; } = true; public Boolean UsingCache { get; set; } = true;
/// <summary>数据规模字段。标识是否大数据表</summary>
public IDataColumn? ScaleColumn { get; set; }
/// <summary>所有表类型名。用于扩展属性</summary> /// <summary>所有表类型名。用于扩展属性</summary>
public IList<IDataTable> AllTables { get; set; } = []; public IList<IDataTable> AllTables { get; set; } = [];
@ -280,8 +283,12 @@ public class EntityBuilder : ClassBuilder
protected override void Prepare() protected override void Prepare()
{ {
// 标记为大数据的表不使用缓存 // 标记为大数据的表不使用缓存
var fi = Table.Columns.FirstOrDefault(e => e.DataScale.EqualIgnoreCase("time") || e.DataScale.StartsWithIgnoreCase("time:", "timeShard:")); var column = Table.Columns.FirstOrDefault(e => e.DataScale.EqualIgnoreCase("time") || e.DataScale.StartsWithIgnoreCase("time:", "timeShard:"));
if (fi != null) UsingCache = false; if (column != null)
{
UsingCache = false;
ScaleColumn = column;
}
// 增加常用命名空间 // 增加常用命名空间
AddNameSpace(); AddNameSpace();
@ -562,6 +569,12 @@ public class EntityBuilder : ClassBuilder
WriteLine(); WriteLine();
BuildExtendSearch(); BuildExtendSearch();
if (ScaleColumn != null)
{
WriteLine();
BuildDelete(ScaleColumn);
}
WriteLine(); WriteLine();
BuildFieldName(); BuildFieldName();
} }
@ -923,6 +936,47 @@ public class EntityBuilder : ClassBuilder
WriteLine("#endregion"); WriteLine("#endregion");
} }
/// <summary>按时间删除数据</summary>
protected virtual void BuildDelete(IDataColumn column)
{
WriteLine("#region 数据清理");
WriteLine("/// <summary>清理指定时间段内的数据</summary>");
WriteLine("/// <param name=\"start\">开始时间。未指定时清理小于指定时间的所有数据</param>");
WriteLine("/// <param name=\"end\">结束时间</param>");
WriteLine("/// <returns>清理行数</returns>");
WriteLine("public static Int32 DeleteWith(DateTime start, DateTime end)");
WriteLine("{");
{
// 分为时间、雪花Id、字符串三种
var type = column.DataType;
if (type == typeof(DateTime))
{
WriteLine("if (start == end) return Delete(_.{0} == start);", column.Name);
WriteLine();
WriteLine("return Delete(_.{0}.Between(start, end));", column.Name);
}
else if (type == typeof(Int64))
{
//WriteLine("var where = new WhereExpression()");
//WriteLine("if (start.Year > 2000) where &= _.{0} >= Meta.Factory.Snow.GetId(start)", column.Name);
//WriteLine("if (end.Year > 2000) where &= _.{0} < Meta.Factory.Snow.GetId(end)", column.Name);
WriteLine("return Delete(_.{0}.Between(start, end, Meta.Factory.Snow));", column.Name);
}
else if (type == typeof(String))
{
WriteLine("if (start == end) return Delete(_.{0} == start);", column.Name);
WriteLine();
WriteLine("var where = new WhereExpression();");
WriteLine("if (start.Year > 2000) where &= _.{0} >= start;", column.Name);
WriteLine("if (end.Year > 2000) where &= _.{0} < end;", column.Name);
WriteLine("return Delete(where);");
}
}
WriteLine("}");
WriteLine("#endregion");
}
#endregion #endregion
#region #region

View File

@ -0,0 +1,184 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class Area : Entity<Area>
{
#region
static Area()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(ParentID));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add<TimeModule>();
// 实体缓存
// var ec = Meta.Cache;
// ec.Expire = 60;
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 保留2位小数
//Longitude = Math.Round(Longitude, 2);
//Latitude = Math.Round(Latitude, 2);
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (!Dirtys[nameof(UpdateTime)]) UpdateTime = DateTime.Now;
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化Area[地区]数据……");
// var entity = new Area();
// entity.ID = 0;
// entity.Name = "abc";
// entity.FullName = "abc";
// entity.ParentID = 0;
// entity.Level = 0;
// entity.Kind = "abc";
// entity.English = "abc";
// entity.PinYin = "abc";
// entity.JianPin = "abc";
// entity.TelCode = "abc";
// entity.ZipCode = "abc";
// entity.Longitude = 0.0;
// entity.Latitude = 0.0;
// entity.GeoHash = "abc";
// entity.Enable = true;
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化Area[地区]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="name">名称</param>
/// <param name="parentId">父级</param>
/// <param name="pinYin">拼音</param>
/// <param name="jianPin">简拼</param>
/// <param name="geoHash">地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米</param>
/// <param name="start">更新时间开始</param>
/// <param name="end">更新时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<Area> Search(String name, Int32 parentId, String pinYin, String jianPin, String geoHash, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (!name.IsNullOrEmpty()) exp &= _.Name == name;
if (parentId >= 0) exp &= _.ParentID == parentId;
if (!pinYin.IsNullOrEmpty()) exp &= _.PinYin == pinYin;
if (!jianPin.IsNullOrEmpty()) exp &= _.JianPin == jianPin;
if (!geoHash.IsNullOrEmpty()) exp &= _.GeoHash == geoHash;
exp &= _.UpdateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Name.Contains(key) | _.FullName.Contains(key) | _.Kind.Contains(key) | _.English.Contains(key) | _.PinYin.Contains(key) | _.JianPin.Contains(key) | _.TelCode.Contains(key) | _.ZipCode.Contains(key) | _.GeoHash.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(Id) as Id,PinYin From Area Where CreateTime>'2020-01-24 00:00:00' Group By PinYin Order By Id Desc limit 20
static readonly FieldCache<Area> _PinYinCache = new FieldCache<Area>(nameof(PinYin))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取拼音列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetPinYinList() => _PinYinCache.FindAllName();
// Select Count(Id) as Id,JianPin From Area Where CreateTime>'2020-01-24 00:00:00' Group By JianPin Order By Id Desc limit 20
static readonly FieldCache<Area> _JianPinCache = new FieldCache<Area>(nameof(JianPin))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取简拼列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetJianPinList() => _JianPinCache.FindAllName();
// Select Count(Id) as Id,GeoHash From Area Where CreateTime>'2020-01-24 00:00:00' Group By GeoHash Order By Id Desc limit 20
static readonly FieldCache<Area> _GeoHashCache = new FieldCache<Area>(nameof(GeoHash))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取地址编码列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetGeoHashList() => _GeoHashCache.FindAllName();
#endregion
#region
public IArea ToModel()
{
var model = new Area();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,465 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>地区。行政区划数据最高支持四级地址9位数字</summary>
[Serializable]
[DataObject]
[Description("地区。行政区划数据最高支持四级地址9位数字")]
[BindIndex("IX_Area_ParentID", false, "ParentID")]
[BindIndex("IX_Area_Name", false, "Name")]
[BindIndex("IX_Area_PinYin", false, "PinYin")]
[BindIndex("IX_Area_JianPin", false, "JianPin")]
[BindIndex("IX_Area_GeoHash", false, "GeoHash")]
[BindIndex("IX_Area_UpdateTime_ID", false, "UpdateTime,ID")]
[BindTable("Area", Description = "地区。行政区划数据最高支持四级地址9位数字", ConnName = "Membership", DbType = DatabaseType.None)]
public partial class Area : IArea, IEntity<IArea>
{
#region
private Int32 _ID;
/// <summary>编码。行政区划编码</summary>
[DisplayName("编码")]
[Description("编码。行政区划编码")]
[DataObjectField(true, false, false, 0)]
[BindColumn("ID", "编码。行政区划编码", "")]
public Int32 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private String? _Name;
/// <summary>名称</summary>
[DisplayName("名称")]
[Description("名称")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Name", "名称", "", Master = true)]
public String? Name { get => _Name; set { if (OnPropertyChanging("Name", value)) { _Name = value; OnPropertyChanged("Name"); } } }
private String? _FullName;
/// <summary>全名</summary>
[DisplayName("全名")]
[Description("全名")]
[DataObjectField(false, false, true, 50)]
[BindColumn("FullName", "全名", "", Master = true)]
public String? FullName { get => _FullName; set { if (OnPropertyChanging("FullName", value)) { _FullName = value; OnPropertyChanged("FullName"); } } }
private Int32 _ParentID;
/// <summary>父级</summary>
[DisplayName("父级")]
[Description("父级")]
[DataObjectField(false, false, false, 0)]
[BindColumn("ParentID", "父级", "")]
public Int32 ParentID { get => _ParentID; set { if (OnPropertyChanging("ParentID", value)) { _ParentID = value; OnPropertyChanged("ParentID"); } } }
private Int32 _Level;
/// <summary>层级</summary>
[DisplayName("层级")]
[Description("层级")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Level", "层级", "")]
public Int32 Level { get => _Level; set { if (OnPropertyChanging("Level", value)) { _Level = value; OnPropertyChanged("Level"); } } }
private String? _Kind;
/// <summary>类型。省市县,自治州等</summary>
[DisplayName("类型")]
[Description("类型。省市县,自治州等")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Kind", "类型。省市县,自治州等", "")]
public String? Kind { get => _Kind; set { if (OnPropertyChanging("Kind", value)) { _Kind = value; OnPropertyChanged("Kind"); } } }
private String? _English;
/// <summary>英文名</summary>
[DisplayName("英文名")]
[Description("英文名")]
[DataObjectField(false, false, true, 50)]
[BindColumn("English", "英文名", "")]
public String? English { get => _English; set { if (OnPropertyChanging("English", value)) { _English = value; OnPropertyChanged("English"); } } }
private String? _PinYin;
/// <summary>拼音</summary>
[DisplayName("拼音")]
[Description("拼音")]
[DataObjectField(false, false, true, 50)]
[BindColumn("PinYin", "拼音", "")]
public String? PinYin { get => _PinYin; set { if (OnPropertyChanging("PinYin", value)) { _PinYin = value; OnPropertyChanged("PinYin"); } } }
private String? _JianPin;
/// <summary>简拼</summary>
[DisplayName("简拼")]
[Description("简拼")]
[DataObjectField(false, false, true, 50)]
[BindColumn("JianPin", "简拼", "")]
public String? JianPin { get => _JianPin; set { if (OnPropertyChanging("JianPin", value)) { _JianPin = value; OnPropertyChanged("JianPin"); } } }
private String? _TelCode;
/// <summary>区号。电话区号</summary>
[DisplayName("区号")]
[Description("区号。电话区号")]
[DataObjectField(false, false, true, 50)]
[BindColumn("TelCode", "区号。电话区号", "")]
public String? TelCode { get => _TelCode; set { if (OnPropertyChanging("TelCode", value)) { _TelCode = value; OnPropertyChanged("TelCode"); } } }
private String? _ZipCode;
/// <summary>邮编。邮政编码</summary>
[DisplayName("邮编")]
[Description("邮编。邮政编码")]
[DataObjectField(false, false, true, 50)]
[BindColumn("ZipCode", "邮编。邮政编码", "")]
public String? ZipCode { get => _ZipCode; set { if (OnPropertyChanging("ZipCode", value)) { _ZipCode = value; OnPropertyChanged("ZipCode"); } } }
private Double _Longitude;
/// <summary>经度</summary>
[DisplayName("经度")]
[Description("经度")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Longitude", "经度", "")]
public Double Longitude { get => _Longitude; set { if (OnPropertyChanging("Longitude", value)) { _Longitude = value; OnPropertyChanged("Longitude"); } } }
private Double _Latitude;
/// <summary>纬度</summary>
[DisplayName("纬度")]
[Description("纬度")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Latitude", "纬度", "")]
public Double Latitude { get => _Latitude; set { if (OnPropertyChanging("Latitude", value)) { _Latitude = value; OnPropertyChanged("Latitude"); } } }
private String? _GeoHash;
/// <summary>地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米</summary>
[DisplayName("地址编码")]
[Description("地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米")]
[DataObjectField(false, false, true, 50)]
[BindColumn("GeoHash", "地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米", "")]
public String? GeoHash { get => _GeoHash; set { if (OnPropertyChanging("GeoHash", value)) { _GeoHash = value; OnPropertyChanged("GeoHash"); } } }
private Boolean _Enable;
/// <summary>启用</summary>
[DisplayName("启用")]
[Description("启用")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Enable", "启用", "")]
public Boolean Enable { get => _Enable; set { if (OnPropertyChanging("Enable", value)) { _Enable = value; OnPropertyChanged("Enable"); } } }
private DateTime _CreateTime;
/// <summary>创建时间</summary>
[Category("扩展")]
[DisplayName("创建时间")]
[Description("创建时间")]
[DataObjectField(false, false, true, 0)]
[BindColumn("CreateTime", "创建时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private DateTime _UpdateTime;
/// <summary>更新时间</summary>
[Category("扩展")]
[DisplayName("更新时间")]
[Description("更新时间")]
[DataObjectField(false, false, true, 0)]
[BindColumn("UpdateTime", "更新时间", "")]
public DateTime UpdateTime { get => _UpdateTime; set { if (OnPropertyChanging("UpdateTime", value)) { _UpdateTime = value; OnPropertyChanged("UpdateTime"); } } }
private String? _Remark;
/// <summary>备注</summary>
[Category("扩展")]
[DisplayName("备注")]
[Description("备注")]
[DataObjectField(false, false, true, 500)]
[BindColumn("Remark", "备注", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IArea model)
{
ID = model.ID;
Name = model.Name;
FullName = model.FullName;
ParentID = model.ParentID;
Level = model.Level;
Kind = model.Kind;
English = model.English;
PinYin = model.PinYin;
JianPin = model.JianPin;
TelCode = model.TelCode;
ZipCode = model.ZipCode;
Longitude = model.Longitude;
Latitude = model.Latitude;
GeoHash = model.GeoHash;
Enable = model.Enable;
CreateTime = model.CreateTime;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"ID" => _ID,
"Name" => _Name,
"FullName" => _FullName,
"ParentID" => _ParentID,
"Level" => _Level,
"Kind" => _Kind,
"English" => _English,
"PinYin" => _PinYin,
"JianPin" => _JianPin,
"TelCode" => _TelCode,
"ZipCode" => _ZipCode,
"Longitude" => _Longitude,
"Latitude" => _Latitude,
"GeoHash" => _GeoHash,
"Enable" => _Enable,
"CreateTime" => _CreateTime,
"UpdateTime" => _UpdateTime,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "ID": _ID = value.ToInt(); break;
case "Name": _Name = Convert.ToString(value); break;
case "FullName": _FullName = Convert.ToString(value); break;
case "ParentID": _ParentID = value.ToInt(); break;
case "Level": _Level = value.ToInt(); break;
case "Kind": _Kind = Convert.ToString(value); break;
case "English": _English = Convert.ToString(value); break;
case "PinYin": _PinYin = Convert.ToString(value); break;
case "JianPin": _JianPin = Convert.ToString(value); break;
case "TelCode": _TelCode = Convert.ToString(value); break;
case "ZipCode": _ZipCode = Convert.ToString(value); break;
case "Longitude": _Longitude = value.ToDouble(); break;
case "Latitude": _Latitude = value.ToDouble(); break;
case "GeoHash": _GeoHash = Convert.ToString(value); break;
case "Enable": _Enable = value.ToBoolean(); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "UpdateTime": _UpdateTime = value.ToDateTime(); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
#endregion
#region
/// <summary>根据编码查找</summary>
/// <param name="id">编码</param>
/// <returns>实体对象</returns>
public static Area FindByID(Int32 id)
{
if (id < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.ID == id);
// 单对象缓存
return Meta.SingleCache[id];
//return Find(_.ID == id);
}
/// <summary>根据父级查找</summary>
/// <param name="parentId">父级</param>
/// <returns>实体列表</returns>
public static IList<Area> FindAllByParentID(Int32 parentId)
{
if (parentId < 0) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.ParentID == parentId);
return FindAll(_.ParentID == parentId);
}
/// <summary>根据名称查找</summary>
/// <param name="name">名称</param>
/// <returns>实体列表</returns>
public static IList<Area> FindAllByName(String name)
{
if (name.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.Name.EqualIgnoreCase(name));
return FindAll(_.Name == name);
}
/// <summary>根据拼音查找</summary>
/// <param name="pinYin">拼音</param>
/// <returns>实体列表</returns>
public static IList<Area> FindAllByPinYin(String pinYin)
{
if (pinYin.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.PinYin.EqualIgnoreCase(pinYin));
return FindAll(_.PinYin == pinYin);
}
/// <summary>根据简拼查找</summary>
/// <param name="jianPin">简拼</param>
/// <returns>实体列表</returns>
public static IList<Area> FindAllByJianPin(String jianPin)
{
if (jianPin.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.JianPin.EqualIgnoreCase(jianPin));
return FindAll(_.JianPin == jianPin);
}
/// <summary>根据地址编码查找</summary>
/// <param name="geoHash">地址编码</param>
/// <returns>实体列表</returns>
public static IList<Area> FindAllByGeoHash(String geoHash)
{
if (geoHash.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.GeoHash.EqualIgnoreCase(geoHash));
return FindAll(_.GeoHash == geoHash);
}
#endregion
#region
/// <summary>取得地区字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编码。行政区划编码</summary>
public static readonly Field ID = FindByName("ID");
/// <summary>名称</summary>
public static readonly Field Name = FindByName("Name");
/// <summary>全名</summary>
public static readonly Field FullName = FindByName("FullName");
/// <summary>父级</summary>
public static readonly Field ParentID = FindByName("ParentID");
/// <summary>层级</summary>
public static readonly Field Level = FindByName("Level");
/// <summary>类型。省市县,自治州等</summary>
public static readonly Field Kind = FindByName("Kind");
/// <summary>英文名</summary>
public static readonly Field English = FindByName("English");
/// <summary>拼音</summary>
public static readonly Field PinYin = FindByName("PinYin");
/// <summary>简拼</summary>
public static readonly Field JianPin = FindByName("JianPin");
/// <summary>区号。电话区号</summary>
public static readonly Field TelCode = FindByName("TelCode");
/// <summary>邮编。邮政编码</summary>
public static readonly Field ZipCode = FindByName("ZipCode");
/// <summary>经度</summary>
public static readonly Field Longitude = FindByName("Longitude");
/// <summary>纬度</summary>
public static readonly Field Latitude = FindByName("Latitude");
/// <summary>地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米</summary>
public static readonly Field GeoHash = FindByName("GeoHash");
/// <summary>启用</summary>
public static readonly Field Enable = FindByName("Enable");
/// <summary>创建时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>更新时间</summary>
public static readonly Field UpdateTime = FindByName("UpdateTime");
/// <summary>备注</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得地区字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编码。行政区划编码</summary>
public const String ID = "ID";
/// <summary>名称</summary>
public const String Name = "Name";
/// <summary>全名</summary>
public const String FullName = "FullName";
/// <summary>父级</summary>
public const String ParentID = "ParentID";
/// <summary>层级</summary>
public const String Level = "Level";
/// <summary>类型。省市县,自治州等</summary>
public const String Kind = "Kind";
/// <summary>英文名</summary>
public const String English = "English";
/// <summary>拼音</summary>
public const String PinYin = "PinYin";
/// <summary>简拼</summary>
public const String JianPin = "JianPin";
/// <summary>区号。电话区号</summary>
public const String TelCode = "TelCode";
/// <summary>邮编。邮政编码</summary>
public const String ZipCode = "ZipCode";
/// <summary>经度</summary>
public const String Longitude = "Longitude";
/// <summary>纬度</summary>
public const String Latitude = "Latitude";
/// <summary>地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米</summary>
public const String GeoHash = "GeoHash";
/// <summary>启用</summary>
public const String Enable = "Enable";
/// <summary>创建时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>更新时间</summary>
public const String UpdateTime = "UpdateTime";
/// <summary>备注</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -0,0 +1,172 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class Parameter : Entity<Parameter>
{
#region
static Parameter()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(UserID));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
// 实体缓存
// var ec = Meta.Cache;
// ec.Expire = 60;
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 保留2位小数
//Ex3 = Math.Round(Ex3, 2);
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserID)]) CreateUserID = user.ID;
if (!Dirtys[nameof(UpdateUserID)]) UpdateUserID = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (!Dirtys[nameof(UpdateTime)]) UpdateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
//if (!Dirtys[nameof(UpdateIP)]) UpdateIP = ManageProvider.UserHost;
// 检查唯一索引
// CheckExist(method == DataMethod.Insert, nameof(UserID), nameof(Category), nameof(Name));
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化Parameter[字典参数]数据……");
// var entity = new Parameter();
// entity.UserID = 0;
// entity.Category = "abc";
// entity.Name = "abc";
// entity.Value = "abc";
// entity.LongValue = "abc";
// entity.Kind = 0;
// entity.Enable = true;
// entity.Ex1 = 0;
// entity.Ex2 = 0.0;
// entity.Ex3 = 0.0;
// entity.Ex4 = "abc";
// entity.Ex5 = "abc";
// entity.Ex6 = "abc";
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化Parameter[字典参数]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="userId">用户。按用户区分参数用户0表示系统级</param>
/// <param name="category">类别</param>
/// <param name="name">名称</param>
/// <param name="start">更新时间开始</param>
/// <param name="end">更新时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<Parameter> Search(Int32 userId, String category, String name, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (userId >= 0) exp &= _.UserID == userId;
if (!category.IsNullOrEmpty()) exp &= _.Category == category;
if (!name.IsNullOrEmpty()) exp &= _.Name == name;
exp &= _.UpdateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Category.Contains(key) | _.Name.Contains(key) | _.Value.Contains(key) | _.LongValue.Contains(key) | _.Ex4.Contains(key) | _.Ex5.Contains(key) | _.Ex6.Contains(key) | _.CreateUser.Contains(key) | _.CreateIP.Contains(key) | _.UpdateUser.Contains(key) | _.UpdateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(ID) as ID,Category From Parameter Where CreateTime>'2020-01-24 00:00:00' Group By Category Order By ID Desc limit 20
static readonly FieldCache<Parameter> _CategoryCache = new FieldCache<Parameter>(nameof(Category))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取类别列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetCategoryList() => _CategoryCache.FindAllName();
#endregion
#region
public IParameter ToModel()
{
var model = new Parameter();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,534 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>字典参数</summary>
[Serializable]
[DataObject]
[Description("字典参数")]
[BindIndex("IU_Parameter_UserID_Category_Name", true, "UserID,Category,Name")]
[BindIndex("IX_Parameter_Category_Name", false, "Category,Name")]
[BindIndex("IX_Parameter_UpdateTime", false, "UpdateTime")]
[BindTable("Parameter", Description = "字典参数", ConnName = "Membership", DbType = DatabaseType.None)]
public partial class Parameter : IParameter, IEntity<IParameter>
{
#region
private Int32 _ID;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("ID", "编号", "")]
public Int32 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private Int32 _UserID;
/// <summary>用户。按用户区分参数用户0表示系统级</summary>
[DisplayName("用户")]
[Description("用户。按用户区分参数用户0表示系统级")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UserID", "用户。按用户区分参数用户0表示系统级", "")]
public Int32 UserID { get => _UserID; set { if (OnPropertyChanging("UserID", value)) { _UserID = value; OnPropertyChanged("UserID"); } } }
private String? _Category;
/// <summary>类别</summary>
[DisplayName("类别")]
[Description("类别")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Category", "类别", "")]
public String? Category { get => _Category; set { if (OnPropertyChanging("Category", value)) { _Category = value; OnPropertyChanged("Category"); } } }
private String? _Name;
/// <summary>名称</summary>
[DisplayName("名称")]
[Description("名称")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Name", "名称", "", Master = true)]
public String? Name { get => _Name; set { if (OnPropertyChanging("Name", value)) { _Name = value; OnPropertyChanged("Name"); } } }
private String? _Value;
/// <summary>数值</summary>
[DisplayName("数值")]
[Description("数值")]
[DataObjectField(false, false, true, 200)]
[BindColumn("Value", "数值", "")]
public String? Value { get => _Value; set { if (OnPropertyChanging("Value", value)) { _Value = value; OnPropertyChanged("Value"); } } }
private String? _LongValue;
/// <summary>长数值</summary>
[DisplayName("长数值")]
[Description("长数值")]
[DataObjectField(false, false, true, 2000)]
[BindColumn("LongValue", "长数值", "")]
public String? LongValue { get => _LongValue; set { if (OnPropertyChanging("LongValue", value)) { _LongValue = value; OnPropertyChanged("LongValue"); } } }
private XCode.Membership.ParameterKinds _Kind;
/// <summary>种类。0普通21列表22名值</summary>
[DisplayName("种类")]
[Description("种类。0普通21列表22名值")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Kind", "种类。0普通21列表22名值", "")]
public XCode.Membership.ParameterKinds Kind { get => _Kind; set { if (OnPropertyChanging("Kind", value)) { _Kind = value; OnPropertyChanged("Kind"); } } }
private Boolean _Enable;
/// <summary>启用</summary>
[DisplayName("启用")]
[Description("启用")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Enable", "启用", "")]
public Boolean Enable { get => _Enable; set { if (OnPropertyChanging("Enable", value)) { _Enable = value; OnPropertyChanged("Enable"); } } }
private Int32 _Ex1;
/// <summary>扩展1</summary>
[Category("扩展")]
[DisplayName("扩展1")]
[Description("扩展1")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex1", "扩展1", "")]
public Int32 Ex1 { get => _Ex1; set { if (OnPropertyChanging("Ex1", value)) { _Ex1 = value; OnPropertyChanged("Ex1"); } } }
private Decimal _Ex2;
/// <summary>扩展2</summary>
[Category("扩展")]
[DisplayName("扩展2")]
[Description("扩展2")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex2", "扩展2", "", Precision = 19, Scale = 4)]
public Decimal Ex2 { get => _Ex2; set { if (OnPropertyChanging("Ex2", value)) { _Ex2 = value; OnPropertyChanged("Ex2"); } } }
private Double _Ex3;
/// <summary>扩展3</summary>
[Category("扩展")]
[DisplayName("扩展3")]
[Description("扩展3")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex3", "扩展3", "")]
public Double Ex3 { get => _Ex3; set { if (OnPropertyChanging("Ex3", value)) { _Ex3 = value; OnPropertyChanged("Ex3"); } } }
private String? _Ex4;
/// <summary>扩展4</summary>
[Category("扩展")]
[DisplayName("扩展4")]
[Description("扩展4")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex4", "扩展4", "")]
public String? Ex4 { get => _Ex4; set { if (OnPropertyChanging("Ex4", value)) { _Ex4 = value; OnPropertyChanged("Ex4"); } } }
private String? _Ex5;
/// <summary>扩展5</summary>
[Category("扩展")]
[DisplayName("扩展5")]
[Description("扩展5")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex5", "扩展5", "")]
public String? Ex5 { get => _Ex5; set { if (OnPropertyChanging("Ex5", value)) { _Ex5 = value; OnPropertyChanged("Ex5"); } } }
private String? _Ex6;
/// <summary>扩展6</summary>
[Category("扩展")]
[DisplayName("扩展6")]
[Description("扩展6")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex6", "扩展6", "")]
public String? Ex6 { get => _Ex6; set { if (OnPropertyChanging("Ex6", value)) { _Ex6 = value; OnPropertyChanged("Ex6"); } } }
private String? _CreateUser;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateUser", "创建者", "")]
public String? CreateUser { get => _CreateUser; set { if (OnPropertyChanging("CreateUser", value)) { _CreateUser = value; OnPropertyChanged("CreateUser"); } } }
private Int32 _CreateUserID;
/// <summary>创建用户</summary>
[Category("扩展")]
[DisplayName("创建用户")]
[Description("创建用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserID", "创建用户", "")]
public Int32 CreateUserID { get => _CreateUserID; set { if (OnPropertyChanging("CreateUserID", value)) { _CreateUserID = value; OnPropertyChanged("CreateUserID"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private DateTime _CreateTime;
/// <summary>创建时间</summary>
[Category("扩展")]
[DisplayName("创建时间")]
[Description("创建时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateTime", "创建时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _UpdateUser;
/// <summary>更新者</summary>
[Category("扩展")]
[DisplayName("更新者")]
[Description("更新者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateUser", "更新者", "")]
public String? UpdateUser { get => _UpdateUser; set { if (OnPropertyChanging("UpdateUser", value)) { _UpdateUser = value; OnPropertyChanged("UpdateUser"); } } }
private Int32 _UpdateUserID;
/// <summary>更新用户</summary>
[Category("扩展")]
[DisplayName("更新用户")]
[Description("更新用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateUserID", "更新用户", "")]
public Int32 UpdateUserID { get => _UpdateUserID; set { if (OnPropertyChanging("UpdateUserID", value)) { _UpdateUserID = value; OnPropertyChanged("UpdateUserID"); } } }
private String? _UpdateIP;
/// <summary>更新地址</summary>
[Category("扩展")]
[DisplayName("更新地址")]
[Description("更新地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateIP", "更新地址", "")]
public String? UpdateIP { get => _UpdateIP; set { if (OnPropertyChanging("UpdateIP", value)) { _UpdateIP = value; OnPropertyChanged("UpdateIP"); } } }
private DateTime _UpdateTime;
/// <summary>更新时间</summary>
[Category("扩展")]
[DisplayName("更新时间")]
[Description("更新时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateTime", "更新时间", "")]
public DateTime UpdateTime { get => _UpdateTime; set { if (OnPropertyChanging("UpdateTime", value)) { _UpdateTime = value; OnPropertyChanged("UpdateTime"); } } }
private String? _Remark;
/// <summary>备注</summary>
[Category("扩展")]
[DisplayName("备注")]
[Description("备注")]
[DataObjectField(false, false, true, 500)]
[BindColumn("Remark", "备注", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IParameter model)
{
ID = model.ID;
UserID = model.UserID;
Category = model.Category;
Name = model.Name;
Value = model.Value;
LongValue = model.LongValue;
Kind = model.Kind;
Enable = model.Enable;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"ID" => _ID,
"UserID" => _UserID,
"Category" => _Category,
"Name" => _Name,
"Value" => _Value,
"LongValue" => _LongValue,
"Kind" => _Kind,
"Enable" => _Enable,
"Ex1" => _Ex1,
"Ex2" => _Ex2,
"Ex3" => _Ex3,
"Ex4" => _Ex4,
"Ex5" => _Ex5,
"Ex6" => _Ex6,
"CreateUser" => _CreateUser,
"CreateUserID" => _CreateUserID,
"CreateIP" => _CreateIP,
"CreateTime" => _CreateTime,
"UpdateUser" => _UpdateUser,
"UpdateUserID" => _UpdateUserID,
"UpdateIP" => _UpdateIP,
"UpdateTime" => _UpdateTime,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "ID": _ID = value.ToInt(); break;
case "UserID": _UserID = value.ToInt(); break;
case "Category": _Category = Convert.ToString(value); break;
case "Name": _Name = Convert.ToString(value); break;
case "Value": _Value = Convert.ToString(value); break;
case "LongValue": _LongValue = Convert.ToString(value); break;
case "Kind": _Kind = (XCode.Membership.ParameterKinds)value.ToInt(); break;
case "Enable": _Enable = value.ToBoolean(); break;
case "Ex1": _Ex1 = value.ToInt(); break;
case "Ex2": _Ex2 = Convert.ToDecimal(value); break;
case "Ex3": _Ex3 = value.ToDouble(); break;
case "Ex4": _Ex4 = Convert.ToString(value); break;
case "Ex5": _Ex5 = Convert.ToString(value); break;
case "Ex6": _Ex6 = Convert.ToString(value); break;
case "CreateUser": _CreateUser = Convert.ToString(value); break;
case "CreateUserID": _CreateUserID = value.ToInt(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "UpdateUser": _UpdateUser = Convert.ToString(value); break;
case "UpdateUserID": _UpdateUserID = value.ToInt(); break;
case "UpdateIP": _UpdateIP = Convert.ToString(value); break;
case "UpdateTime": _UpdateTime = value.ToDateTime(); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
/// <summary>用户</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public User? User => Extends.Get(nameof(User), k => User.FindByID(UserID));
/// <summary>用户</summary>
[Map(nameof(UserID), typeof(User), "ID")]
public String? UserName => User?.ToString();
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static Parameter FindByID(Int32 id)
{
if (id < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.ID == id);
// 单对象缓存
return Meta.SingleCache[id];
//return Find(_.ID == id);
}
/// <summary>根据用户、类别、名称查找</summary>
/// <param name="userId">用户</param>
/// <param name="category">类别</param>
/// <param name="name">名称</param>
/// <returns>实体对象</returns>
public static Parameter FindByUserIDAndCategoryAndName(Int32 userId, String category, String name)
{
if (userId < 0) return null;
if (category.IsNullOrEmpty()) return null;
if (name.IsNullOrEmpty()) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.UserID == userId && e.Category.EqualIgnoreCase(category) && e.Name.EqualIgnoreCase(name));
return Find(_.UserID == userId & _.Category == category & _.Name == name);
}
/// <summary>根据类别、名称查找</summary>
/// <param name="category">类别</param>
/// <param name="name">名称</param>
/// <returns>实体列表</returns>
public static IList<Parameter> FindAllByCategoryAndName(String category, String name)
{
if (category.IsNullOrEmpty()) return [];
if (name.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.Category.EqualIgnoreCase(category) && e.Name.EqualIgnoreCase(name));
return FindAll(_.Category == category & _.Name == name);
}
#endregion
#region
/// <summary>取得字典参数字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field ID = FindByName("ID");
/// <summary>用户。按用户区分参数用户0表示系统级</summary>
public static readonly Field UserID = FindByName("UserID");
/// <summary>类别</summary>
public static readonly Field Category = FindByName("Category");
/// <summary>名称</summary>
public static readonly Field Name = FindByName("Name");
/// <summary>数值</summary>
public static readonly Field Value = FindByName("Value");
/// <summary>长数值</summary>
public static readonly Field LongValue = FindByName("LongValue");
/// <summary>种类。0普通21列表22名值</summary>
public static readonly Field Kind = FindByName("Kind");
/// <summary>启用</summary>
public static readonly Field Enable = FindByName("Enable");
/// <summary>扩展1</summary>
public static readonly Field Ex1 = FindByName("Ex1");
/// <summary>扩展2</summary>
public static readonly Field Ex2 = FindByName("Ex2");
/// <summary>扩展3</summary>
public static readonly Field Ex3 = FindByName("Ex3");
/// <summary>扩展4</summary>
public static readonly Field Ex4 = FindByName("Ex4");
/// <summary>扩展5</summary>
public static readonly Field Ex5 = FindByName("Ex5");
/// <summary>扩展6</summary>
public static readonly Field Ex6 = FindByName("Ex6");
/// <summary>创建者</summary>
public static readonly Field CreateUser = FindByName("CreateUser");
/// <summary>创建用户</summary>
public static readonly Field CreateUserID = FindByName("CreateUserID");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>创建时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>更新者</summary>
public static readonly Field UpdateUser = FindByName("UpdateUser");
/// <summary>更新用户</summary>
public static readonly Field UpdateUserID = FindByName("UpdateUserID");
/// <summary>更新地址</summary>
public static readonly Field UpdateIP = FindByName("UpdateIP");
/// <summary>更新时间</summary>
public static readonly Field UpdateTime = FindByName("UpdateTime");
/// <summary>备注</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得字典参数字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String ID = "ID";
/// <summary>用户。按用户区分参数用户0表示系统级</summary>
public const String UserID = "UserID";
/// <summary>类别</summary>
public const String Category = "Category";
/// <summary>名称</summary>
public const String Name = "Name";
/// <summary>数值</summary>
public const String Value = "Value";
/// <summary>长数值</summary>
public const String LongValue = "LongValue";
/// <summary>种类。0普通21列表22名值</summary>
public const String Kind = "Kind";
/// <summary>启用</summary>
public const String Enable = "Enable";
/// <summary>扩展1</summary>
public const String Ex1 = "Ex1";
/// <summary>扩展2</summary>
public const String Ex2 = "Ex2";
/// <summary>扩展3</summary>
public const String Ex3 = "Ex3";
/// <summary>扩展4</summary>
public const String Ex4 = "Ex4";
/// <summary>扩展5</summary>
public const String Ex5 = "Ex5";
/// <summary>扩展6</summary>
public const String Ex6 = "Ex6";
/// <summary>创建者</summary>
public const String CreateUser = "CreateUser";
/// <summary>创建用户</summary>
public const String CreateUserID = "CreateUserID";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>创建时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>更新者</summary>
public const String UpdateUser = "UpdateUser";
/// <summary>更新用户</summary>
public const String UpdateUserID = "UpdateUserID";
/// <summary>更新地址</summary>
public const String UpdateIP = "UpdateIP";
/// <summary>更新时间</summary>
public const String UpdateTime = "UpdateTime";
/// <summary>备注</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -0,0 +1,174 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class MemberLog : Entity<MemberLog>
{
#region
static MemberLog()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(LinkID));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
Meta.Modules.Add<TraceModule>();
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 保留2位小数
//Ex3 = Math.Round(Ex3, 2);
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserID)]) CreateUserID = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化MemberLog[成员日志]数据……");
// var entity = new MemberLog();
// entity.Ds = "abc";
// entity.Category = "abc";
// entity.Action = "abc";
// entity.LinkID = 0;
// entity.Success = true;
// entity.UserName = "abc";
// entity.Ex1 = 0;
// entity.Ex2 = 0;
// entity.Ex3 = 0.0;
// entity.Ex4 = "abc";
// entity.Ex5 = "abc";
// entity.Ex6 = "abc";
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化MemberLog[成员日志]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="category">类别</param>
/// <param name="action">操作</param>
/// <param name="linkId">链接</param>
/// <param name="createUserId">创建用户</param>
/// <param name="start">时间开始</param>
/// <param name="end">时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<MemberLog> Search(String category, String action, Int32 linkId, Int32 createUserId, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (!category.IsNullOrEmpty()) exp &= _.Category == category;
if (!action.IsNullOrEmpty()) exp &= _.Action == action;
if (linkId >= 0) exp &= _.LinkID == linkId;
if (createUserId >= 0) exp &= _.CreateUserID == createUserId;
exp &= _.CreateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Ds.Contains(key) | _.Category.Contains(key) | _.Action.Contains(key) | _.UserName.Contains(key) | _.Ex4.Contains(key) | _.Ex5.Contains(key) | _.Ex6.Contains(key) | _.TraceId.Contains(key) | _.CreateUser.Contains(key) | _.CreateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(ID) as ID,Action From MemberLog Where CreateTime>'2020-01-24 00:00:00' Group By Action Order By ID Desc limit 20
static readonly FieldCache<MemberLog> _ActionCache = new FieldCache<MemberLog>(nameof(Action))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取操作列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetActionList() => _ActionCache.FindAllName();
// Select Count(ID) as ID,Category From MemberLog Where CreateTime>'2020-01-24 00:00:00' Group By Category Order By ID Desc limit 20
static readonly FieldCache<MemberLog> _CategoryCache = new FieldCache<MemberLog>(nameof(Category))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取类别列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetCategoryList() => _CategoryCache.FindAllName();
#endregion
#region
public IMemberLog ToModel()
{
var model = new MemberLog();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,473 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>成员日志</summary>
[Serializable]
[DataObject]
[Description("成员日志")]
[BindIndex("IX_MemberLog_Action_Category_ID", false, "Action,Category,ID")]
[BindIndex("IX_MemberLog_Category_LinkID_ID", false, "Category,LinkID,ID")]
[BindIndex("IX_MemberLog_CreateUserID_ID", false, "CreateUserID,ID")]
[BindTable("MemberLog", Description = "成员日志", ConnName = "Log", DbType = DatabaseType.None)]
public partial class MemberLog : IMemberLog, IEntity<IMemberLog>
{
#region
private Int64 _ID;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("ID", "编号", "")]
public Int64 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private String? _Ds;
/// <summary>数据分区</summary>
[DisplayName("数据分区")]
[Description("数据分区")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ds", "数据分区", "", DataScale = "time")]
public String? Ds { get => _Ds; set { if (OnPropertyChanging("Ds", value)) { _Ds = value; OnPropertyChanged("Ds"); } } }
private String? _Category;
/// <summary>类别</summary>
[DisplayName("类别")]
[Description("类别")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Category", "类别", "")]
public String? Category { get => _Category; set { if (OnPropertyChanging("Category", value)) { _Category = value; OnPropertyChanged("Category"); } } }
private String? _Action;
/// <summary>操作</summary>
[DisplayName("操作")]
[Description("操作")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Action", "操作", "")]
public String? Action { get => _Action; set { if (OnPropertyChanging("Action", value)) { _Action = value; OnPropertyChanged("Action"); } } }
private Int32 _LinkID;
/// <summary>链接</summary>
[DisplayName("链接")]
[Description("链接")]
[DataObjectField(false, false, false, 0)]
[BindColumn("LinkID", "链接", "")]
public Int32 LinkID { get => _LinkID; set { if (OnPropertyChanging("LinkID", value)) { _LinkID = value; OnPropertyChanged("LinkID"); } } }
private Boolean _Success;
/// <summary>成功</summary>
[DisplayName("成功")]
[Description("成功")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Success", "成功", "")]
public Boolean Success { get => _Success; set { if (OnPropertyChanging("Success", value)) { _Success = value; OnPropertyChanged("Success"); } } }
private String? _UserName;
/// <summary>用户名</summary>
[DisplayName("用户名")]
[Description("用户名")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UserName", "用户名", "")]
public String? UserName { get => _UserName; set { if (OnPropertyChanging("UserName", value)) { _UserName = value; OnPropertyChanged("UserName"); } } }
private Int32 _Ex1;
/// <summary>扩展1</summary>
[Category("扩展")]
[DisplayName("扩展1")]
[Description("扩展1")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex1", "扩展1", "")]
public Int32 Ex1 { get => _Ex1; set { if (OnPropertyChanging("Ex1", value)) { _Ex1 = value; OnPropertyChanged("Ex1"); } } }
private Int32 _Ex2;
/// <summary>扩展2</summary>
[Category("扩展")]
[DisplayName("扩展2")]
[Description("扩展2")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex2", "扩展2", "")]
public Int32 Ex2 { get => _Ex2; set { if (OnPropertyChanging("Ex2", value)) { _Ex2 = value; OnPropertyChanged("Ex2"); } } }
private Double _Ex3;
/// <summary>扩展3</summary>
[Category("扩展")]
[DisplayName("扩展3")]
[Description("扩展3")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex3", "扩展3", "")]
public Double Ex3 { get => _Ex3; set { if (OnPropertyChanging("Ex3", value)) { _Ex3 = value; OnPropertyChanged("Ex3"); } } }
private String? _Ex4;
/// <summary>扩展4</summary>
[Category("扩展")]
[DisplayName("扩展4")]
[Description("扩展4")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex4", "扩展4", "")]
public String? Ex4 { get => _Ex4; set { if (OnPropertyChanging("Ex4", value)) { _Ex4 = value; OnPropertyChanged("Ex4"); } } }
private String? _Ex5;
/// <summary>扩展5</summary>
[Category("扩展")]
[DisplayName("扩展5")]
[Description("扩展5")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex5", "扩展5", "")]
public String? Ex5 { get => _Ex5; set { if (OnPropertyChanging("Ex5", value)) { _Ex5 = value; OnPropertyChanged("Ex5"); } } }
private String? _Ex6;
/// <summary>扩展6</summary>
[Category("扩展")]
[DisplayName("扩展6")]
[Description("扩展6")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex6", "扩展6", "")]
public String? Ex6 { get => _Ex6; set { if (OnPropertyChanging("Ex6", value)) { _Ex6 = value; OnPropertyChanged("Ex6"); } } }
private String? _TraceId;
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
[DisplayName("性能追踪")]
[Description("性能追踪。用于APM性能追踪定位还原该事件的调用链")]
[DataObjectField(false, false, true, 50)]
[BindColumn("TraceId", "性能追踪。用于APM性能追踪定位还原该事件的调用链", "")]
public String? TraceId { get => _TraceId; set { if (OnPropertyChanging("TraceId", value)) { _TraceId = value; OnPropertyChanged("TraceId"); } } }
private String? _CreateUser;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateUser", "创建者", "")]
public String? CreateUser { get => _CreateUser; set { if (OnPropertyChanging("CreateUser", value)) { _CreateUser = value; OnPropertyChanged("CreateUser"); } } }
private Int32 _CreateUserID;
/// <summary>创建用户</summary>
[Category("扩展")]
[DisplayName("创建用户")]
[Description("创建用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserID", "创建用户", "")]
public Int32 CreateUserID { get => _CreateUserID; set { if (OnPropertyChanging("CreateUserID", value)) { _CreateUserID = value; OnPropertyChanged("CreateUserID"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private DateTime _CreateTime;
/// <summary>时间</summary>
[DisplayName("时间")]
[Description("时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateTime", "时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _Remark;
/// <summary>详细信息</summary>
[DisplayName("详细信息")]
[Description("详细信息")]
[DataObjectField(false, false, true, 2000)]
[BindColumn("Remark", "详细信息", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IMemberLog model)
{
ID = model.ID;
Ds = model.Ds;
Category = model.Category;
Action = model.Action;
LinkID = model.LinkID;
Success = model.Success;
UserName = model.UserName;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
TraceId = model.TraceId;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"ID" => _ID,
"Ds" => _Ds,
"Category" => _Category,
"Action" => _Action,
"LinkID" => _LinkID,
"Success" => _Success,
"UserName" => _UserName,
"Ex1" => _Ex1,
"Ex2" => _Ex2,
"Ex3" => _Ex3,
"Ex4" => _Ex4,
"Ex5" => _Ex5,
"Ex6" => _Ex6,
"TraceId" => _TraceId,
"CreateUser" => _CreateUser,
"CreateUserID" => _CreateUserID,
"CreateIP" => _CreateIP,
"CreateTime" => _CreateTime,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "ID": _ID = value.ToLong(); break;
case "Ds": _Ds = Convert.ToString(value); break;
case "Category": _Category = Convert.ToString(value); break;
case "Action": _Action = Convert.ToString(value); break;
case "LinkID": _LinkID = value.ToInt(); break;
case "Success": _Success = value.ToBoolean(); break;
case "UserName": _UserName = Convert.ToString(value); break;
case "Ex1": _Ex1 = value.ToInt(); break;
case "Ex2": _Ex2 = value.ToInt(); break;
case "Ex3": _Ex3 = value.ToDouble(); break;
case "Ex4": _Ex4 = Convert.ToString(value); break;
case "Ex5": _Ex5 = Convert.ToString(value); break;
case "Ex6": _Ex6 = Convert.ToString(value); break;
case "TraceId": _TraceId = Convert.ToString(value); break;
case "CreateUser": _CreateUser = Convert.ToString(value); break;
case "CreateUserID": _CreateUserID = value.ToInt(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
/// <summary>创建用户</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public User? MyCreateUser => Extends.Get(nameof(MyCreateUser), k => User.FindByID(CreateUserID));
/// <summary>创建用户</summary>
[Map(nameof(CreateUserID), typeof(User), "ID")]
[Category("扩展")]
public String? CreateUserName => MyCreateUser?.ToString();
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static MemberLog FindByID(Int64 id)
{
if (id < 0) return null;
return Find(_.ID == id);
}
/// <summary>根据操作、类别查找</summary>
/// <param name="action">操作</param>
/// <param name="category">类别</param>
/// <returns>实体列表</returns>
public static IList<MemberLog> FindAllByActionAndCategory(String action, String category)
{
if (action.IsNullOrEmpty()) return [];
if (category.IsNullOrEmpty()) return [];
return FindAll(_.Action == action & _.Category == category);
}
/// <summary>根据类别、链接查找</summary>
/// <param name="category">类别</param>
/// <param name="linkId">链接</param>
/// <returns>实体列表</returns>
public static IList<MemberLog> FindAllByCategoryAndLinkID(String category, Int32 linkId)
{
if (category.IsNullOrEmpty()) return [];
if (linkId < 0) return [];
return FindAll(_.Category == category & _.LinkID == linkId);
}
/// <summary>根据创建用户查找</summary>
/// <param name="createUserId">创建用户</param>
/// <returns>实体列表</returns>
public static IList<MemberLog> FindAllByCreateUserID(Int32 createUserId)
{
if (createUserId < 0) return [];
return FindAll(_.CreateUserID == createUserId);
}
#endregion
#region
/// <summary>清理指定时间段内的数据</summary>
/// <param name="start">开始时间。未指定时清理小于指定时间的所有数据</param>
/// <param name="end">结束时间</param>
/// <returns>清理行数</returns>
public static Int32 DeleteWith(DateTime start, DateTime end)
{
if (start == end) return Delete(_.Ds == start);
var where = new WhereExpression();
if (start.Year > 2000) where &= _.Ds >= start;
if (end.Year > 2000) where &= _.Ds < end;
return Delete(where);
}
#endregion
#region
/// <summary>取得成员日志字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field ID = FindByName("ID");
/// <summary>数据分区</summary>
public static readonly Field Ds = FindByName("Ds");
/// <summary>类别</summary>
public static readonly Field Category = FindByName("Category");
/// <summary>操作</summary>
public static readonly Field Action = FindByName("Action");
/// <summary>链接</summary>
public static readonly Field LinkID = FindByName("LinkID");
/// <summary>成功</summary>
public static readonly Field Success = FindByName("Success");
/// <summary>用户名</summary>
public static readonly Field UserName = FindByName("UserName");
/// <summary>扩展1</summary>
public static readonly Field Ex1 = FindByName("Ex1");
/// <summary>扩展2</summary>
public static readonly Field Ex2 = FindByName("Ex2");
/// <summary>扩展3</summary>
public static readonly Field Ex3 = FindByName("Ex3");
/// <summary>扩展4</summary>
public static readonly Field Ex4 = FindByName("Ex4");
/// <summary>扩展5</summary>
public static readonly Field Ex5 = FindByName("Ex5");
/// <summary>扩展6</summary>
public static readonly Field Ex6 = FindByName("Ex6");
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
public static readonly Field TraceId = FindByName("TraceId");
/// <summary>创建者</summary>
public static readonly Field CreateUser = FindByName("CreateUser");
/// <summary>创建用户</summary>
public static readonly Field CreateUserID = FindByName("CreateUserID");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>详细信息</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得成员日志字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String ID = "ID";
/// <summary>数据分区</summary>
public const String Ds = "Ds";
/// <summary>类别</summary>
public const String Category = "Category";
/// <summary>操作</summary>
public const String Action = "Action";
/// <summary>链接</summary>
public const String LinkID = "LinkID";
/// <summary>成功</summary>
public const String Success = "Success";
/// <summary>用户名</summary>
public const String UserName = "UserName";
/// <summary>扩展1</summary>
public const String Ex1 = "Ex1";
/// <summary>扩展2</summary>
public const String Ex2 = "Ex2";
/// <summary>扩展3</summary>
public const String Ex3 = "Ex3";
/// <summary>扩展4</summary>
public const String Ex4 = "Ex4";
/// <summary>扩展5</summary>
public const String Ex5 = "Ex5";
/// <summary>扩展6</summary>
public const String Ex6 = "Ex6";
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
public const String TraceId = "TraceId";
/// <summary>创建者</summary>
public const String CreateUser = "CreateUser";
/// <summary>创建用户</summary>
public const String CreateUserID = "CreateUserID";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>详细信息</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -24,7 +24,7 @@ using XCode.DataAccessLayer;
using XCode.Membership; using XCode.Membership;
using XCode.Shards; using XCode.Shards;
namespace XCode.Membership; namespace XCode.Membership666;
public partial class Log : Entity<Log> public partial class Log : Entity<Log>
{ {

View File

@ -11,7 +11,7 @@ using XCode.Cache;
using XCode.Configuration; using XCode.Configuration;
using XCode.DataAccessLayer; using XCode.DataAccessLayer;
namespace XCode.Membership; namespace XCode.Membership666;
/// <summary>日志</summary> /// <summary>日志</summary>
[Serializable] [Serializable]
@ -25,11 +25,11 @@ public partial class Log : ILog, IEntity<ILog>
{ {
#region #region
private Int64 _ID; private Int64 _ID;
/// <summary>编号</summary> /// <summary>编号。按天分表</summary>
[DisplayName("编号")] [DisplayName("编号")]
[Description("编号")] [Description("编号。按天分表")]
[DataObjectField(true, false, false, 0)] [DataObjectField(true, false, false, 0)]
[BindColumn("ID", "编号", "", DataScale = "time")] [BindColumn("ID", "编号。按天分表", "", DataScale = "timeShard:yyMMdd")]
public Int64 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } } public Int64 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private String? _Category; private String? _Category;
@ -318,11 +318,22 @@ public partial class Log : ILog, IEntity<ILog>
} }
#endregion #endregion
#region
/// <summary>清理指定时间段内的数据</summary>
/// <param name="start">开始时间。未指定时清理小于指定时间的所有数据</param>
/// <param name="end">结束时间</param>
/// <returns>清理行数</returns>
public static Int32 DeleteWith(DateTime start, DateTime end)
{
return Delete(_.ID.Between(start, end, Meta.Factory.Snow));
}
#endregion
#region #region
/// <summary>取得日志字段信息的快捷方式</summary> /// <summary>取得日志字段信息的快捷方式</summary>
public partial class _ public partial class _
{ {
/// <summary>编号</summary> /// <summary>编号。按天分表</summary>
public static readonly Field ID = FindByName("ID"); public static readonly Field ID = FindByName("ID");
/// <summary>类别</summary> /// <summary>类别</summary>
@ -382,7 +393,7 @@ public partial class Log : ILog, IEntity<ILog>
/// <summary>取得日志字段名称的快捷方式</summary> /// <summary>取得日志字段名称的快捷方式</summary>
public partial class __ public partial class __
{ {
/// <summary>编号</summary> /// <summary>编号。按天分表</summary>
public const String ID = "ID"; public const String ID = "ID";
/// <summary>类别</summary> /// <summary>类别</summary>

View File

@ -24,7 +24,7 @@ using XCode.DataAccessLayer;
using XCode.Membership; using XCode.Membership;
using XCode.Shards; using XCode.Shards;
namespace XCode.Membership; namespace XCode.Membership666;
public partial class User : Entity<User> public partial class User : Entity<User>
{ {

View File

@ -24,7 +24,7 @@ using XCode.DataAccessLayer;
using XCode.Membership; using XCode.Membership;
using XCode.Shards; using XCode.Shards;
namespace XCode.Membership; namespace XCode.Membership666;
public partial class User : Entity<User> public partial class User : Entity<User>
{ {

View File

@ -11,7 +11,7 @@ using XCode.Cache;
using XCode.Configuration; using XCode.Configuration;
using XCode.DataAccessLayer; using XCode.DataAccessLayer;
namespace XCode.Membership; namespace XCode.Membership666;
/// <summary>用户。用户帐号信息</summary> /// <summary>用户。用户帐号信息</summary>
[Serializable] [Serializable]

View File

@ -0,0 +1,174 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class UserLog : Entity<UserLog>
{
#region
static UserLog()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(LinkID));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
Meta.Modules.Add<TraceModule>();
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 保留2位小数
//Ex3 = Math.Round(Ex3, 2);
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserID)]) CreateUserID = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化UserLog[用户日志]数据……");
// var entity = new UserLog();
// entity.DataTime = DateTime.Now;
// entity.Category = "abc";
// entity.Action = "abc";
// entity.LinkID = 0;
// entity.Success = true;
// entity.UserName = "abc";
// entity.Ex1 = 0;
// entity.Ex2 = 0;
// entity.Ex3 = 0.0;
// entity.Ex4 = "abc";
// entity.Ex5 = "abc";
// entity.Ex6 = "abc";
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化UserLog[用户日志]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="category">类别</param>
/// <param name="action">操作</param>
/// <param name="linkId">链接</param>
/// <param name="createUserId">创建用户</param>
/// <param name="start">时间开始</param>
/// <param name="end">时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<UserLog> Search(String category, String action, Int32 linkId, Int32 createUserId, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (!category.IsNullOrEmpty()) exp &= _.Category == category;
if (!action.IsNullOrEmpty()) exp &= _.Action == action;
if (linkId >= 0) exp &= _.LinkID == linkId;
if (createUserId >= 0) exp &= _.CreateUserID == createUserId;
exp &= _.CreateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Category.Contains(key) | _.Action.Contains(key) | _.UserName.Contains(key) | _.Ex4.Contains(key) | _.Ex5.Contains(key) | _.Ex6.Contains(key) | _.TraceId.Contains(key) | _.CreateUser.Contains(key) | _.CreateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(ID) as ID,Action From UserLog Where CreateTime>'2020-01-24 00:00:00' Group By Action Order By ID Desc limit 20
static readonly FieldCache<UserLog> _ActionCache = new FieldCache<UserLog>(nameof(Action))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取操作列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetActionList() => _ActionCache.FindAllName();
// Select Count(ID) as ID,Category From UserLog Where CreateTime>'2020-01-24 00:00:00' Group By Category Order By ID Desc limit 20
static readonly FieldCache<UserLog> _CategoryCache = new FieldCache<UserLog>(nameof(Category))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取类别列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetCategoryList() => _CategoryCache.FindAllName();
#endregion
#region
public IUserLog ToModel()
{
var model = new UserLog();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,470 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>用户日志</summary>
[Serializable]
[DataObject]
[Description("用户日志")]
[BindIndex("IX_UserLog_Action_Category_ID", false, "Action,Category,ID")]
[BindIndex("IX_UserLog_Category_LinkID_ID", false, "Category,LinkID,ID")]
[BindIndex("IX_UserLog_CreateUserID_ID", false, "CreateUserID,ID")]
[BindTable("UserLog", Description = "用户日志", ConnName = "Log", DbType = DatabaseType.None)]
public partial class UserLog : IUserLog, IEntity<IUserLog>
{
#region
private Int64 _ID;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("ID", "编号", "")]
public Int64 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private DateTime _DataTime;
/// <summary>数据时间。按月分表</summary>
[DisplayName("数据时间")]
[Description("数据时间。按月分表")]
[DataObjectField(false, false, true, 0)]
[BindColumn("DataTime", "数据时间。按月分表", "", DataScale = "timeShard:yyMM")]
public DateTime DataTime { get => _DataTime; set { if (OnPropertyChanging("DataTime", value)) { _DataTime = value; OnPropertyChanged("DataTime"); } } }
private String? _Category;
/// <summary>类别</summary>
[DisplayName("类别")]
[Description("类别")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Category", "类别", "")]
public String? Category { get => _Category; set { if (OnPropertyChanging("Category", value)) { _Category = value; OnPropertyChanged("Category"); } } }
private String? _Action;
/// <summary>操作</summary>
[DisplayName("操作")]
[Description("操作")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Action", "操作", "")]
public String? Action { get => _Action; set { if (OnPropertyChanging("Action", value)) { _Action = value; OnPropertyChanged("Action"); } } }
private Int32 _LinkID;
/// <summary>链接</summary>
[DisplayName("链接")]
[Description("链接")]
[DataObjectField(false, false, false, 0)]
[BindColumn("LinkID", "链接", "")]
public Int32 LinkID { get => _LinkID; set { if (OnPropertyChanging("LinkID", value)) { _LinkID = value; OnPropertyChanged("LinkID"); } } }
private Boolean _Success;
/// <summary>成功</summary>
[DisplayName("成功")]
[Description("成功")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Success", "成功", "")]
public Boolean Success { get => _Success; set { if (OnPropertyChanging("Success", value)) { _Success = value; OnPropertyChanged("Success"); } } }
private String? _UserName;
/// <summary>用户名</summary>
[DisplayName("用户名")]
[Description("用户名")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UserName", "用户名", "")]
public String? UserName { get => _UserName; set { if (OnPropertyChanging("UserName", value)) { _UserName = value; OnPropertyChanged("UserName"); } } }
private Int32 _Ex1;
/// <summary>扩展1</summary>
[Category("扩展")]
[DisplayName("扩展1")]
[Description("扩展1")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex1", "扩展1", "")]
public Int32 Ex1 { get => _Ex1; set { if (OnPropertyChanging("Ex1", value)) { _Ex1 = value; OnPropertyChanged("Ex1"); } } }
private Int32 _Ex2;
/// <summary>扩展2</summary>
[Category("扩展")]
[DisplayName("扩展2")]
[Description("扩展2")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex2", "扩展2", "")]
public Int32 Ex2 { get => _Ex2; set { if (OnPropertyChanging("Ex2", value)) { _Ex2 = value; OnPropertyChanged("Ex2"); } } }
private Double _Ex3;
/// <summary>扩展3</summary>
[Category("扩展")]
[DisplayName("扩展3")]
[Description("扩展3")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex3", "扩展3", "")]
public Double Ex3 { get => _Ex3; set { if (OnPropertyChanging("Ex3", value)) { _Ex3 = value; OnPropertyChanged("Ex3"); } } }
private String? _Ex4;
/// <summary>扩展4</summary>
[Category("扩展")]
[DisplayName("扩展4")]
[Description("扩展4")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex4", "扩展4", "")]
public String? Ex4 { get => _Ex4; set { if (OnPropertyChanging("Ex4", value)) { _Ex4 = value; OnPropertyChanged("Ex4"); } } }
private String? _Ex5;
/// <summary>扩展5</summary>
[Category("扩展")]
[DisplayName("扩展5")]
[Description("扩展5")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex5", "扩展5", "")]
public String? Ex5 { get => _Ex5; set { if (OnPropertyChanging("Ex5", value)) { _Ex5 = value; OnPropertyChanged("Ex5"); } } }
private String? _Ex6;
/// <summary>扩展6</summary>
[Category("扩展")]
[DisplayName("扩展6")]
[Description("扩展6")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex6", "扩展6", "")]
public String? Ex6 { get => _Ex6; set { if (OnPropertyChanging("Ex6", value)) { _Ex6 = value; OnPropertyChanged("Ex6"); } } }
private String? _TraceId;
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
[DisplayName("性能追踪")]
[Description("性能追踪。用于APM性能追踪定位还原该事件的调用链")]
[DataObjectField(false, false, true, 50)]
[BindColumn("TraceId", "性能追踪。用于APM性能追踪定位还原该事件的调用链", "")]
public String? TraceId { get => _TraceId; set { if (OnPropertyChanging("TraceId", value)) { _TraceId = value; OnPropertyChanged("TraceId"); } } }
private String? _CreateUser;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateUser", "创建者", "")]
public String? CreateUser { get => _CreateUser; set { if (OnPropertyChanging("CreateUser", value)) { _CreateUser = value; OnPropertyChanged("CreateUser"); } } }
private Int32 _CreateUserID;
/// <summary>创建用户</summary>
[Category("扩展")]
[DisplayName("创建用户")]
[Description("创建用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserID", "创建用户", "")]
public Int32 CreateUserID { get => _CreateUserID; set { if (OnPropertyChanging("CreateUserID", value)) { _CreateUserID = value; OnPropertyChanged("CreateUserID"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private DateTime _CreateTime;
/// <summary>时间</summary>
[DisplayName("时间")]
[Description("时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateTime", "时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _Remark;
/// <summary>详细信息</summary>
[DisplayName("详细信息")]
[Description("详细信息")]
[DataObjectField(false, false, true, 2000)]
[BindColumn("Remark", "详细信息", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IUserLog model)
{
ID = model.ID;
DataTime = model.DataTime;
Category = model.Category;
Action = model.Action;
LinkID = model.LinkID;
Success = model.Success;
UserName = model.UserName;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
TraceId = model.TraceId;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"ID" => _ID,
"DataTime" => _DataTime,
"Category" => _Category,
"Action" => _Action,
"LinkID" => _LinkID,
"Success" => _Success,
"UserName" => _UserName,
"Ex1" => _Ex1,
"Ex2" => _Ex2,
"Ex3" => _Ex3,
"Ex4" => _Ex4,
"Ex5" => _Ex5,
"Ex6" => _Ex6,
"TraceId" => _TraceId,
"CreateUser" => _CreateUser,
"CreateUserID" => _CreateUserID,
"CreateIP" => _CreateIP,
"CreateTime" => _CreateTime,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "ID": _ID = value.ToLong(); break;
case "DataTime": _DataTime = value.ToDateTime(); break;
case "Category": _Category = Convert.ToString(value); break;
case "Action": _Action = Convert.ToString(value); break;
case "LinkID": _LinkID = value.ToInt(); break;
case "Success": _Success = value.ToBoolean(); break;
case "UserName": _UserName = Convert.ToString(value); break;
case "Ex1": _Ex1 = value.ToInt(); break;
case "Ex2": _Ex2 = value.ToInt(); break;
case "Ex3": _Ex3 = value.ToDouble(); break;
case "Ex4": _Ex4 = Convert.ToString(value); break;
case "Ex5": _Ex5 = Convert.ToString(value); break;
case "Ex6": _Ex6 = Convert.ToString(value); break;
case "TraceId": _TraceId = Convert.ToString(value); break;
case "CreateUser": _CreateUser = Convert.ToString(value); break;
case "CreateUserID": _CreateUserID = value.ToInt(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
/// <summary>创建用户</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public User? MyCreateUser => Extends.Get(nameof(MyCreateUser), k => User.FindByID(CreateUserID));
/// <summary>创建用户</summary>
[Map(nameof(CreateUserID), typeof(User), "ID")]
[Category("扩展")]
public String? CreateUserName => MyCreateUser?.ToString();
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static UserLog FindByID(Int64 id)
{
if (id < 0) return null;
return Find(_.ID == id);
}
/// <summary>根据操作、类别查找</summary>
/// <param name="action">操作</param>
/// <param name="category">类别</param>
/// <returns>实体列表</returns>
public static IList<UserLog> FindAllByActionAndCategory(String action, String category)
{
if (action.IsNullOrEmpty()) return [];
if (category.IsNullOrEmpty()) return [];
return FindAll(_.Action == action & _.Category == category);
}
/// <summary>根据类别、链接查找</summary>
/// <param name="category">类别</param>
/// <param name="linkId">链接</param>
/// <returns>实体列表</returns>
public static IList<UserLog> FindAllByCategoryAndLinkID(String category, Int32 linkId)
{
if (category.IsNullOrEmpty()) return [];
if (linkId < 0) return [];
return FindAll(_.Category == category & _.LinkID == linkId);
}
/// <summary>根据创建用户查找</summary>
/// <param name="createUserId">创建用户</param>
/// <returns>实体列表</returns>
public static IList<UserLog> FindAllByCreateUserID(Int32 createUserId)
{
if (createUserId < 0) return [];
return FindAll(_.CreateUserID == createUserId);
}
#endregion
#region
/// <summary>清理指定时间段内的数据</summary>
/// <param name="start">开始时间。未指定时清理小于指定时间的所有数据</param>
/// <param name="end">结束时间</param>
/// <returns>清理行数</returns>
public static Int32 DeleteWith(DateTime start, DateTime end)
{
if (start == end) return Delete(_.DataTime == start);
return Delete(_.DataTime.Between(start, end));
}
#endregion
#region
/// <summary>取得用户日志字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field ID = FindByName("ID");
/// <summary>数据时间。按月分表</summary>
public static readonly Field DataTime = FindByName("DataTime");
/// <summary>类别</summary>
public static readonly Field Category = FindByName("Category");
/// <summary>操作</summary>
public static readonly Field Action = FindByName("Action");
/// <summary>链接</summary>
public static readonly Field LinkID = FindByName("LinkID");
/// <summary>成功</summary>
public static readonly Field Success = FindByName("Success");
/// <summary>用户名</summary>
public static readonly Field UserName = FindByName("UserName");
/// <summary>扩展1</summary>
public static readonly Field Ex1 = FindByName("Ex1");
/// <summary>扩展2</summary>
public static readonly Field Ex2 = FindByName("Ex2");
/// <summary>扩展3</summary>
public static readonly Field Ex3 = FindByName("Ex3");
/// <summary>扩展4</summary>
public static readonly Field Ex4 = FindByName("Ex4");
/// <summary>扩展5</summary>
public static readonly Field Ex5 = FindByName("Ex5");
/// <summary>扩展6</summary>
public static readonly Field Ex6 = FindByName("Ex6");
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
public static readonly Field TraceId = FindByName("TraceId");
/// <summary>创建者</summary>
public static readonly Field CreateUser = FindByName("CreateUser");
/// <summary>创建用户</summary>
public static readonly Field CreateUserID = FindByName("CreateUserID");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>详细信息</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得用户日志字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String ID = "ID";
/// <summary>数据时间。按月分表</summary>
public const String DataTime = "DataTime";
/// <summary>类别</summary>
public const String Category = "Category";
/// <summary>操作</summary>
public const String Action = "Action";
/// <summary>链接</summary>
public const String LinkID = "LinkID";
/// <summary>成功</summary>
public const String Success = "Success";
/// <summary>用户名</summary>
public const String UserName = "UserName";
/// <summary>扩展1</summary>
public const String Ex1 = "Ex1";
/// <summary>扩展2</summary>
public const String Ex2 = "Ex2";
/// <summary>扩展3</summary>
public const String Ex3 = "Ex3";
/// <summary>扩展4</summary>
public const String Ex4 = "Ex4";
/// <summary>扩展5</summary>
public const String Ex5 = "Ex5";
/// <summary>扩展6</summary>
public const String Ex6 = "Ex6";
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
public const String TraceId = "TraceId";
/// <summary>创建者</summary>
public const String CreateUser = "CreateUser";
/// <summary>创建用户</summary>
public const String CreateUserID = "CreateUserID";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>详细信息</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -0,0 +1,161 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class Tenant : Entity<Tenant>
{
#region
static Tenant()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(ManagerId));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
// 实体缓存
// var ec = Meta.Cache;
// ec.Expire = 60;
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserId)]) CreateUserId = user.ID;
if (!Dirtys[nameof(UpdateUserId)]) UpdateUserId = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (!Dirtys[nameof(UpdateTime)]) UpdateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
//if (!Dirtys[nameof(UpdateIP)]) UpdateIP = ManageProvider.UserHost;
// 检查唯一索引
// CheckExist(method == DataMethod.Insert, nameof(Code));
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化Tenant[租户]数据……");
// var entity = new Tenant();
// entity.Code = "abc";
// entity.Name = "abc";
// entity.Enable = true;
// entity.ManagerId = 0;
// entity.RoleIds = "abc";
// entity.Logo = "abc";
// entity.DatabaseName = "abc";
// entity.TableName = "abc";
// entity.Expired = DateTime.Now;
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化Tenant[租户]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="code">编码。唯一编码</param>
/// <param name="start">更新时间开始</param>
/// <param name="end">更新时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<Tenant> Search(String code, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (!code.IsNullOrEmpty()) exp &= _.Code == code;
exp &= _.UpdateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Code.Contains(key) | _.Name.Contains(key) | _.RoleIds.Contains(key) | _.Logo.Contains(key) | _.DatabaseName.Contains(key) | _.TableName.Contains(key) | _.CreateIP.Contains(key) | _.UpdateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(Id) as Id,Category From Tenant Where CreateTime>'2020-01-24 00:00:00' Group By Category Order By Id Desc limit 20
//static readonly FieldCache<Tenant> _CategoryCache = new FieldCache<Tenant>(nameof(Category))
//{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
//};
///// <summary>获取类别列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
///// <returns></returns>
//public static IDictionary<String, String> GetCategoryList() => _CategoryCache.FindAllName();
#endregion
#region
public ITenant ToModel()
{
var model = new Tenant();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,397 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>租户。多租户SAAS平台用于隔离业务数据</summary>
[Serializable]
[DataObject]
[Description("租户。多租户SAAS平台用于隔离业务数据")]
[BindIndex("IU_Tenant_Code", true, "Code")]
[BindTable("Tenant", Description = "租户。多租户SAAS平台用于隔离业务数据", ConnName = "Membership", DbType = DatabaseType.None)]
public partial class Tenant : ITenant, IEntity<ITenant>
{
#region
private Int32 _Id;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("Id", "编号", "")]
public Int32 Id { get => _Id; set { if (OnPropertyChanging("Id", value)) { _Id = value; OnPropertyChanged("Id"); } } }
private String? _Code;
/// <summary>编码。唯一编码</summary>
[DisplayName("编码")]
[Description("编码。唯一编码")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Code", "编码。唯一编码", "")]
public String? Code { get => _Code; set { if (OnPropertyChanging("Code", value)) { _Code = value; OnPropertyChanged("Code"); } } }
private String? _Name;
/// <summary>名称。显示名称</summary>
[DisplayName("名称")]
[Description("名称。显示名称")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Name", "名称。显示名称", "", Master = true)]
public String? Name { get => _Name; set { if (OnPropertyChanging("Name", value)) { _Name = value; OnPropertyChanged("Name"); } } }
private Boolean _Enable;
/// <summary>启用</summary>
[DisplayName("启用")]
[Description("启用")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Enable", "启用", "")]
public Boolean Enable { get => _Enable; set { if (OnPropertyChanging("Enable", value)) { _Enable = value; OnPropertyChanged("Enable"); } } }
private Int32 _ManagerId;
/// <summary>管理者</summary>
[DisplayName("管理者")]
[Description("管理者")]
[DataObjectField(false, false, false, 0)]
[BindColumn("ManagerId", "管理者", "")]
public Int32 ManagerId { get => _ManagerId; set { if (OnPropertyChanging("ManagerId", value)) { _ManagerId = value; OnPropertyChanged("ManagerId"); } } }
private String? _RoleIds;
/// <summary>角色组。租户可选的角色集合,不同级别的租户所拥有的角色不一样,高级功能也会不同</summary>
[DisplayName("角色组")]
[Description("角色组。租户可选的角色集合,不同级别的租户所拥有的角色不一样,高级功能也会不同")]
[DataObjectField(false, false, true, 200)]
[BindColumn("RoleIds", "角色组。租户可选的角色集合,不同级别的租户所拥有的角色不一样,高级功能也会不同", "")]
public String? RoleIds { get => _RoleIds; set { if (OnPropertyChanging("RoleIds", value)) { _RoleIds = value; OnPropertyChanged("RoleIds"); } } }
private String? _Logo;
/// <summary>图标。附件路径</summary>
[DisplayName("图标")]
[Description("图标。附件路径")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Logo", "图标。附件路径", "", ItemType = "image")]
public String? Logo { get => _Logo; set { if (OnPropertyChanging("Logo", value)) { _Logo = value; OnPropertyChanged("Logo"); } } }
private String? _DatabaseName;
/// <summary>数据库。分库用的数据库名</summary>
[DisplayName("数据库")]
[Description("数据库。分库用的数据库名")]
[DataObjectField(false, false, true, 50)]
[BindColumn("DatabaseName", "数据库。分库用的数据库名", "")]
public String? DatabaseName { get => _DatabaseName; set { if (OnPropertyChanging("DatabaseName", value)) { _DatabaseName = value; OnPropertyChanged("DatabaseName"); } } }
private String? _TableName;
/// <summary>数据表。分表用的数据表前缀</summary>
[DisplayName("数据表")]
[Description("数据表。分表用的数据表前缀")]
[DataObjectField(false, false, true, 50)]
[BindColumn("TableName", "数据表。分表用的数据表前缀", "")]
public String? TableName { get => _TableName; set { if (OnPropertyChanging("TableName", value)) { _TableName = value; OnPropertyChanged("TableName"); } } }
private DateTime _Expired;
/// <summary>过期时间。达到该时间后,自动禁用租户,空表示永不过期</summary>
[DisplayName("过期时间")]
[Description("过期时间。达到该时间后,自动禁用租户,空表示永不过期")]
[DataObjectField(false, false, true, 0)]
[BindColumn("Expired", "过期时间。达到该时间后,自动禁用租户,空表示永不过期", "")]
public DateTime Expired { get => _Expired; set { if (OnPropertyChanging("Expired", value)) { _Expired = value; OnPropertyChanged("Expired"); } } }
private Int32 _CreateUserId;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserId", "创建者", "")]
public Int32 CreateUserId { get => _CreateUserId; set { if (OnPropertyChanging("CreateUserId", value)) { _CreateUserId = value; OnPropertyChanged("CreateUserId"); } } }
private DateTime _CreateTime;
/// <summary>创建时间</summary>
[Category("扩展")]
[DisplayName("创建时间")]
[Description("创建时间")]
[DataObjectField(false, false, true, 0)]
[BindColumn("CreateTime", "创建时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private Int32 _UpdateUserId;
/// <summary>更新者</summary>
[Category("扩展")]
[DisplayName("更新者")]
[Description("更新者")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateUserId", "更新者", "")]
public Int32 UpdateUserId { get => _UpdateUserId; set { if (OnPropertyChanging("UpdateUserId", value)) { _UpdateUserId = value; OnPropertyChanged("UpdateUserId"); } } }
private DateTime _UpdateTime;
/// <summary>更新时间</summary>
[Category("扩展")]
[DisplayName("更新时间")]
[Description("更新时间")]
[DataObjectField(false, false, true, 0)]
[BindColumn("UpdateTime", "更新时间", "")]
public DateTime UpdateTime { get => _UpdateTime; set { if (OnPropertyChanging("UpdateTime", value)) { _UpdateTime = value; OnPropertyChanged("UpdateTime"); } } }
private String? _UpdateIP;
/// <summary>更新地址</summary>
[Category("扩展")]
[DisplayName("更新地址")]
[Description("更新地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateIP", "更新地址", "")]
public String? UpdateIP { get => _UpdateIP; set { if (OnPropertyChanging("UpdateIP", value)) { _UpdateIP = value; OnPropertyChanged("UpdateIP"); } } }
private String? _Remark;
/// <summary>描述</summary>
[Category("扩展")]
[DisplayName("描述")]
[Description("描述")]
[DataObjectField(false, false, true, 500)]
[BindColumn("Remark", "描述", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(ITenant model)
{
Id = model.Id;
Code = model.Code;
Name = model.Name;
Enable = model.Enable;
ManagerId = model.ManagerId;
RoleIds = model.RoleIds;
Logo = model.Logo;
DatabaseName = model.DatabaseName;
TableName = model.TableName;
Expired = model.Expired;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"Id" => _Id,
"Code" => _Code,
"Name" => _Name,
"Enable" => _Enable,
"ManagerId" => _ManagerId,
"RoleIds" => _RoleIds,
"Logo" => _Logo,
"DatabaseName" => _DatabaseName,
"TableName" => _TableName,
"Expired" => _Expired,
"CreateUserId" => _CreateUserId,
"CreateTime" => _CreateTime,
"CreateIP" => _CreateIP,
"UpdateUserId" => _UpdateUserId,
"UpdateTime" => _UpdateTime,
"UpdateIP" => _UpdateIP,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "Id": _Id = value.ToInt(); break;
case "Code": _Code = Convert.ToString(value); break;
case "Name": _Name = Convert.ToString(value); break;
case "Enable": _Enable = value.ToBoolean(); break;
case "ManagerId": _ManagerId = value.ToInt(); break;
case "RoleIds": _RoleIds = Convert.ToString(value); break;
case "Logo": _Logo = Convert.ToString(value); break;
case "DatabaseName": _DatabaseName = Convert.ToString(value); break;
case "TableName": _TableName = Convert.ToString(value); break;
case "Expired": _Expired = value.ToDateTime(); break;
case "CreateUserId": _CreateUserId = value.ToInt(); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "UpdateUserId": _UpdateUserId = value.ToInt(); break;
case "UpdateTime": _UpdateTime = value.ToDateTime(); break;
case "UpdateIP": _UpdateIP = Convert.ToString(value); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
/// <summary>管理者</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public User? Manager => Extends.Get(nameof(Manager), k => User.FindByID(ManagerId));
/// <summary>管理者</summary>
[Map(nameof(ManagerId), typeof(User), "ID")]
public String? ManagerName => Manager?.ToString();
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static Tenant FindById(Int32 id)
{
if (id < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.Id == id);
// 单对象缓存
return Meta.SingleCache[id];
//return Find(_.Id == id);
}
/// <summary>根据编码查找</summary>
/// <param name="code">编码</param>
/// <returns>实体对象</returns>
public static Tenant FindByCode(String code)
{
if (code.IsNullOrEmpty()) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.Code.EqualIgnoreCase(code));
return Find(_.Code == code);
}
#endregion
#region
/// <summary>取得租户字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field Id = FindByName("Id");
/// <summary>编码。唯一编码</summary>
public static readonly Field Code = FindByName("Code");
/// <summary>名称。显示名称</summary>
public static readonly Field Name = FindByName("Name");
/// <summary>启用</summary>
public static readonly Field Enable = FindByName("Enable");
/// <summary>管理者</summary>
public static readonly Field ManagerId = FindByName("ManagerId");
/// <summary>角色组。租户可选的角色集合,不同级别的租户所拥有的角色不一样,高级功能也会不同</summary>
public static readonly Field RoleIds = FindByName("RoleIds");
/// <summary>图标。附件路径</summary>
public static readonly Field Logo = FindByName("Logo");
/// <summary>数据库。分库用的数据库名</summary>
public static readonly Field DatabaseName = FindByName("DatabaseName");
/// <summary>数据表。分表用的数据表前缀</summary>
public static readonly Field TableName = FindByName("TableName");
/// <summary>过期时间。达到该时间后,自动禁用租户,空表示永不过期</summary>
public static readonly Field Expired = FindByName("Expired");
/// <summary>创建者</summary>
public static readonly Field CreateUserId = FindByName("CreateUserId");
/// <summary>创建时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>更新者</summary>
public static readonly Field UpdateUserId = FindByName("UpdateUserId");
/// <summary>更新时间</summary>
public static readonly Field UpdateTime = FindByName("UpdateTime");
/// <summary>更新地址</summary>
public static readonly Field UpdateIP = FindByName("UpdateIP");
/// <summary>描述</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得租户字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String Id = "Id";
/// <summary>编码。唯一编码</summary>
public const String Code = "Code";
/// <summary>名称。显示名称</summary>
public const String Name = "Name";
/// <summary>启用</summary>
public const String Enable = "Enable";
/// <summary>管理者</summary>
public const String ManagerId = "ManagerId";
/// <summary>角色组。租户可选的角色集合,不同级别的租户所拥有的角色不一样,高级功能也会不同</summary>
public const String RoleIds = "RoleIds";
/// <summary>图标。附件路径</summary>
public const String Logo = "Logo";
/// <summary>数据库。分库用的数据库名</summary>
public const String DatabaseName = "DatabaseName";
/// <summary>数据表。分表用的数据表前缀</summary>
public const String TableName = "TableName";
/// <summary>过期时间。达到该时间后,自动禁用租户,空表示永不过期</summary>
public const String Expired = "Expired";
/// <summary>创建者</summary>
public const String CreateUserId = "CreateUserId";
/// <summary>创建时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>更新者</summary>
public const String UpdateUserId = "UpdateUserId";
/// <summary>更新时间</summary>
public const String UpdateTime = "UpdateTime";
/// <summary>更新地址</summary>
public const String UpdateIP = "UpdateIP";
/// <summary>描述</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -0,0 +1,160 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class TenantUser : Entity<TenantUser>
{
#region
static TenantUser()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(TenantId));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
Meta.Modules.Add<TenantModule>();
// 实体缓存
// var ec = Meta.Cache;
// ec.Expire = 60;
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserId)]) CreateUserId = user.ID;
if (!Dirtys[nameof(UpdateUserId)]) UpdateUserId = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (!Dirtys[nameof(UpdateTime)]) UpdateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
//if (!Dirtys[nameof(UpdateIP)]) UpdateIP = ManageProvider.UserHost;
// 检查唯一索引
// CheckExist(method == DataMethod.Insert, nameof(TenantId), nameof(UserId));
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化TenantUser[租户关系]数据……");
// var entity = new TenantUser();
// entity.TenantId = 0;
// entity.UserId = 0;
// entity.Enable = true;
// entity.RoleId = 0;
// entity.RoleIds = "abc";
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化TenantUser[租户关系]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="tenantId">租户</param>
/// <param name="userId">用户</param>
/// <param name="start">更新时间开始</param>
/// <param name="end">更新时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<TenantUser> Search(Int32 tenantId, Int32 userId, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (tenantId >= 0) exp &= _.TenantId == tenantId;
if (userId >= 0) exp &= _.UserId == userId;
exp &= _.UpdateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.RoleIds.Contains(key) | _.CreateIP.Contains(key) | _.UpdateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(Id) as Id,Category From TenantUser Where CreateTime>'2020-01-24 00:00:00' Group By Category Order By Id Desc limit 20
//static readonly FieldCache<TenantUser> _CategoryCache = new FieldCache<TenantUser>(nameof(Category))
//{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
//};
///// <summary>获取类别列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
///// <returns></returns>
//public static IDictionary<String, String> GetCategoryList() => _CategoryCache.FindAllName();
#endregion
#region
public ITenantUser ToModel()
{
var model = new TenantUser();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,361 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>租户关系。用户选择租户进入系统后,以租户关系角色组替代自有角色组来进行鉴权</summary>
[Serializable]
[DataObject]
[Description("租户关系。用户选择租户进入系统后,以租户关系角色组替代自有角色组来进行鉴权")]
[BindIndex("IU_TenantUser_TenantId_UserId", true, "TenantId,UserId")]
[BindIndex("IX_TenantUser_UserId", false, "UserId")]
[BindTable("TenantUser", Description = "租户关系。用户选择租户进入系统后,以租户关系角色组替代自有角色组来进行鉴权", ConnName = "Membership", DbType = DatabaseType.None)]
public partial class TenantUser : ITenantUser, IEntity<ITenantUser>
{
#region
private Int32 _Id;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("Id", "编号", "")]
public Int32 Id { get => _Id; set { if (OnPropertyChanging("Id", value)) { _Id = value; OnPropertyChanged("Id"); } } }
private Int32 _TenantId;
/// <summary>租户</summary>
[DisplayName("租户")]
[Description("租户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("TenantId", "租户", "")]
public Int32 TenantId { get => _TenantId; set { if (OnPropertyChanging("TenantId", value)) { _TenantId = value; OnPropertyChanged("TenantId"); } } }
private Int32 _UserId;
/// <summary>用户</summary>
[DisplayName("用户")]
[Description("用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UserId", "用户", "")]
public Int32 UserId { get => _UserId; set { if (OnPropertyChanging("UserId", value)) { _UserId = value; OnPropertyChanged("UserId"); } } }
private Boolean _Enable;
/// <summary>启用</summary>
[DisplayName("启用")]
[Description("启用")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Enable", "启用", "")]
public Boolean Enable { get => _Enable; set { if (OnPropertyChanging("Enable", value)) { _Enable = value; OnPropertyChanged("Enable"); } } }
private Int32 _RoleId;
/// <summary>角色。用户在该租户所对应的主要角色,替换用户自身的角色组</summary>
[DisplayName("角色")]
[Description("角色。用户在该租户所对应的主要角色,替换用户自身的角色组")]
[DataObjectField(false, false, false, 0)]
[BindColumn("RoleId", "角色。用户在该租户所对应的主要角色,替换用户自身的角色组", "")]
public Int32 RoleId { get => _RoleId; set { if (OnPropertyChanging("RoleId", value)) { _RoleId = value; OnPropertyChanged("RoleId"); } } }
private String? _RoleIds;
/// <summary>角色组。次要角色集合</summary>
[DisplayName("角色组")]
[Description("角色组。次要角色集合")]
[DataObjectField(false, false, true, 200)]
[BindColumn("RoleIds", "角色组。次要角色集合", "")]
public String? RoleIds { get => _RoleIds; set { if (OnPropertyChanging("RoleIds", value)) { _RoleIds = value; OnPropertyChanged("RoleIds"); } } }
private Int32 _CreateUserId;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserId", "创建者", "")]
public Int32 CreateUserId { get => _CreateUserId; set { if (OnPropertyChanging("CreateUserId", value)) { _CreateUserId = value; OnPropertyChanged("CreateUserId"); } } }
private DateTime _CreateTime;
/// <summary>创建时间</summary>
[Category("扩展")]
[DisplayName("创建时间")]
[Description("创建时间")]
[DataObjectField(false, false, true, 0)]
[BindColumn("CreateTime", "创建时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private Int32 _UpdateUserId;
/// <summary>更新者</summary>
[Category("扩展")]
[DisplayName("更新者")]
[Description("更新者")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateUserId", "更新者", "")]
public Int32 UpdateUserId { get => _UpdateUserId; set { if (OnPropertyChanging("UpdateUserId", value)) { _UpdateUserId = value; OnPropertyChanged("UpdateUserId"); } } }
private DateTime _UpdateTime;
/// <summary>更新时间</summary>
[Category("扩展")]
[DisplayName("更新时间")]
[Description("更新时间")]
[DataObjectField(false, false, true, 0)]
[BindColumn("UpdateTime", "更新时间", "")]
public DateTime UpdateTime { get => _UpdateTime; set { if (OnPropertyChanging("UpdateTime", value)) { _UpdateTime = value; OnPropertyChanged("UpdateTime"); } } }
private String? _UpdateIP;
/// <summary>更新地址</summary>
[Category("扩展")]
[DisplayName("更新地址")]
[Description("更新地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateIP", "更新地址", "")]
public String? UpdateIP { get => _UpdateIP; set { if (OnPropertyChanging("UpdateIP", value)) { _UpdateIP = value; OnPropertyChanged("UpdateIP"); } } }
private String? _Remark;
/// <summary>描述</summary>
[Category("扩展")]
[DisplayName("描述")]
[Description("描述")]
[DataObjectField(false, false, true, 500)]
[BindColumn("Remark", "描述", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(ITenantUser model)
{
Id = model.Id;
TenantId = model.TenantId;
UserId = model.UserId;
Enable = model.Enable;
RoleId = model.RoleId;
RoleIds = model.RoleIds;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"Id" => _Id,
"TenantId" => _TenantId,
"UserId" => _UserId,
"Enable" => _Enable,
"RoleId" => _RoleId,
"RoleIds" => _RoleIds,
"CreateUserId" => _CreateUserId,
"CreateTime" => _CreateTime,
"CreateIP" => _CreateIP,
"UpdateUserId" => _UpdateUserId,
"UpdateTime" => _UpdateTime,
"UpdateIP" => _UpdateIP,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "Id": _Id = value.ToInt(); break;
case "TenantId": _TenantId = value.ToInt(); break;
case "UserId": _UserId = value.ToInt(); break;
case "Enable": _Enable = value.ToBoolean(); break;
case "RoleId": _RoleId = value.ToInt(); break;
case "RoleIds": _RoleIds = Convert.ToString(value); break;
case "CreateUserId": _CreateUserId = value.ToInt(); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "UpdateUserId": _UpdateUserId = value.ToInt(); break;
case "UpdateTime": _UpdateTime = value.ToDateTime(); break;
case "UpdateIP": _UpdateIP = Convert.ToString(value); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
/// <summary>租户</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public Tenant? Tenant => Extends.Get(nameof(Tenant), k => Tenant.FindById(TenantId));
/// <summary>租户</summary>
[Map(nameof(TenantId), typeof(Tenant), "Id")]
public String? TenantName => Tenant?.ToString();
/// <summary>用户</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public User? User => Extends.Get(nameof(User), k => User.FindByID(UserId));
/// <summary>用户</summary>
[Map(nameof(UserId), typeof(User), "ID")]
public String? UserName => User?.ToString();
/// <summary>角色</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public Role? Role => Extends.Get(nameof(Role), k => Role.FindByID(RoleId));
/// <summary>角色</summary>
[Map(nameof(RoleId), typeof(Role), "ID")]
public String? RoleName => Role?.Name;
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static TenantUser FindById(Int32 id)
{
if (id < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.Id == id);
// 单对象缓存
return Meta.SingleCache[id];
//return Find(_.Id == id);
}
/// <summary>根据租户、用户查找</summary>
/// <param name="tenantId">租户</param>
/// <param name="userId">用户</param>
/// <returns>实体对象</returns>
public static TenantUser FindByTenantIdAndUserId(Int32 tenantId, Int32 userId)
{
if (tenantId < 0) return null;
if (userId < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.TenantId == tenantId && e.UserId == userId);
return Find(_.TenantId == tenantId & _.UserId == userId);
}
/// <summary>根据用户查找</summary>
/// <param name="userId">用户</param>
/// <returns>实体列表</returns>
public static IList<TenantUser> FindAllByUserId(Int32 userId)
{
if (userId < 0) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.UserId == userId);
return FindAll(_.UserId == userId);
}
#endregion
#region
/// <summary>取得租户关系字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field Id = FindByName("Id");
/// <summary>租户</summary>
public static readonly Field TenantId = FindByName("TenantId");
/// <summary>用户</summary>
public static readonly Field UserId = FindByName("UserId");
/// <summary>启用</summary>
public static readonly Field Enable = FindByName("Enable");
/// <summary>角色。用户在该租户所对应的主要角色,替换用户自身的角色组</summary>
public static readonly Field RoleId = FindByName("RoleId");
/// <summary>角色组。次要角色集合</summary>
public static readonly Field RoleIds = FindByName("RoleIds");
/// <summary>创建者</summary>
public static readonly Field CreateUserId = FindByName("CreateUserId");
/// <summary>创建时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>更新者</summary>
public static readonly Field UpdateUserId = FindByName("UpdateUserId");
/// <summary>更新时间</summary>
public static readonly Field UpdateTime = FindByName("UpdateTime");
/// <summary>更新地址</summary>
public static readonly Field UpdateIP = FindByName("UpdateIP");
/// <summary>描述</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得租户关系字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String Id = "Id";
/// <summary>租户</summary>
public const String TenantId = "TenantId";
/// <summary>用户</summary>
public const String UserId = "UserId";
/// <summary>启用</summary>
public const String Enable = "Enable";
/// <summary>角色。用户在该租户所对应的主要角色,替换用户自身的角色组</summary>
public const String RoleId = "RoleId";
/// <summary>角色组。次要角色集合</summary>
public const String RoleIds = "RoleIds";
/// <summary>创建者</summary>
public const String CreateUserId = "CreateUserId";
/// <summary>创建时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>更新者</summary>
public const String UpdateUserId = "UpdateUserId";
/// <summary>更新时间</summary>
public const String UpdateTime = "UpdateTime";
/// <summary>更新地址</summary>
public const String UpdateIP = "UpdateIP";
/// <summary>描述</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -0,0 +1,177 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class Menu : Entity<Menu>
{
#region
static Menu()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(ParentID));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
// 实体缓存
// var ec = Meta.Cache;
// ec.Expire = 60;
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 这里验证参数范围,建议抛出参数异常,指定参数名,前端用户界面可以捕获参数异常并聚焦到对应的参数输入框
if (Name.IsNullOrEmpty()) throw new ArgumentNullException(nameof(Name), "名称不能为空!");
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 保留2位小数
//Ex3 = Math.Round(Ex3, 2);
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserID)]) CreateUserID = user.ID;
if (!Dirtys[nameof(UpdateUserID)]) UpdateUserID = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (!Dirtys[nameof(UpdateTime)]) UpdateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
//if (!Dirtys[nameof(UpdateIP)]) UpdateIP = ManageProvider.UserHost;
// 检查唯一索引
// CheckExist(method == DataMethod.Insert, nameof(ParentID), nameof(Name));
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化Menu[菜单]数据……");
// var entity = new Menu();
// entity.Name = "abc";
// entity.DisplayName = "abc";
// entity.FullName = "abc";
// entity.ParentID = 0;
// entity.Url = "abc";
// entity.Sort = 0;
// entity.Icon = "abc";
// entity.Visible = true;
// entity.Necessary = true;
// entity.NewWindow = true;
// entity.Permission = "abc";
// entity.Ex1 = 0;
// entity.Ex2 = 0;
// entity.Ex3 = 0.0;
// entity.Ex4 = "abc";
// entity.Ex5 = "abc";
// entity.Ex6 = "abc";
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化Menu[菜单]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="name">名称</param>
/// <param name="parentId">父编号</param>
/// <param name="start">更新时间开始</param>
/// <param name="end">更新时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<Menu> Search(String name, Int32 parentId, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (!name.IsNullOrEmpty()) exp &= _.Name == name;
if (parentId >= 0) exp &= _.ParentID == parentId;
exp &= _.UpdateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Name.Contains(key) | _.DisplayName.Contains(key) | _.FullName.Contains(key) | _.Url.Contains(key) | _.Icon.Contains(key) | _.Permission.Contains(key) | _.Ex4.Contains(key) | _.Ex5.Contains(key) | _.Ex6.Contains(key) | _.CreateUser.Contains(key) | _.CreateIP.Contains(key) | _.UpdateUser.Contains(key) | _.UpdateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(ID) as ID,Category From Menu Where CreateTime>'2020-01-24 00:00:00' Group By Category Order By ID Desc limit 20
//static readonly FieldCache<Menu> _CategoryCache = new FieldCache<Menu>(nameof(Category))
//{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
//};
///// <summary>获取类别列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
///// <returns></returns>
//public static IDictionary<String, String> GetCategoryList() => _CategoryCache.FindAllName();
#endregion
#region
public IMenu ToModel()
{
var model = new Menu();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,589 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>菜单</summary>
[Serializable]
[DataObject]
[Description("菜单")]
[BindIndex("IX_Menu_Name", false, "Name")]
[BindIndex("IU_Menu_ParentID_Name", true, "ParentID,Name")]
[BindTable("Menu", Description = "菜单", ConnName = "Membership", DbType = DatabaseType.None)]
public partial class Menu : IMenu, IEntity<IMenu>
{
#region
private Int32 _ID;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("ID", "编号", "")]
public Int32 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private String _Name = null!;
/// <summary>名称</summary>
[DisplayName("名称")]
[Description("名称")]
[DataObjectField(false, false, false, 50)]
[BindColumn("Name", "名称", "", Master = true)]
public String Name { get => _Name; set { if (OnPropertyChanging("Name", value)) { _Name = value; OnPropertyChanged("Name"); } } }
private String? _DisplayName;
/// <summary>显示名</summary>
[DisplayName("显示名")]
[Description("显示名")]
[DataObjectField(false, false, true, 50)]
[BindColumn("DisplayName", "显示名", "")]
public String? DisplayName { get => _DisplayName; set { if (OnPropertyChanging("DisplayName", value)) { _DisplayName = value; OnPropertyChanged("DisplayName"); } } }
private String? _FullName;
/// <summary>全名</summary>
[DisplayName("全名")]
[Description("全名")]
[DataObjectField(false, false, true, 200)]
[BindColumn("FullName", "全名", "")]
public String? FullName { get => _FullName; set { if (OnPropertyChanging("FullName", value)) { _FullName = value; OnPropertyChanged("FullName"); } } }
private Int32 _ParentID;
/// <summary>父编号</summary>
[DisplayName("父编号")]
[Description("父编号")]
[DataObjectField(false, false, false, 0)]
[BindColumn("ParentID", "父编号", "")]
public Int32 ParentID { get => _ParentID; set { if (OnPropertyChanging("ParentID", value)) { _ParentID = value; OnPropertyChanged("ParentID"); } } }
private String? _Url;
/// <summary>链接</summary>
[DisplayName("链接")]
[Description("链接")]
[DataObjectField(false, false, true, 200)]
[BindColumn("Url", "链接", "")]
public String? Url { get => _Url; set { if (OnPropertyChanging("Url", value)) { _Url = value; OnPropertyChanged("Url"); } } }
private Int32 _Sort;
/// <summary>排序</summary>
[DisplayName("排序")]
[Description("排序")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Sort", "排序", "")]
public Int32 Sort { get => _Sort; set { if (OnPropertyChanging("Sort", value)) { _Sort = value; OnPropertyChanged("Sort"); } } }
private String? _Icon;
/// <summary>图标</summary>
[DisplayName("图标")]
[Description("图标")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Icon", "图标", "")]
public String? Icon { get => _Icon; set { if (OnPropertyChanging("Icon", value)) { _Icon = value; OnPropertyChanged("Icon"); } } }
private Boolean _Visible;
/// <summary>可见</summary>
[DisplayName("可见")]
[Description("可见")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Visible", "可见", "")]
public Boolean Visible { get => _Visible; set { if (OnPropertyChanging("Visible", value)) { _Visible = value; OnPropertyChanged("Visible"); } } }
private Boolean _Necessary;
/// <summary>必要。必要的菜单,必须至少有角色拥有这些权限,如果没有则自动授权给系统角色</summary>
[DisplayName("必要")]
[Description("必要。必要的菜单,必须至少有角色拥有这些权限,如果没有则自动授权给系统角色")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Necessary", "必要。必要的菜单,必须至少有角色拥有这些权限,如果没有则自动授权给系统角色", "")]
public Boolean Necessary { get => _Necessary; set { if (OnPropertyChanging("Necessary", value)) { _Necessary = value; OnPropertyChanged("Necessary"); } } }
private Boolean _NewWindow;
/// <summary>新窗口。新窗口打开链接</summary>
[DisplayName("新窗口")]
[Description("新窗口。新窗口打开链接")]
[DataObjectField(false, false, false, 0)]
[BindColumn("NewWindow", "新窗口。新窗口打开链接", "")]
public Boolean NewWindow { get => _NewWindow; set { if (OnPropertyChanging("NewWindow", value)) { _NewWindow = value; OnPropertyChanged("NewWindow"); } } }
private String? _Permission;
/// <summary>权限子项。逗号分隔,每个权限子项名值竖线分隔</summary>
[DisplayName("权限子项")]
[Description("权限子项。逗号分隔,每个权限子项名值竖线分隔")]
[DataObjectField(false, false, true, 200)]
[BindColumn("Permission", "权限子项。逗号分隔,每个权限子项名值竖线分隔", "")]
public String? Permission { get => _Permission; set { if (OnPropertyChanging("Permission", value)) { _Permission = value; OnPropertyChanged("Permission"); } } }
private Int32 _Ex1;
/// <summary>扩展1</summary>
[Category("扩展")]
[DisplayName("扩展1")]
[Description("扩展1")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex1", "扩展1", "")]
public Int32 Ex1 { get => _Ex1; set { if (OnPropertyChanging("Ex1", value)) { _Ex1 = value; OnPropertyChanged("Ex1"); } } }
private Int32 _Ex2;
/// <summary>扩展2</summary>
[Category("扩展")]
[DisplayName("扩展2")]
[Description("扩展2")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex2", "扩展2", "")]
public Int32 Ex2 { get => _Ex2; set { if (OnPropertyChanging("Ex2", value)) { _Ex2 = value; OnPropertyChanged("Ex2"); } } }
private Double _Ex3;
/// <summary>扩展3</summary>
[Category("扩展")]
[DisplayName("扩展3")]
[Description("扩展3")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex3", "扩展3", "")]
public Double Ex3 { get => _Ex3; set { if (OnPropertyChanging("Ex3", value)) { _Ex3 = value; OnPropertyChanged("Ex3"); } } }
private String? _Ex4;
/// <summary>扩展4</summary>
[Category("扩展")]
[DisplayName("扩展4")]
[Description("扩展4")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex4", "扩展4", "")]
public String? Ex4 { get => _Ex4; set { if (OnPropertyChanging("Ex4", value)) { _Ex4 = value; OnPropertyChanged("Ex4"); } } }
private String? _Ex5;
/// <summary>扩展5</summary>
[Category("扩展")]
[DisplayName("扩展5")]
[Description("扩展5")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex5", "扩展5", "")]
public String? Ex5 { get => _Ex5; set { if (OnPropertyChanging("Ex5", value)) { _Ex5 = value; OnPropertyChanged("Ex5"); } } }
private String? _Ex6;
/// <summary>扩展6</summary>
[Category("扩展")]
[DisplayName("扩展6")]
[Description("扩展6")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex6", "扩展6", "")]
public String? Ex6 { get => _Ex6; set { if (OnPropertyChanging("Ex6", value)) { _Ex6 = value; OnPropertyChanged("Ex6"); } } }
private String? _CreateUser;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateUser", "创建者", "")]
public String? CreateUser { get => _CreateUser; set { if (OnPropertyChanging("CreateUser", value)) { _CreateUser = value; OnPropertyChanged("CreateUser"); } } }
private Int32 _CreateUserID;
/// <summary>创建用户</summary>
[Category("扩展")]
[DisplayName("创建用户")]
[Description("创建用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserID", "创建用户", "")]
public Int32 CreateUserID { get => _CreateUserID; set { if (OnPropertyChanging("CreateUserID", value)) { _CreateUserID = value; OnPropertyChanged("CreateUserID"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private DateTime _CreateTime;
/// <summary>创建时间</summary>
[Category("扩展")]
[DisplayName("创建时间")]
[Description("创建时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateTime", "创建时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _UpdateUser;
/// <summary>更新者</summary>
[Category("扩展")]
[DisplayName("更新者")]
[Description("更新者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateUser", "更新者", "")]
public String? UpdateUser { get => _UpdateUser; set { if (OnPropertyChanging("UpdateUser", value)) { _UpdateUser = value; OnPropertyChanged("UpdateUser"); } } }
private Int32 _UpdateUserID;
/// <summary>更新用户</summary>
[Category("扩展")]
[DisplayName("更新用户")]
[Description("更新用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateUserID", "更新用户", "")]
public Int32 UpdateUserID { get => _UpdateUserID; set { if (OnPropertyChanging("UpdateUserID", value)) { _UpdateUserID = value; OnPropertyChanged("UpdateUserID"); } } }
private String? _UpdateIP;
/// <summary>更新地址</summary>
[Category("扩展")]
[DisplayName("更新地址")]
[Description("更新地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateIP", "更新地址", "")]
public String? UpdateIP { get => _UpdateIP; set { if (OnPropertyChanging("UpdateIP", value)) { _UpdateIP = value; OnPropertyChanged("UpdateIP"); } } }
private DateTime _UpdateTime;
/// <summary>更新时间</summary>
[Category("扩展")]
[DisplayName("更新时间")]
[Description("更新时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateTime", "更新时间", "")]
public DateTime UpdateTime { get => _UpdateTime; set { if (OnPropertyChanging("UpdateTime", value)) { _UpdateTime = value; OnPropertyChanged("UpdateTime"); } } }
private String? _Remark;
/// <summary>备注</summary>
[Category("扩展")]
[DisplayName("备注")]
[Description("备注")]
[DataObjectField(false, false, true, 500)]
[BindColumn("Remark", "备注", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IMenu model)
{
ID = model.ID;
Name = model.Name;
DisplayName = model.DisplayName;
FullName = model.FullName;
ParentID = model.ParentID;
Url = model.Url;
Sort = model.Sort;
Icon = model.Icon;
Visible = model.Visible;
Necessary = model.Necessary;
NewWindow = model.NewWindow;
Permission = model.Permission;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"ID" => _ID,
"Name" => _Name,
"DisplayName" => _DisplayName,
"FullName" => _FullName,
"ParentID" => _ParentID,
"Url" => _Url,
"Sort" => _Sort,
"Icon" => _Icon,
"Visible" => _Visible,
"Necessary" => _Necessary,
"NewWindow" => _NewWindow,
"Permission" => _Permission,
"Ex1" => _Ex1,
"Ex2" => _Ex2,
"Ex3" => _Ex3,
"Ex4" => _Ex4,
"Ex5" => _Ex5,
"Ex6" => _Ex6,
"CreateUser" => _CreateUser,
"CreateUserID" => _CreateUserID,
"CreateIP" => _CreateIP,
"CreateTime" => _CreateTime,
"UpdateUser" => _UpdateUser,
"UpdateUserID" => _UpdateUserID,
"UpdateIP" => _UpdateIP,
"UpdateTime" => _UpdateTime,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "ID": _ID = value.ToInt(); break;
case "Name": _Name = Convert.ToString(value); break;
case "DisplayName": _DisplayName = Convert.ToString(value); break;
case "FullName": _FullName = Convert.ToString(value); break;
case "ParentID": _ParentID = value.ToInt(); break;
case "Url": _Url = Convert.ToString(value); break;
case "Sort": _Sort = value.ToInt(); break;
case "Icon": _Icon = Convert.ToString(value); break;
case "Visible": _Visible = value.ToBoolean(); break;
case "Necessary": _Necessary = value.ToBoolean(); break;
case "NewWindow": _NewWindow = value.ToBoolean(); break;
case "Permission": _Permission = Convert.ToString(value); break;
case "Ex1": _Ex1 = value.ToInt(); break;
case "Ex2": _Ex2 = value.ToInt(); break;
case "Ex3": _Ex3 = value.ToDouble(); break;
case "Ex4": _Ex4 = Convert.ToString(value); break;
case "Ex5": _Ex5 = Convert.ToString(value); break;
case "Ex6": _Ex6 = Convert.ToString(value); break;
case "CreateUser": _CreateUser = Convert.ToString(value); break;
case "CreateUserID": _CreateUserID = value.ToInt(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "UpdateUser": _UpdateUser = Convert.ToString(value); break;
case "UpdateUserID": _UpdateUserID = value.ToInt(); break;
case "UpdateIP": _UpdateIP = Convert.ToString(value); break;
case "UpdateTime": _UpdateTime = value.ToDateTime(); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static Menu FindByID(Int32 id)
{
if (id < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.ID == id);
// 单对象缓存
return Meta.SingleCache[id];
//return Find(_.ID == id);
}
/// <summary>根据名称查找</summary>
/// <param name="name">名称</param>
/// <returns>实体列表</returns>
public static IList<Menu> FindAllByName(String name)
{
if (name.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.Name.EqualIgnoreCase(name));
return FindAll(_.Name == name);
}
/// <summary>根据父编号、名称查找</summary>
/// <param name="parentId">父编号</param>
/// <param name="name">名称</param>
/// <returns>实体对象</returns>
public static Menu FindByParentIDAndName(Int32 parentId, String name)
{
if (parentId < 0) return null;
if (name.IsNullOrEmpty()) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.ParentID == parentId && e.Name.EqualIgnoreCase(name));
return Find(_.ParentID == parentId & _.Name == name);
}
#endregion
#region
/// <summary>取得菜单字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field ID = FindByName("ID");
/// <summary>名称</summary>
public static readonly Field Name = FindByName("Name");
/// <summary>显示名</summary>
public static readonly Field DisplayName = FindByName("DisplayName");
/// <summary>全名</summary>
public static readonly Field FullName = FindByName("FullName");
/// <summary>父编号</summary>
public static readonly Field ParentID = FindByName("ParentID");
/// <summary>链接</summary>
public static readonly Field Url = FindByName("Url");
/// <summary>排序</summary>
public static readonly Field Sort = FindByName("Sort");
/// <summary>图标</summary>
public static readonly Field Icon = FindByName("Icon");
/// <summary>可见</summary>
public static readonly Field Visible = FindByName("Visible");
/// <summary>必要。必要的菜单,必须至少有角色拥有这些权限,如果没有则自动授权给系统角色</summary>
public static readonly Field Necessary = FindByName("Necessary");
/// <summary>新窗口。新窗口打开链接</summary>
public static readonly Field NewWindow = FindByName("NewWindow");
/// <summary>权限子项。逗号分隔,每个权限子项名值竖线分隔</summary>
public static readonly Field Permission = FindByName("Permission");
/// <summary>扩展1</summary>
public static readonly Field Ex1 = FindByName("Ex1");
/// <summary>扩展2</summary>
public static readonly Field Ex2 = FindByName("Ex2");
/// <summary>扩展3</summary>
public static readonly Field Ex3 = FindByName("Ex3");
/// <summary>扩展4</summary>
public static readonly Field Ex4 = FindByName("Ex4");
/// <summary>扩展5</summary>
public static readonly Field Ex5 = FindByName("Ex5");
/// <summary>扩展6</summary>
public static readonly Field Ex6 = FindByName("Ex6");
/// <summary>创建者</summary>
public static readonly Field CreateUser = FindByName("CreateUser");
/// <summary>创建用户</summary>
public static readonly Field CreateUserID = FindByName("CreateUserID");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>创建时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>更新者</summary>
public static readonly Field UpdateUser = FindByName("UpdateUser");
/// <summary>更新用户</summary>
public static readonly Field UpdateUserID = FindByName("UpdateUserID");
/// <summary>更新地址</summary>
public static readonly Field UpdateIP = FindByName("UpdateIP");
/// <summary>更新时间</summary>
public static readonly Field UpdateTime = FindByName("UpdateTime");
/// <summary>备注</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得菜单字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String ID = "ID";
/// <summary>名称</summary>
public const String Name = "Name";
/// <summary>显示名</summary>
public const String DisplayName = "DisplayName";
/// <summary>全名</summary>
public const String FullName = "FullName";
/// <summary>父编号</summary>
public const String ParentID = "ParentID";
/// <summary>链接</summary>
public const String Url = "Url";
/// <summary>排序</summary>
public const String Sort = "Sort";
/// <summary>图标</summary>
public const String Icon = "Icon";
/// <summary>可见</summary>
public const String Visible = "Visible";
/// <summary>必要。必要的菜单,必须至少有角色拥有这些权限,如果没有则自动授权给系统角色</summary>
public const String Necessary = "Necessary";
/// <summary>新窗口。新窗口打开链接</summary>
public const String NewWindow = "NewWindow";
/// <summary>权限子项。逗号分隔,每个权限子项名值竖线分隔</summary>
public const String Permission = "Permission";
/// <summary>扩展1</summary>
public const String Ex1 = "Ex1";
/// <summary>扩展2</summary>
public const String Ex2 = "Ex2";
/// <summary>扩展3</summary>
public const String Ex3 = "Ex3";
/// <summary>扩展4</summary>
public const String Ex4 = "Ex4";
/// <summary>扩展5</summary>
public const String Ex5 = "Ex5";
/// <summary>扩展6</summary>
public const String Ex6 = "Ex6";
/// <summary>创建者</summary>
public const String CreateUser = "CreateUser";
/// <summary>创建用户</summary>
public const String CreateUserID = "CreateUserID";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>创建时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>更新者</summary>
public const String UpdateUser = "UpdateUser";
/// <summary>更新用户</summary>
public const String UpdateUserID = "UpdateUserID";
/// <summary>更新地址</summary>
public const String UpdateIP = "UpdateIP";
/// <summary>更新时间</summary>
public const String UpdateTime = "UpdateTime";
/// <summary>备注</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -0,0 +1,175 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class Role : Entity<Role>
{
#region
static Role()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(Sort));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
// 实体缓存
// var ec = Meta.Cache;
// ec.Expire = 60;
// 单对象缓存
var sc = Meta.SingleCache;
// sc.Expire = 60;
sc.FindSlaveKeyMethod = k => Find(_.Name == k);
sc.GetSlaveKeyMethod = e => e.Name;
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 这里验证参数范围,建议抛出参数异常,指定参数名,前端用户界面可以捕获参数异常并聚焦到对应的参数输入框
if (Name.IsNullOrEmpty()) throw new ArgumentNullException(nameof(Name), "名称不能为空!");
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 保留2位小数
//Ex3 = Math.Round(Ex3, 2);
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserID)]) CreateUserID = user.ID;
if (!Dirtys[nameof(UpdateUserID)]) UpdateUserID = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (!Dirtys[nameof(UpdateTime)]) UpdateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
//if (!Dirtys[nameof(UpdateIP)]) UpdateIP = ManageProvider.UserHost;
// 检查唯一索引
// CheckExist(method == DataMethod.Insert, nameof(Name));
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化Role[角色]数据……");
// var entity = new Role();
// entity.Name = "abc";
// entity.Enable = true;
// entity.IsSystem = true;
// entity.Permission = "abc";
// entity.Sort = 0;
// entity.Ex1 = 0;
// entity.Ex2 = 0;
// entity.Ex3 = 0.0;
// entity.Ex4 = "abc";
// entity.Ex5 = "abc";
// entity.Ex6 = "abc";
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化Role[角色]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="name">名称</param>
/// <param name="start">更新时间开始</param>
/// <param name="end">更新时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<Role> Search(String name, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (!name.IsNullOrEmpty()) exp &= _.Name == name;
exp &= _.UpdateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Name.Contains(key) | _.Permission.Contains(key) | _.Ex4.Contains(key) | _.Ex5.Contains(key) | _.Ex6.Contains(key) | _.CreateUser.Contains(key) | _.CreateIP.Contains(key) | _.UpdateUser.Contains(key) | _.UpdateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(ID) as ID,Category From Role Where CreateTime>'2020-01-24 00:00:00' Group By Category Order By ID Desc limit 20
//static readonly FieldCache<Role> _CategoryCache = new FieldCache<Role>(nameof(Category))
//{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
//};
///// <summary>获取类别列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
///// <returns></returns>
//public static IDictionary<String, String> GetCategoryList() => _CategoryCache.FindAllName();
#endregion
#region
public IRole ToModel()
{
var model = new Role();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,474 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>角色</summary>
[Serializable]
[DataObject]
[Description("角色")]
[BindIndex("IU_Role_Name", true, "Name")]
[BindTable("Role", Description = "角色", ConnName = "Membership", DbType = DatabaseType.None)]
public partial class Role : IRole, IEntity<IRole>
{
#region
private Int32 _ID;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("ID", "编号", "")]
public Int32 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private String _Name = null!;
/// <summary>名称</summary>
[DisplayName("名称")]
[Description("名称")]
[DataObjectField(false, false, false, 50)]
[BindColumn("Name", "名称", "", Master = true)]
public String Name { get => _Name; set { if (OnPropertyChanging("Name", value)) { _Name = value; OnPropertyChanged("Name"); } } }
private Boolean _Enable;
/// <summary>启用</summary>
[DisplayName("启用")]
[Description("启用")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Enable", "启用", "")]
public Boolean Enable { get => _Enable; set { if (OnPropertyChanging("Enable", value)) { _Enable = value; OnPropertyChanged("Enable"); } } }
private Boolean _IsSystem;
/// <summary>系统。用于业务系统开发使用,不受数据权限约束,禁止修改名称或删除</summary>
[DisplayName("系统")]
[Description("系统。用于业务系统开发使用,不受数据权限约束,禁止修改名称或删除")]
[DataObjectField(false, false, false, 0)]
[BindColumn("IsSystem", "系统。用于业务系统开发使用,不受数据权限约束,禁止修改名称或删除", "")]
public Boolean IsSystem { get => _IsSystem; set { if (OnPropertyChanging("IsSystem", value)) { _IsSystem = value; OnPropertyChanged("IsSystem"); } } }
private String? _Permission;
/// <summary>权限。对不同资源的权限,逗号分隔,每个资源的权限子项竖线分隔</summary>
[DisplayName("权限")]
[Description("权限。对不同资源的权限,逗号分隔,每个资源的权限子项竖线分隔")]
[DataObjectField(false, false, true, -1)]
[BindColumn("Permission", "权限。对不同资源的权限,逗号分隔,每个资源的权限子项竖线分隔", "")]
public String? Permission { get => _Permission; set { if (OnPropertyChanging("Permission", value)) { _Permission = value; OnPropertyChanged("Permission"); } } }
private Int32 _Sort;
/// <summary>排序</summary>
[DisplayName("排序")]
[Description("排序")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Sort", "排序", "")]
public Int32 Sort { get => _Sort; set { if (OnPropertyChanging("Sort", value)) { _Sort = value; OnPropertyChanged("Sort"); } } }
private Int32 _Ex1;
/// <summary>扩展1</summary>
[Category("扩展")]
[DisplayName("扩展1")]
[Description("扩展1")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex1", "扩展1", "")]
public Int32 Ex1 { get => _Ex1; set { if (OnPropertyChanging("Ex1", value)) { _Ex1 = value; OnPropertyChanged("Ex1"); } } }
private Int32 _Ex2;
/// <summary>扩展2</summary>
[Category("扩展")]
[DisplayName("扩展2")]
[Description("扩展2")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex2", "扩展2", "")]
public Int32 Ex2 { get => _Ex2; set { if (OnPropertyChanging("Ex2", value)) { _Ex2 = value; OnPropertyChanged("Ex2"); } } }
private Double _Ex3;
/// <summary>扩展3</summary>
[Category("扩展")]
[DisplayName("扩展3")]
[Description("扩展3")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex3", "扩展3", "")]
public Double Ex3 { get => _Ex3; set { if (OnPropertyChanging("Ex3", value)) { _Ex3 = value; OnPropertyChanged("Ex3"); } } }
private String? _Ex4;
/// <summary>扩展4</summary>
[Category("扩展")]
[DisplayName("扩展4")]
[Description("扩展4")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex4", "扩展4", "")]
public String? Ex4 { get => _Ex4; set { if (OnPropertyChanging("Ex4", value)) { _Ex4 = value; OnPropertyChanged("Ex4"); } } }
private String? _Ex5;
/// <summary>扩展5</summary>
[Category("扩展")]
[DisplayName("扩展5")]
[Description("扩展5")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex5", "扩展5", "")]
public String? Ex5 { get => _Ex5; set { if (OnPropertyChanging("Ex5", value)) { _Ex5 = value; OnPropertyChanged("Ex5"); } } }
private String? _Ex6;
/// <summary>扩展6</summary>
[Category("扩展")]
[DisplayName("扩展6")]
[Description("扩展6")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex6", "扩展6", "")]
public String? Ex6 { get => _Ex6; set { if (OnPropertyChanging("Ex6", value)) { _Ex6 = value; OnPropertyChanged("Ex6"); } } }
private String? _CreateUser;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateUser", "创建者", "")]
public String? CreateUser { get => _CreateUser; set { if (OnPropertyChanging("CreateUser", value)) { _CreateUser = value; OnPropertyChanged("CreateUser"); } } }
private Int32 _CreateUserID;
/// <summary>创建用户</summary>
[Category("扩展")]
[DisplayName("创建用户")]
[Description("创建用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserID", "创建用户", "")]
public Int32 CreateUserID { get => _CreateUserID; set { if (OnPropertyChanging("CreateUserID", value)) { _CreateUserID = value; OnPropertyChanged("CreateUserID"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private DateTime _CreateTime;
/// <summary>创建时间</summary>
[Category("扩展")]
[DisplayName("创建时间")]
[Description("创建时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateTime", "创建时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _UpdateUser;
/// <summary>更新者</summary>
[Category("扩展")]
[DisplayName("更新者")]
[Description("更新者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateUser", "更新者", "")]
public String? UpdateUser { get => _UpdateUser; set { if (OnPropertyChanging("UpdateUser", value)) { _UpdateUser = value; OnPropertyChanged("UpdateUser"); } } }
private Int32 _UpdateUserID;
/// <summary>更新用户</summary>
[Category("扩展")]
[DisplayName("更新用户")]
[Description("更新用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateUserID", "更新用户", "")]
public Int32 UpdateUserID { get => _UpdateUserID; set { if (OnPropertyChanging("UpdateUserID", value)) { _UpdateUserID = value; OnPropertyChanged("UpdateUserID"); } } }
private String? _UpdateIP;
/// <summary>更新地址</summary>
[Category("扩展")]
[DisplayName("更新地址")]
[Description("更新地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateIP", "更新地址", "")]
public String? UpdateIP { get => _UpdateIP; set { if (OnPropertyChanging("UpdateIP", value)) { _UpdateIP = value; OnPropertyChanged("UpdateIP"); } } }
private DateTime _UpdateTime;
/// <summary>更新时间</summary>
[Category("扩展")]
[DisplayName("更新时间")]
[Description("更新时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateTime", "更新时间", "")]
public DateTime UpdateTime { get => _UpdateTime; set { if (OnPropertyChanging("UpdateTime", value)) { _UpdateTime = value; OnPropertyChanged("UpdateTime"); } } }
private String? _Remark;
/// <summary>备注</summary>
[Category("扩展")]
[DisplayName("备注")]
[Description("备注")]
[DataObjectField(false, false, true, 500)]
[BindColumn("Remark", "备注", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IRole model)
{
ID = model.ID;
Name = model.Name;
Enable = model.Enable;
IsSystem = model.IsSystem;
Permission = model.Permission;
Sort = model.Sort;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"ID" => _ID,
"Name" => _Name,
"Enable" => _Enable,
"IsSystem" => _IsSystem,
"Permission" => _Permission,
"Sort" => _Sort,
"Ex1" => _Ex1,
"Ex2" => _Ex2,
"Ex3" => _Ex3,
"Ex4" => _Ex4,
"Ex5" => _Ex5,
"Ex6" => _Ex6,
"CreateUser" => _CreateUser,
"CreateUserID" => _CreateUserID,
"CreateIP" => _CreateIP,
"CreateTime" => _CreateTime,
"UpdateUser" => _UpdateUser,
"UpdateUserID" => _UpdateUserID,
"UpdateIP" => _UpdateIP,
"UpdateTime" => _UpdateTime,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "ID": _ID = value.ToInt(); break;
case "Name": _Name = Convert.ToString(value); break;
case "Enable": _Enable = value.ToBoolean(); break;
case "IsSystem": _IsSystem = value.ToBoolean(); break;
case "Permission": _Permission = Convert.ToString(value); break;
case "Sort": _Sort = value.ToInt(); break;
case "Ex1": _Ex1 = value.ToInt(); break;
case "Ex2": _Ex2 = value.ToInt(); break;
case "Ex3": _Ex3 = value.ToDouble(); break;
case "Ex4": _Ex4 = Convert.ToString(value); break;
case "Ex5": _Ex5 = Convert.ToString(value); break;
case "Ex6": _Ex6 = Convert.ToString(value); break;
case "CreateUser": _CreateUser = Convert.ToString(value); break;
case "CreateUserID": _CreateUserID = value.ToInt(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "UpdateUser": _UpdateUser = Convert.ToString(value); break;
case "UpdateUserID": _UpdateUserID = value.ToInt(); break;
case "UpdateIP": _UpdateIP = Convert.ToString(value); break;
case "UpdateTime": _UpdateTime = value.ToDateTime(); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static Role FindByID(Int32 id)
{
if (id < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.ID == id);
// 单对象缓存
return Meta.SingleCache[id];
//return Find(_.ID == id);
}
/// <summary>根据名称查找</summary>
/// <param name="name">名称</param>
/// <returns>实体对象</returns>
public static Role FindByName(String name)
{
if (name.IsNullOrEmpty()) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.Name.EqualIgnoreCase(name));
// 单对象缓存
return Meta.SingleCache.GetItemWithSlaveKey(name) as Role;
//return Find(_.Name == name);
}
#endregion
#region
/// <summary>取得角色字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field ID = FindByName("ID");
/// <summary>名称</summary>
public static readonly Field Name = FindByName("Name");
/// <summary>启用</summary>
public static readonly Field Enable = FindByName("Enable");
/// <summary>系统。用于业务系统开发使用,不受数据权限约束,禁止修改名称或删除</summary>
public static readonly Field IsSystem = FindByName("IsSystem");
/// <summary>权限。对不同资源的权限,逗号分隔,每个资源的权限子项竖线分隔</summary>
public static readonly Field Permission = FindByName("Permission");
/// <summary>排序</summary>
public static readonly Field Sort = FindByName("Sort");
/// <summary>扩展1</summary>
public static readonly Field Ex1 = FindByName("Ex1");
/// <summary>扩展2</summary>
public static readonly Field Ex2 = FindByName("Ex2");
/// <summary>扩展3</summary>
public static readonly Field Ex3 = FindByName("Ex3");
/// <summary>扩展4</summary>
public static readonly Field Ex4 = FindByName("Ex4");
/// <summary>扩展5</summary>
public static readonly Field Ex5 = FindByName("Ex5");
/// <summary>扩展6</summary>
public static readonly Field Ex6 = FindByName("Ex6");
/// <summary>创建者</summary>
public static readonly Field CreateUser = FindByName("CreateUser");
/// <summary>创建用户</summary>
public static readonly Field CreateUserID = FindByName("CreateUserID");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>创建时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>更新者</summary>
public static readonly Field UpdateUser = FindByName("UpdateUser");
/// <summary>更新用户</summary>
public static readonly Field UpdateUserID = FindByName("UpdateUserID");
/// <summary>更新地址</summary>
public static readonly Field UpdateIP = FindByName("UpdateIP");
/// <summary>更新时间</summary>
public static readonly Field UpdateTime = FindByName("UpdateTime");
/// <summary>备注</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得角色字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String ID = "ID";
/// <summary>名称</summary>
public const String Name = "Name";
/// <summary>启用</summary>
public const String Enable = "Enable";
/// <summary>系统。用于业务系统开发使用,不受数据权限约束,禁止修改名称或删除</summary>
public const String IsSystem = "IsSystem";
/// <summary>权限。对不同资源的权限,逗号分隔,每个资源的权限子项竖线分隔</summary>
public const String Permission = "Permission";
/// <summary>排序</summary>
public const String Sort = "Sort";
/// <summary>扩展1</summary>
public const String Ex1 = "Ex1";
/// <summary>扩展2</summary>
public const String Ex2 = "Ex2";
/// <summary>扩展3</summary>
public const String Ex3 = "Ex3";
/// <summary>扩展4</summary>
public const String Ex4 = "Ex4";
/// <summary>扩展5</summary>
public const String Ex5 = "Ex5";
/// <summary>扩展6</summary>
public const String Ex6 = "Ex6";
/// <summary>创建者</summary>
public const String CreateUser = "CreateUser";
/// <summary>创建用户</summary>
public const String CreateUserID = "CreateUserID";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>创建时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>更新者</summary>
public const String UpdateUser = "UpdateUser";
/// <summary>更新用户</summary>
public const String UpdateUserID = "UpdateUserID";
/// <summary>更新地址</summary>
public const String UpdateIP = "UpdateIP";
/// <summary>更新时间</summary>
public const String UpdateTime = "UpdateTime";
/// <summary>备注</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -0,0 +1,178 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.Serialization;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using NewLife.Log;
using NewLife.Model;
using NewLife.Reflection;
using NewLife.Threading;
using NewLife.Web;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
using XCode.Membership;
using XCode.Shards;
namespace XCode.Membership666;
public partial class Department : Entity<Department>
{
#region
static Department()
{
// 累加字段,生成 Update xx Set Count=Count+1234 Where xxx
//var df = Meta.Factory.AdditionalFields;
//df.Add(nameof(TenantId));
// 过滤器 UserModule、TimeModule、IPModule
Meta.Modules.Add(new UserModule { AllowEmpty = false });
Meta.Modules.Add<TimeModule>();
Meta.Modules.Add(new IPModule { AllowEmpty = false });
Meta.Modules.Add<TenantModule>();
// 实体缓存
// var ec = Meta.Cache;
// ec.Expire = 60;
}
/// <summary>验证并修补数据,返回验证结果,或者通过抛出异常的方式提示验证失败。</summary>
/// <param name="method">添删改方法</param>
public override Boolean Valid(DataMethod method)
{
//if (method == DataMethod.Delete) return true;
// 如果没有脏数据,则不需要进行任何处理
if (!HasDirty) return true;
// 这里验证参数范围,建议抛出参数异常,指定参数名,前端用户界面可以捕获参数异常并聚焦到对应的参数输入框
if (Name.IsNullOrEmpty()) throw new ArgumentNullException(nameof(Name), "名称不能为空!");
// 建议先调用基类方法,基类方法会做一些统一处理
if (!base.Valid(method)) return false;
// 在新插入数据或者修改了指定字段时进行修正
// 保留2位小数
//Ex3 = Math.Round(Ex3, 2);
// 处理当前已登录用户信息可以由UserModule过滤器代劳
/*var user = ManageProvider.User;
if (user != null)
{
if (method == DataMethod.Insert && !Dirtys[nameof(CreateUserID)]) CreateUserID = user.ID;
if (!Dirtys[nameof(UpdateUserID)]) UpdateUserID = user.ID;
}*/
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateTime)]) CreateTime = DateTime.Now;
//if (!Dirtys[nameof(UpdateTime)]) UpdateTime = DateTime.Now;
//if (method == DataMethod.Insert && !Dirtys[nameof(CreateIP)]) CreateIP = ManageProvider.UserHost;
//if (!Dirtys[nameof(UpdateIP)]) UpdateIP = ManageProvider.UserHost;
return true;
}
///// <summary>首次连接数据库时初始化数据,仅用于实体类重载,用户不应该调用该方法</summary>
//[EditorBrowsable(EditorBrowsableState.Never)]
//protected override void InitData()
//{
// // InitData一般用于当数据表没有数据时添加一些默认数据该实体类的任何第一次数据库操作都会触发该方法默认异步调用
// if (Meta.Session.Count > 0) return;
// if (XTrace.Debug) XTrace.WriteLine("开始初始化Department[部门]数据……");
// var entity = new Department();
// entity.TenantId = 0;
// entity.Code = "abc";
// entity.Name = "abc";
// entity.FullName = "abc";
// entity.ParentID = 0;
// entity.Level = 0;
// entity.Sort = 0;
// entity.Enable = true;
// entity.Visible = true;
// entity.ManagerId = 0;
// entity.Ex1 = 0;
// entity.Ex2 = 0;
// entity.Ex3 = 0.0;
// entity.Ex4 = "abc";
// entity.Ex5 = "abc";
// entity.Ex6 = "abc";
// entity.Insert();
// if (XTrace.Debug) XTrace.WriteLine("完成初始化Department[部门]数据!");
//}
///// <summary>已重载。基类先调用Valid(true)验证数据然后在事务保护内调用OnInsert</summary>
///// <returns></returns>
//public override Int32 Insert()
//{
// return base.Insert();
//}
///// <summary>已重载。在事务保护范围内处理业务位于Valid之后</summary>
///// <returns></returns>
//protected override Int32 OnDelete()
//{
// return base.OnDelete();
//}
#endregion
#region
#endregion
#region
/// <summary>高级查询</summary>
/// <param name="tenantId">租户</param>
/// <param name="code">代码</param>
/// <param name="name">名称</param>
/// <param name="parentId">父级</param>
/// <param name="start">更新时间开始</param>
/// <param name="end">更新时间结束</param>
/// <param name="key">关键字</param>
/// <param name="page">分页参数信息。可携带统计和数据权限扩展查询等信息</param>
/// <returns>实体列表</returns>
public static IList<Department> Search(Int32 tenantId, String code, String name, Int32 parentId, DateTime start, DateTime end, String key, PageParameter page)
{
var exp = new WhereExpression();
if (tenantId >= 0) exp &= _.TenantId == tenantId;
if (!code.IsNullOrEmpty()) exp &= _.Code == code;
if (!name.IsNullOrEmpty()) exp &= _.Name == name;
if (parentId >= 0) exp &= _.ParentID == parentId;
exp &= _.UpdateTime.Between(start, end);
if (!key.IsNullOrEmpty()) exp &= _.Code.Contains(key) | _.Name.Contains(key) | _.FullName.Contains(key) | _.Ex4.Contains(key) | _.Ex5.Contains(key) | _.Ex6.Contains(key) | _.CreateUser.Contains(key) | _.CreateIP.Contains(key) | _.UpdateUser.Contains(key) | _.UpdateIP.Contains(key) | _.Remark.Contains(key);
return FindAll(exp, page);
}
// Select Count(ID) as ID,Code From Department Where CreateTime>'2020-01-24 00:00:00' Group By Code Order By ID Desc limit 20
static readonly FieldCache<Department> _CodeCache = new FieldCache<Department>(nameof(Code))
{
//Where = _.CreateTime > DateTime.Today.AddDays(-30) & Expression.Empty
};
/// <summary>获取代码列表字段缓存10分钟分组统计数据最多的前20种用于魔方前台下拉选择</summary>
/// <returns></returns>
public static IDictionary<String, String> GetCodeList() => _CodeCache.FindAllName();
#endregion
#region
public IDepartment ToModel()
{
var model = new Department();
model.Copy(this);
return model;
}
#endregion
}

View File

@ -0,0 +1,617 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
using NewLife;
using NewLife.Data;
using XCode;
using XCode.Cache;
using XCode.Configuration;
using XCode.DataAccessLayer;
namespace XCode.Membership666;
/// <summary>部门。组织机构,多级树状结构</summary>
[Serializable]
[DataObject]
[Description("部门。组织机构,多级树状结构")]
[BindIndex("IX_Department_Name", false, "Name")]
[BindIndex("IX_Department_ParentID_Name", false, "ParentID,Name")]
[BindIndex("IX_Department_Code", false, "Code")]
[BindIndex("IX_Department_UpdateTime", false, "UpdateTime")]
[BindIndex("IX_Department_TenantId", false, "TenantId")]
[BindTable("Department", Description = "部门。组织机构,多级树状结构", ConnName = "Membership", DbType = DatabaseType.None)]
public partial class Department : IDepartment, IEntity<IDepartment>
{
#region
private Int32 _ID;
/// <summary>编号</summary>
[DisplayName("编号")]
[Description("编号")]
[DataObjectField(true, true, false, 0)]
[BindColumn("ID", "编号", "")]
public Int32 ID { get => _ID; set { if (OnPropertyChanging("ID", value)) { _ID = value; OnPropertyChanged("ID"); } } }
private Int32 _TenantId;
/// <summary>租户</summary>
[DisplayName("租户")]
[Description("租户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("TenantId", "租户", "")]
public Int32 TenantId { get => _TenantId; set { if (OnPropertyChanging("TenantId", value)) { _TenantId = value; OnPropertyChanged("TenantId"); } } }
private String? _Code;
/// <summary>代码</summary>
[DisplayName("代码")]
[Description("代码")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Code", "代码", "")]
public String? Code { get => _Code; set { if (OnPropertyChanging("Code", value)) { _Code = value; OnPropertyChanged("Code"); } } }
private String _Name = null!;
/// <summary>名称</summary>
[DisplayName("名称")]
[Description("名称")]
[DataObjectField(false, false, false, 50)]
[BindColumn("Name", "名称", "", Master = true)]
public String Name { get => _Name; set { if (OnPropertyChanging("Name", value)) { _Name = value; OnPropertyChanged("Name"); } } }
private String? _FullName;
/// <summary>全名</summary>
[DisplayName("全名")]
[Description("全名")]
[DataObjectField(false, false, true, 200)]
[BindColumn("FullName", "全名", "")]
public String? FullName { get => _FullName; set { if (OnPropertyChanging("FullName", value)) { _FullName = value; OnPropertyChanged("FullName"); } } }
private Int32 _ParentID;
/// <summary>父级</summary>
[DisplayName("父级")]
[Description("父级")]
[DataObjectField(false, false, false, 0)]
[BindColumn("ParentID", "父级", "")]
public Int32 ParentID { get => _ParentID; set { if (OnPropertyChanging("ParentID", value)) { _ParentID = value; OnPropertyChanged("ParentID"); } } }
private Int32 _Level;
/// <summary>层级。树状结构的层级</summary>
[DisplayName("层级")]
[Description("层级。树状结构的层级")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Level", "层级。树状结构的层级", "")]
public Int32 Level { get => _Level; set { if (OnPropertyChanging("Level", value)) { _Level = value; OnPropertyChanged("Level"); } } }
private Int32 _Sort;
/// <summary>排序。同级内排序</summary>
[DisplayName("排序")]
[Description("排序。同级内排序")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Sort", "排序。同级内排序", "")]
public Int32 Sort { get => _Sort; set { if (OnPropertyChanging("Sort", value)) { _Sort = value; OnPropertyChanged("Sort"); } } }
private Boolean _Enable;
/// <summary>启用</summary>
[DisplayName("启用")]
[Description("启用")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Enable", "启用", "")]
public Boolean Enable { get => _Enable; set { if (OnPropertyChanging("Enable", value)) { _Enable = value; OnPropertyChanged("Enable"); } } }
private Boolean _Visible;
/// <summary>可见</summary>
[DisplayName("可见")]
[Description("可见")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Visible", "可见", "")]
public Boolean Visible { get => _Visible; set { if (OnPropertyChanging("Visible", value)) { _Visible = value; OnPropertyChanged("Visible"); } } }
private Int32 _ManagerId;
/// <summary>管理者</summary>
[DisplayName("管理者")]
[Description("管理者")]
[DataObjectField(false, false, false, 0)]
[BindColumn("ManagerId", "管理者", "")]
public Int32 ManagerId { get => _ManagerId; set { if (OnPropertyChanging("ManagerId", value)) { _ManagerId = value; OnPropertyChanged("ManagerId"); } } }
private Int32 _Ex1;
/// <summary>扩展1</summary>
[Category("扩展")]
[DisplayName("扩展1")]
[Description("扩展1")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex1", "扩展1", "")]
public Int32 Ex1 { get => _Ex1; set { if (OnPropertyChanging("Ex1", value)) { _Ex1 = value; OnPropertyChanged("Ex1"); } } }
private Int32 _Ex2;
/// <summary>扩展2</summary>
[Category("扩展")]
[DisplayName("扩展2")]
[Description("扩展2")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex2", "扩展2", "")]
public Int32 Ex2 { get => _Ex2; set { if (OnPropertyChanging("Ex2", value)) { _Ex2 = value; OnPropertyChanged("Ex2"); } } }
private Double _Ex3;
/// <summary>扩展3</summary>
[Category("扩展")]
[DisplayName("扩展3")]
[Description("扩展3")]
[DataObjectField(false, false, false, 0)]
[BindColumn("Ex3", "扩展3", "")]
public Double Ex3 { get => _Ex3; set { if (OnPropertyChanging("Ex3", value)) { _Ex3 = value; OnPropertyChanged("Ex3"); } } }
private String? _Ex4;
/// <summary>扩展4</summary>
[Category("扩展")]
[DisplayName("扩展4")]
[Description("扩展4")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex4", "扩展4", "")]
public String? Ex4 { get => _Ex4; set { if (OnPropertyChanging("Ex4", value)) { _Ex4 = value; OnPropertyChanged("Ex4"); } } }
private String? _Ex5;
/// <summary>扩展5</summary>
[Category("扩展")]
[DisplayName("扩展5")]
[Description("扩展5")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex5", "扩展5", "")]
public String? Ex5 { get => _Ex5; set { if (OnPropertyChanging("Ex5", value)) { _Ex5 = value; OnPropertyChanged("Ex5"); } } }
private String? _Ex6;
/// <summary>扩展6</summary>
[Category("扩展")]
[DisplayName("扩展6")]
[Description("扩展6")]
[DataObjectField(false, false, true, 50)]
[BindColumn("Ex6", "扩展6", "")]
public String? Ex6 { get => _Ex6; set { if (OnPropertyChanging("Ex6", value)) { _Ex6 = value; OnPropertyChanged("Ex6"); } } }
private String? _CreateUser;
/// <summary>创建者</summary>
[Category("扩展")]
[DisplayName("创建者")]
[Description("创建者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateUser", "创建者", "")]
public String? CreateUser { get => _CreateUser; set { if (OnPropertyChanging("CreateUser", value)) { _CreateUser = value; OnPropertyChanged("CreateUser"); } } }
private Int32 _CreateUserID;
/// <summary>创建用户</summary>
[Category("扩展")]
[DisplayName("创建用户")]
[Description("创建用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateUserID", "创建用户", "")]
public Int32 CreateUserID { get => _CreateUserID; set { if (OnPropertyChanging("CreateUserID", value)) { _CreateUserID = value; OnPropertyChanged("CreateUserID"); } } }
private String? _CreateIP;
/// <summary>创建地址</summary>
[Category("扩展")]
[DisplayName("创建地址")]
[Description("创建地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("CreateIP", "创建地址", "")]
public String? CreateIP { get => _CreateIP; set { if (OnPropertyChanging("CreateIP", value)) { _CreateIP = value; OnPropertyChanged("CreateIP"); } } }
private DateTime _CreateTime;
/// <summary>创建时间</summary>
[Category("扩展")]
[DisplayName("创建时间")]
[Description("创建时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("CreateTime", "创建时间", "")]
public DateTime CreateTime { get => _CreateTime; set { if (OnPropertyChanging("CreateTime", value)) { _CreateTime = value; OnPropertyChanged("CreateTime"); } } }
private String? _UpdateUser;
/// <summary>更新者</summary>
[Category("扩展")]
[DisplayName("更新者")]
[Description("更新者")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateUser", "更新者", "")]
public String? UpdateUser { get => _UpdateUser; set { if (OnPropertyChanging("UpdateUser", value)) { _UpdateUser = value; OnPropertyChanged("UpdateUser"); } } }
private Int32 _UpdateUserID;
/// <summary>更新用户</summary>
[Category("扩展")]
[DisplayName("更新用户")]
[Description("更新用户")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateUserID", "更新用户", "")]
public Int32 UpdateUserID { get => _UpdateUserID; set { if (OnPropertyChanging("UpdateUserID", value)) { _UpdateUserID = value; OnPropertyChanged("UpdateUserID"); } } }
private String? _UpdateIP;
/// <summary>更新地址</summary>
[Category("扩展")]
[DisplayName("更新地址")]
[Description("更新地址")]
[DataObjectField(false, false, true, 50)]
[BindColumn("UpdateIP", "更新地址", "")]
public String? UpdateIP { get => _UpdateIP; set { if (OnPropertyChanging("UpdateIP", value)) { _UpdateIP = value; OnPropertyChanged("UpdateIP"); } } }
private DateTime _UpdateTime;
/// <summary>更新时间</summary>
[Category("扩展")]
[DisplayName("更新时间")]
[Description("更新时间")]
[DataObjectField(false, false, false, 0)]
[BindColumn("UpdateTime", "更新时间", "")]
public DateTime UpdateTime { get => _UpdateTime; set { if (OnPropertyChanging("UpdateTime", value)) { _UpdateTime = value; OnPropertyChanged("UpdateTime"); } } }
private String? _Remark;
/// <summary>备注</summary>
[Category("扩展")]
[DisplayName("备注")]
[Description("备注")]
[DataObjectField(false, false, true, 500)]
[BindColumn("Remark", "备注", "")]
public String? Remark { get => _Remark; set { if (OnPropertyChanging("Remark", value)) { _Remark = value; OnPropertyChanged("Remark"); } } }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IDepartment model)
{
ID = model.ID;
TenantId = model.TenantId;
Code = model.Code;
Name = model.Name;
FullName = model.FullName;
ParentID = model.ParentID;
Level = model.Level;
Sort = model.Sort;
Enable = model.Enable;
Visible = model.Visible;
ManagerId = model.ManagerId;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
#region /
/// <summary>获取/设置 字段值</summary>
/// <param name="name">字段名</param>
/// <returns></returns>
public override Object? this[String name]
{
get => name switch
{
"ID" => _ID,
"TenantId" => _TenantId,
"Code" => _Code,
"Name" => _Name,
"FullName" => _FullName,
"ParentID" => _ParentID,
"Level" => _Level,
"Sort" => _Sort,
"Enable" => _Enable,
"Visible" => _Visible,
"ManagerId" => _ManagerId,
"Ex1" => _Ex1,
"Ex2" => _Ex2,
"Ex3" => _Ex3,
"Ex4" => _Ex4,
"Ex5" => _Ex5,
"Ex6" => _Ex6,
"CreateUser" => _CreateUser,
"CreateUserID" => _CreateUserID,
"CreateIP" => _CreateIP,
"CreateTime" => _CreateTime,
"UpdateUser" => _UpdateUser,
"UpdateUserID" => _UpdateUserID,
"UpdateIP" => _UpdateIP,
"UpdateTime" => _UpdateTime,
"Remark" => _Remark,
_ => base[name]
};
set
{
switch (name)
{
case "ID": _ID = value.ToInt(); break;
case "TenantId": _TenantId = value.ToInt(); break;
case "Code": _Code = Convert.ToString(value); break;
case "Name": _Name = Convert.ToString(value); break;
case "FullName": _FullName = Convert.ToString(value); break;
case "ParentID": _ParentID = value.ToInt(); break;
case "Level": _Level = value.ToInt(); break;
case "Sort": _Sort = value.ToInt(); break;
case "Enable": _Enable = value.ToBoolean(); break;
case "Visible": _Visible = value.ToBoolean(); break;
case "ManagerId": _ManagerId = value.ToInt(); break;
case "Ex1": _Ex1 = value.ToInt(); break;
case "Ex2": _Ex2 = value.ToInt(); break;
case "Ex3": _Ex3 = value.ToDouble(); break;
case "Ex4": _Ex4 = Convert.ToString(value); break;
case "Ex5": _Ex5 = Convert.ToString(value); break;
case "Ex6": _Ex6 = Convert.ToString(value); break;
case "CreateUser": _CreateUser = Convert.ToString(value); break;
case "CreateUserID": _CreateUserID = value.ToInt(); break;
case "CreateIP": _CreateIP = Convert.ToString(value); break;
case "CreateTime": _CreateTime = value.ToDateTime(); break;
case "UpdateUser": _UpdateUser = Convert.ToString(value); break;
case "UpdateUserID": _UpdateUserID = value.ToInt(); break;
case "UpdateIP": _UpdateIP = Convert.ToString(value); break;
case "UpdateTime": _UpdateTime = value.ToDateTime(); break;
case "Remark": _Remark = Convert.ToString(value); break;
default: base[name] = value; break;
}
}
}
#endregion
#region
/// <summary>租户</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public Tenant? Tenant => Extends.Get(nameof(Tenant), k => Tenant.FindById(TenantId));
/// <summary>租户</summary>
[Map(nameof(TenantId), typeof(Tenant), "Id")]
public String? TenantName => Tenant?.ToString();
/// <summary>管理者</summary>
[XmlIgnore, IgnoreDataMember, ScriptIgnore]
public User? Manager => Extends.Get(nameof(Manager), k => User.FindByID(ManagerId));
/// <summary>管理者</summary>
[Map(nameof(ManagerId), typeof(User), "ID")]
public String? ManagerName => Manager?.ToString();
#endregion
#region
/// <summary>根据编号查找</summary>
/// <param name="id">编号</param>
/// <returns>实体对象</returns>
public static Department FindByID(Int32 id)
{
if (id < 0) return null;
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.Find(e => e.ID == id);
// 单对象缓存
return Meta.SingleCache[id];
//return Find(_.ID == id);
}
/// <summary>根据名称查找</summary>
/// <param name="name">名称</param>
/// <returns>实体列表</returns>
public static IList<Department> FindAllByName(String name)
{
if (name.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.Name.EqualIgnoreCase(name));
return FindAll(_.Name == name);
}
/// <summary>根据父级、名称查找</summary>
/// <param name="parentId">父级</param>
/// <param name="name">名称</param>
/// <returns>实体列表</returns>
public static IList<Department> FindAllByParentIDAndName(Int32 parentId, String name)
{
if (parentId < 0) return [];
if (name.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.ParentID == parentId && e.Name.EqualIgnoreCase(name));
return FindAll(_.ParentID == parentId & _.Name == name);
}
/// <summary>根据代码查找</summary>
/// <param name="code">代码</param>
/// <returns>实体列表</returns>
public static IList<Department> FindAllByCode(String code)
{
if (code.IsNullOrEmpty()) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.Code.EqualIgnoreCase(code));
return FindAll(_.Code == code);
}
/// <summary>根据租户查找</summary>
/// <param name="tenantId">租户</param>
/// <returns>实体列表</returns>
public static IList<Department> FindAllByTenantId(Int32 tenantId)
{
if (tenantId < 0) return [];
// 实体缓存
if (Meta.Session.Count < 1000) return Meta.Cache.FindAll(e => e.TenantId == tenantId);
return FindAll(_.TenantId == tenantId);
}
#endregion
#region
/// <summary>取得部门字段信息的快捷方式</summary>
public partial class _
{
/// <summary>编号</summary>
public static readonly Field ID = FindByName("ID");
/// <summary>租户</summary>
public static readonly Field TenantId = FindByName("TenantId");
/// <summary>代码</summary>
public static readonly Field Code = FindByName("Code");
/// <summary>名称</summary>
public static readonly Field Name = FindByName("Name");
/// <summary>全名</summary>
public static readonly Field FullName = FindByName("FullName");
/// <summary>父级</summary>
public static readonly Field ParentID = FindByName("ParentID");
/// <summary>层级。树状结构的层级</summary>
public static readonly Field Level = FindByName("Level");
/// <summary>排序。同级内排序</summary>
public static readonly Field Sort = FindByName("Sort");
/// <summary>启用</summary>
public static readonly Field Enable = FindByName("Enable");
/// <summary>可见</summary>
public static readonly Field Visible = FindByName("Visible");
/// <summary>管理者</summary>
public static readonly Field ManagerId = FindByName("ManagerId");
/// <summary>扩展1</summary>
public static readonly Field Ex1 = FindByName("Ex1");
/// <summary>扩展2</summary>
public static readonly Field Ex2 = FindByName("Ex2");
/// <summary>扩展3</summary>
public static readonly Field Ex3 = FindByName("Ex3");
/// <summary>扩展4</summary>
public static readonly Field Ex4 = FindByName("Ex4");
/// <summary>扩展5</summary>
public static readonly Field Ex5 = FindByName("Ex5");
/// <summary>扩展6</summary>
public static readonly Field Ex6 = FindByName("Ex6");
/// <summary>创建者</summary>
public static readonly Field CreateUser = FindByName("CreateUser");
/// <summary>创建用户</summary>
public static readonly Field CreateUserID = FindByName("CreateUserID");
/// <summary>创建地址</summary>
public static readonly Field CreateIP = FindByName("CreateIP");
/// <summary>创建时间</summary>
public static readonly Field CreateTime = FindByName("CreateTime");
/// <summary>更新者</summary>
public static readonly Field UpdateUser = FindByName("UpdateUser");
/// <summary>更新用户</summary>
public static readonly Field UpdateUserID = FindByName("UpdateUserID");
/// <summary>更新地址</summary>
public static readonly Field UpdateIP = FindByName("UpdateIP");
/// <summary>更新时间</summary>
public static readonly Field UpdateTime = FindByName("UpdateTime");
/// <summary>备注</summary>
public static readonly Field Remark = FindByName("Remark");
static Field FindByName(String name) => Meta.Table.FindByName(name);
}
/// <summary>取得部门字段名称的快捷方式</summary>
public partial class __
{
/// <summary>编号</summary>
public const String ID = "ID";
/// <summary>租户</summary>
public const String TenantId = "TenantId";
/// <summary>代码</summary>
public const String Code = "Code";
/// <summary>名称</summary>
public const String Name = "Name";
/// <summary>全名</summary>
public const String FullName = "FullName";
/// <summary>父级</summary>
public const String ParentID = "ParentID";
/// <summary>层级。树状结构的层级</summary>
public const String Level = "Level";
/// <summary>排序。同级内排序</summary>
public const String Sort = "Sort";
/// <summary>启用</summary>
public const String Enable = "Enable";
/// <summary>可见</summary>
public const String Visible = "Visible";
/// <summary>管理者</summary>
public const String ManagerId = "ManagerId";
/// <summary>扩展1</summary>
public const String Ex1 = "Ex1";
/// <summary>扩展2</summary>
public const String Ex2 = "Ex2";
/// <summary>扩展3</summary>
public const String Ex3 = "Ex3";
/// <summary>扩展4</summary>
public const String Ex4 = "Ex4";
/// <summary>扩展5</summary>
public const String Ex5 = "Ex5";
/// <summary>扩展6</summary>
public const String Ex6 = "Ex6";
/// <summary>创建者</summary>
public const String CreateUser = "CreateUser";
/// <summary>创建用户</summary>
public const String CreateUserID = "CreateUserID";
/// <summary>创建地址</summary>
public const String CreateIP = "CreateIP";
/// <summary>创建时间</summary>
public const String CreateTime = "CreateTime";
/// <summary>更新者</summary>
public const String UpdateUser = "UpdateUser";
/// <summary>更新用户</summary>
public const String UpdateUserID = "UpdateUserID";
/// <summary>更新地址</summary>
public const String UpdateIP = "UpdateIP";
/// <summary>更新时间</summary>
public const String UpdateTime = "UpdateTime";
/// <summary>备注</summary>
public const String Remark = "Remark";
}
#endregion
}

View File

@ -27,6 +27,7 @@ public class EntityBuilderTests
//var file2 = @"..\..\XUnitTest.XCode\".CombinePath(file); //var file2 = @"..\..\XUnitTest.XCode\".CombinePath(file);
//File.WriteAllText(file2, text); //File.WriteAllText(file2, text);
if (!File.Exists(file)) return null;
var target = File.ReadAllText(file.GetFullPath()); var target = File.ReadAllText(file.GetFullPath());
return target; return target;
@ -298,29 +299,75 @@ public class EntityBuilderTests
option.Output = @"Output\EntityInterfaces\"; option.Output = @"Output\EntityInterfaces\";
InterfaceBuilder.BuildInterfaces(tables, option); InterfaceBuilder.BuildInterfaces(tables, option);
// 拷贝输出到原始目录,仅测试使用
foreach (var table in tables)
{
{
var rs = File.ReadAllText($"Entity\\{table.DisplayName}.cs".GetFullPath());
var target = ReadTarget($"Code\\Entity\\{table.DisplayName}.cs", rs);
}
{
var rs = File.ReadAllText($"Entity\\{table.DisplayName}.Biz.cs".GetFullPath());
var target = ReadTarget($"Code\\Entity\\{table.DisplayName}.Biz.cs", rs);
}
{
var rs = File.ReadAllText($"Output\\EntityModels\\{table.Name}Model.cs".GetFullPath());
var target = ReadTarget($"Code\\EntityModels\\{table.Name}Model.cs", rs);
}
{
var rs = File.ReadAllText($"Output\\EntityInterfaces\\I{table.Name}.cs".GetFullPath());
var target = ReadTarget($"Code\\EntityInterfaces\\I{table.Name}.cs", rs);
}
}
{ {
var rs = File.ReadAllText("Entity\\日志.cs".GetFullPath()); var rs = File.ReadAllText("Entity\\日志.cs".GetFullPath());
var target = ReadTarget("Code\\Entity\\日志.cs", rs); var target = ReadTarget("Code\\Entity\\日志.cs", rs);
Assert.Equal(target, rs); Assert.Equal(target, rs);
} }
{ {
var rs = File.ReadAllText("Entity\\日志.Biz.cs".GetFullPath()); var rs = File.ReadAllText("Entity\\日志.Biz.cs".GetFullPath());
var target = ReadTarget("Code\\Entity\\日志.Biz.cs", rs); var target = ReadTarget("Code\\Entity\\日志.Biz.cs", rs);
Assert.Equal(target, rs); Assert.Equal(target, rs);
} }
{ {
var rs = File.ReadAllText("Output\\EntityModels\\LogModel.cs".GetFullPath()); var rs = File.ReadAllText("Output\\EntityModels\\LogModel.cs".GetFullPath());
var target = ReadTarget("Code\\EntityModels\\LogModel.cs", rs); var target = ReadTarget("Code\\EntityModels\\LogModel.cs", rs);
Assert.Equal(target, rs); Assert.Equal(target, rs);
} }
{ {
var rs = File.ReadAllText("Output\\EntityInterfaces\\ILog.cs".GetFullPath()); var rs = File.ReadAllText("Output\\EntityInterfaces\\ILog.cs".GetFullPath());
var target = ReadTarget("Code\\EntityInterfaces\\ILog.cs", rs); var target = ReadTarget("Code\\EntityInterfaces\\ILog.cs", rs);
Assert.Equal(target, rs); Assert.Equal(target, rs);
} }
{
var rs = File.ReadAllText("Entity\\用户日志.cs".GetFullPath());
var target = ReadTarget("Code\\Entity\\用户日志.cs", rs);
Assert.Equal(target, rs);
}
{
var rs = File.ReadAllText("Entity\\用户日志.Biz.cs".GetFullPath());
var target = ReadTarget("Code\\Entity\\用户日志.Biz.cs", rs);
Assert.Equal(target, rs);
rs = File.ReadAllText("Output\\EntityInterfaces\\IUserLog.cs".GetFullPath());
ReadTarget("Code\\EntityInterfaces\\IUserLog.cs", rs);
}
{
var rs = File.ReadAllText("Entity\\成员日志.cs".GetFullPath());
var target = ReadTarget("Code\\Entity\\成员日志.cs", rs);
Assert.Equal(target, rs);
}
{
var rs = File.ReadAllText("Entity\\成员日志.Biz.cs".GetFullPath());
var target = ReadTarget("Code\\Entity\\成员日志.Biz.cs", rs);
Assert.Equal(target, rs);
rs = File.ReadAllText("Output\\EntityInterfaces\\IMemberLog.cs".GetFullPath());
ReadTarget("Code\\EntityInterfaces\\IMemberLog.cs", rs);
}
} }
[Fact] [Fact]

View File

@ -0,0 +1,68 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>地区。行政区划数据最高支持四级地址9位数字</summary>
public partial interface IArea
{
#region
/// <summary>编码。行政区划编码</summary>
Int32 ID { get; set; }
/// <summary>名称</summary>
String? Name { get; set; }
/// <summary>全名</summary>
String? FullName { get; set; }
/// <summary>父级</summary>
Int32 ParentID { get; set; }
/// <summary>层级</summary>
Int32 Level { get; set; }
/// <summary>类型。省市县,自治州等</summary>
String? Kind { get; set; }
/// <summary>英文名</summary>
String? English { get; set; }
/// <summary>拼音</summary>
String? PinYin { get; set; }
/// <summary>简拼</summary>
String? JianPin { get; set; }
/// <summary>区号。电话区号</summary>
String? TelCode { get; set; }
/// <summary>邮编。邮政编码</summary>
String? ZipCode { get; set; }
/// <summary>经度</summary>
Double Longitude { get; set; }
/// <summary>纬度</summary>
Double Latitude { get; set; }
/// <summary>地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米</summary>
String? GeoHash { get; set; }
/// <summary>启用</summary>
Boolean Enable { get; set; }
/// <summary>创建时间</summary>
DateTime CreateTime { get; set; }
/// <summary>更新时间</summary>
DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -0,0 +1,92 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>部门。组织机构,多级树状结构</summary>
public partial interface IDepartment
{
#region
/// <summary>编号</summary>
Int32 ID { get; set; }
/// <summary>租户</summary>
Int32 TenantId { get; set; }
/// <summary>代码</summary>
String? Code { get; set; }
/// <summary>名称</summary>
String Name { get; set; }
/// <summary>全名</summary>
String? FullName { get; set; }
/// <summary>父级</summary>
Int32 ParentID { get; set; }
/// <summary>层级。树状结构的层级</summary>
Int32 Level { get; set; }
/// <summary>排序。同级内排序</summary>
Int32 Sort { get; set; }
/// <summary>启用</summary>
Boolean Enable { get; set; }
/// <summary>可见</summary>
Boolean Visible { get; set; }
/// <summary>管理者</summary>
Int32 ManagerId { get; set; }
/// <summary>扩展1</summary>
Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
Double Ex3 { get; set; }
/// <summary>扩展4</summary>
String? Ex4 { get; set; }
/// <summary>扩展5</summary>
String? Ex5 { get; set; }
/// <summary>扩展6</summary>
String? Ex6 { get; set; }
/// <summary>创建者</summary>
String? CreateUser { get; set; }
/// <summary>创建用户</summary>
Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
String? CreateIP { get; set; }
/// <summary>创建时间</summary>
DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -5,13 +5,13 @@ using System.Runtime.Serialization;
using System.Web.Script.Serialization; using System.Web.Script.Serialization;
using System.Xml.Serialization; using System.Xml.Serialization;
namespace XCode.Membership; namespace XCode.Membership666;
/// <summary>日志</summary> /// <summary>日志</summary>
public partial interface ILog public partial interface ILog
{ {
#region #region
/// <summary>编号</summary> /// <summary>编号。按天分表</summary>
Int64 ID { get; set; } Int64 ID { get; set; }
/// <summary>类别</summary> /// <summary>类别</summary>

View File

@ -0,0 +1,71 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>成员日志</summary>
public partial interface IMemberLog
{
#region
/// <summary>编号</summary>
Int64 ID { get; set; }
/// <summary>数据分区</summary>
String? Ds { get; set; }
/// <summary>类别</summary>
String? Category { get; set; }
/// <summary>操作</summary>
String? Action { get; set; }
/// <summary>链接</summary>
Int32 LinkID { get; set; }
/// <summary>成功</summary>
Boolean Success { get; set; }
/// <summary>用户名</summary>
String? UserName { get; set; }
/// <summary>扩展1</summary>
Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
Double Ex3 { get; set; }
/// <summary>扩展4</summary>
String? Ex4 { get; set; }
/// <summary>扩展5</summary>
String? Ex5 { get; set; }
/// <summary>扩展6</summary>
String? Ex6 { get; set; }
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
String? TraceId { get; set; }
/// <summary>创建者</summary>
String? CreateUser { get; set; }
/// <summary>创建用户</summary>
Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
String? CreateIP { get; set; }
/// <summary>时间</summary>
DateTime CreateTime { get; set; }
/// <summary>详细信息</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -0,0 +1,95 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>菜单</summary>
public partial interface IMenu
{
#region
/// <summary>编号</summary>
Int32 ID { get; set; }
/// <summary>名称</summary>
String Name { get; set; }
/// <summary>显示名</summary>
String? DisplayName { get; set; }
/// <summary>全名</summary>
String? FullName { get; set; }
/// <summary>父编号</summary>
Int32 ParentID { get; set; }
/// <summary>链接</summary>
String? Url { get; set; }
/// <summary>排序</summary>
Int32 Sort { get; set; }
/// <summary>图标</summary>
String? Icon { get; set; }
/// <summary>可见</summary>
Boolean Visible { get; set; }
/// <summary>必要。必要的菜单,必须至少有角色拥有这些权限,如果没有则自动授权给系统角色</summary>
Boolean Necessary { get; set; }
/// <summary>新窗口。新窗口打开链接</summary>
Boolean NewWindow { get; set; }
/// <summary>权限子项。逗号分隔,每个权限子项名值竖线分隔</summary>
String? Permission { get; set; }
/// <summary>扩展1</summary>
Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
Double Ex3 { get; set; }
/// <summary>扩展4</summary>
String? Ex4 { get; set; }
/// <summary>扩展5</summary>
String? Ex5 { get; set; }
/// <summary>扩展6</summary>
String? Ex6 { get; set; }
/// <summary>创建者</summary>
String? CreateUser { get; set; }
/// <summary>创建用户</summary>
Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
String? CreateIP { get; set; }
/// <summary>创建时间</summary>
DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -0,0 +1,83 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>字典参数</summary>
public partial interface IParameter
{
#region
/// <summary>编号</summary>
Int32 ID { get; set; }
/// <summary>用户。按用户区分参数用户0表示系统级</summary>
Int32 UserID { get; set; }
/// <summary>类别</summary>
String? Category { get; set; }
/// <summary>名称</summary>
String? Name { get; set; }
/// <summary>数值</summary>
String? Value { get; set; }
/// <summary>长数值</summary>
String? LongValue { get; set; }
/// <summary>种类。0普通21列表22名值</summary>
XCode.Membership.ParameterKinds Kind { get; set; }
/// <summary>启用</summary>
Boolean Enable { get; set; }
/// <summary>扩展1</summary>
Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
Decimal Ex2 { get; set; }
/// <summary>扩展3</summary>
Double Ex3 { get; set; }
/// <summary>扩展4</summary>
String? Ex4 { get; set; }
/// <summary>扩展5</summary>
String? Ex5 { get; set; }
/// <summary>扩展6</summary>
String? Ex6 { get; set; }
/// <summary>创建者</summary>
String? CreateUser { get; set; }
/// <summary>创建用户</summary>
Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
String? CreateIP { get; set; }
/// <summary>创建时间</summary>
DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -0,0 +1,77 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>角色</summary>
public partial interface IRole
{
#region
/// <summary>编号</summary>
Int32 ID { get; set; }
/// <summary>名称</summary>
String Name { get; set; }
/// <summary>启用</summary>
Boolean Enable { get; set; }
/// <summary>系统。用于业务系统开发使用,不受数据权限约束,禁止修改名称或删除</summary>
Boolean IsSystem { get; set; }
/// <summary>权限。对不同资源的权限,逗号分隔,每个资源的权限子项竖线分隔</summary>
String? Permission { get; set; }
/// <summary>排序</summary>
Int32 Sort { get; set; }
/// <summary>扩展1</summary>
Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
Double Ex3 { get; set; }
/// <summary>扩展4</summary>
String? Ex4 { get; set; }
/// <summary>扩展5</summary>
String? Ex5 { get; set; }
/// <summary>扩展6</summary>
String? Ex6 { get; set; }
/// <summary>创建者</summary>
String? CreateUser { get; set; }
/// <summary>创建用户</summary>
Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
String? CreateIP { get; set; }
/// <summary>创建时间</summary>
DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -0,0 +1,47 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>租户。多租户SAAS平台用于隔离业务数据</summary>
public partial interface ITenant
{
#region
/// <summary>编号</summary>
Int32 Id { get; set; }
/// <summary>编码。唯一编码</summary>
String? Code { get; set; }
/// <summary>名称。显示名称</summary>
String? Name { get; set; }
/// <summary>启用</summary>
Boolean Enable { get; set; }
/// <summary>管理者</summary>
Int32 ManagerId { get; set; }
/// <summary>角色组。租户可选的角色集合,不同级别的租户所拥有的角色不一样,高级功能也会不同</summary>
String? RoleIds { get; set; }
/// <summary>图标。附件路径</summary>
String? Logo { get; set; }
/// <summary>数据库。分库用的数据库名</summary>
String? DatabaseName { get; set; }
/// <summary>数据表。分表用的数据表前缀</summary>
String? TableName { get; set; }
/// <summary>过期时间。达到该时间后,自动禁用租户,空表示永不过期</summary>
DateTime Expired { get; set; }
/// <summary>描述</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -0,0 +1,35 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>租户关系。用户选择租户进入系统后,以租户关系角色组替代自有角色组来进行鉴权</summary>
public partial interface ITenantUser
{
#region
/// <summary>编号</summary>
Int32 Id { get; set; }
/// <summary>租户</summary>
Int32 TenantId { get; set; }
/// <summary>用户</summary>
Int32 UserId { get; set; }
/// <summary>启用</summary>
Boolean Enable { get; set; }
/// <summary>角色。用户在该租户所对应的主要角色,替换用户自身的角色组</summary>
Int32 RoleId { get; set; }
/// <summary>角色组。次要角色集合</summary>
String? RoleIds { get; set; }
/// <summary>描述</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -5,7 +5,7 @@ using System.Runtime.Serialization;
using System.Web.Script.Serialization; using System.Web.Script.Serialization;
using System.Xml.Serialization; using System.Xml.Serialization;
namespace XCode.Membership; namespace XCode.Membership666;
/// <summary>用户。用户帐号信息</summary> /// <summary>用户。用户帐号信息</summary>
public partial interface IUser public partial interface IUser

View File

@ -0,0 +1,71 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>用户日志</summary>
public partial interface IUserLog
{
#region
/// <summary>编号</summary>
Int64 ID { get; set; }
/// <summary>数据时间。按月分表</summary>
DateTime DataTime { get; set; }
/// <summary>类别</summary>
String? Category { get; set; }
/// <summary>操作</summary>
String? Action { get; set; }
/// <summary>链接</summary>
Int32 LinkID { get; set; }
/// <summary>成功</summary>
Boolean Success { get; set; }
/// <summary>用户名</summary>
String? UserName { get; set; }
/// <summary>扩展1</summary>
Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
Double Ex3 { get; set; }
/// <summary>扩展4</summary>
String? Ex4 { get; set; }
/// <summary>扩展5</summary>
String? Ex5 { get; set; }
/// <summary>扩展6</summary>
String? Ex6 { get; set; }
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
String? TraceId { get; set; }
/// <summary>创建者</summary>
String? CreateUser { get; set; }
/// <summary>创建用户</summary>
Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
String? CreateIP { get; set; }
/// <summary>时间</summary>
DateTime CreateTime { get; set; }
/// <summary>详细信息</summary>
String? Remark { get; set; }
#endregion
}

View File

@ -0,0 +1,94 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>地区。行政区划数据最高支持四级地址9位数字</summary>
public partial class AreaModel : IArea
{
#region
/// <summary>编码。行政区划编码</summary>
public Int32 ID { get; set; }
/// <summary>名称</summary>
public String? Name { get; set; }
/// <summary>全名</summary>
public String? FullName { get; set; }
/// <summary>父级</summary>
public Int32 ParentID { get; set; }
/// <summary>层级</summary>
public Int32 Level { get; set; }
/// <summary>类型。省市县,自治州等</summary>
public String? Kind { get; set; }
/// <summary>英文名</summary>
public String? English { get; set; }
/// <summary>拼音</summary>
public String? PinYin { get; set; }
/// <summary>简拼</summary>
public String? JianPin { get; set; }
/// <summary>区号。电话区号</summary>
public String? TelCode { get; set; }
/// <summary>邮编。邮政编码</summary>
public String? ZipCode { get; set; }
/// <summary>经度</summary>
public Double Longitude { get; set; }
/// <summary>纬度</summary>
public Double Latitude { get; set; }
/// <summary>地址编码。字符串前缀相同越多地理距离越近8位精度19米6位610米</summary>
public String? GeoHash { get; set; }
/// <summary>启用</summary>
public Boolean Enable { get; set; }
/// <summary>创建时间</summary>
public DateTime CreateTime { get; set; }
/// <summary>更新时间</summary>
public DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IArea model)
{
ID = model.ID;
Name = model.Name;
FullName = model.FullName;
ParentID = model.ParentID;
Level = model.Level;
Kind = model.Kind;
English = model.English;
PinYin = model.PinYin;
JianPin = model.JianPin;
TelCode = model.TelCode;
ZipCode = model.ZipCode;
Longitude = model.Longitude;
Latitude = model.Latitude;
GeoHash = model.GeoHash;
Enable = model.Enable;
CreateTime = model.CreateTime;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
}

View File

@ -0,0 +1,126 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>部门。组织机构,多级树状结构</summary>
public partial class DepartmentModel : IDepartment
{
#region
/// <summary>编号</summary>
public Int32 ID { get; set; }
/// <summary>租户</summary>
public Int32 TenantId { get; set; }
/// <summary>代码</summary>
public String? Code { get; set; }
/// <summary>名称</summary>
public String Name { get; set; } = null!;
/// <summary>全名</summary>
public String? FullName { get; set; }
/// <summary>父级</summary>
public Int32 ParentID { get; set; }
/// <summary>层级。树状结构的层级</summary>
public Int32 Level { get; set; }
/// <summary>排序。同级内排序</summary>
public Int32 Sort { get; set; }
/// <summary>启用</summary>
public Boolean Enable { get; set; }
/// <summary>可见</summary>
public Boolean Visible { get; set; }
/// <summary>管理者</summary>
public Int32 ManagerId { get; set; }
/// <summary>扩展1</summary>
public Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
public Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
public Double Ex3 { get; set; }
/// <summary>扩展4</summary>
public String? Ex4 { get; set; }
/// <summary>扩展5</summary>
public String? Ex5 { get; set; }
/// <summary>扩展6</summary>
public String? Ex6 { get; set; }
/// <summary>创建者</summary>
public String? CreateUser { get; set; }
/// <summary>创建用户</summary>
public Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
public String? CreateIP { get; set; }
/// <summary>创建时间</summary>
public DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
public String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
public Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
public String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
public DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IDepartment model)
{
ID = model.ID;
TenantId = model.TenantId;
Code = model.Code;
Name = model.Name;
FullName = model.FullName;
ParentID = model.ParentID;
Level = model.Level;
Sort = model.Sort;
Enable = model.Enable;
Visible = model.Visible;
ManagerId = model.ManagerId;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
}

View File

@ -5,13 +5,13 @@ using System.Runtime.Serialization;
using System.Web.Script.Serialization; using System.Web.Script.Serialization;
using System.Xml.Serialization; using System.Xml.Serialization;
namespace XCode.Membership; namespace XCode.Membership666;
/// <summary>日志</summary> /// <summary>日志</summary>
public partial class LogModel : ILog public partial class LogModel : ILog
{ {
#region #region
/// <summary>编号</summary> /// <summary>编号。按天分表</summary>
public Int64 ID { get; set; } public Int64 ID { get; set; }
/// <summary>类别</summary> /// <summary>类别</summary>

View File

@ -0,0 +1,98 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>成员日志</summary>
public partial class MemberLogModel : IMemberLog
{
#region
/// <summary>编号</summary>
public Int64 ID { get; set; }
/// <summary>数据分区</summary>
public String? Ds { get; set; }
/// <summary>类别</summary>
public String? Category { get; set; }
/// <summary>操作</summary>
public String? Action { get; set; }
/// <summary>链接</summary>
public Int32 LinkID { get; set; }
/// <summary>成功</summary>
public Boolean Success { get; set; }
/// <summary>用户名</summary>
public String? UserName { get; set; }
/// <summary>扩展1</summary>
public Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
public Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
public Double Ex3 { get; set; }
/// <summary>扩展4</summary>
public String? Ex4 { get; set; }
/// <summary>扩展5</summary>
public String? Ex5 { get; set; }
/// <summary>扩展6</summary>
public String? Ex6 { get; set; }
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
public String? TraceId { get; set; }
/// <summary>创建者</summary>
public String? CreateUser { get; set; }
/// <summary>创建用户</summary>
public Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
public String? CreateIP { get; set; }
/// <summary>时间</summary>
public DateTime CreateTime { get; set; }
/// <summary>详细信息</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IMemberLog model)
{
ID = model.ID;
Ds = model.Ds;
Category = model.Category;
Action = model.Action;
LinkID = model.LinkID;
Success = model.Success;
UserName = model.UserName;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
TraceId = model.TraceId;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
Remark = model.Remark;
}
#endregion
}

View File

@ -0,0 +1,130 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>菜单</summary>
public partial class MenuModel : IMenu
{
#region
/// <summary>编号</summary>
public Int32 ID { get; set; }
/// <summary>名称</summary>
public String Name { get; set; } = null!;
/// <summary>显示名</summary>
public String? DisplayName { get; set; }
/// <summary>全名</summary>
public String? FullName { get; set; }
/// <summary>父编号</summary>
public Int32 ParentID { get; set; }
/// <summary>链接</summary>
public String? Url { get; set; }
/// <summary>排序</summary>
public Int32 Sort { get; set; }
/// <summary>图标</summary>
public String? Icon { get; set; }
/// <summary>可见</summary>
public Boolean Visible { get; set; }
/// <summary>必要。必要的菜单,必须至少有角色拥有这些权限,如果没有则自动授权给系统角色</summary>
public Boolean Necessary { get; set; }
/// <summary>新窗口。新窗口打开链接</summary>
public Boolean NewWindow { get; set; }
/// <summary>权限子项。逗号分隔,每个权限子项名值竖线分隔</summary>
public String? Permission { get; set; }
/// <summary>扩展1</summary>
public Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
public Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
public Double Ex3 { get; set; }
/// <summary>扩展4</summary>
public String? Ex4 { get; set; }
/// <summary>扩展5</summary>
public String? Ex5 { get; set; }
/// <summary>扩展6</summary>
public String? Ex6 { get; set; }
/// <summary>创建者</summary>
public String? CreateUser { get; set; }
/// <summary>创建用户</summary>
public Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
public String? CreateIP { get; set; }
/// <summary>创建时间</summary>
public DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
public String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
public Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
public String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
public DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IMenu model)
{
ID = model.ID;
Name = model.Name;
DisplayName = model.DisplayName;
FullName = model.FullName;
ParentID = model.ParentID;
Url = model.Url;
Sort = model.Sort;
Icon = model.Icon;
Visible = model.Visible;
Necessary = model.Necessary;
NewWindow = model.NewWindow;
Permission = model.Permission;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
}

View File

@ -0,0 +1,114 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>字典参数</summary>
public partial class ParameterModel : IParameter
{
#region
/// <summary>编号</summary>
public Int32 ID { get; set; }
/// <summary>用户。按用户区分参数用户0表示系统级</summary>
public Int32 UserID { get; set; }
/// <summary>类别</summary>
public String? Category { get; set; }
/// <summary>名称</summary>
public String? Name { get; set; }
/// <summary>数值</summary>
public String? Value { get; set; }
/// <summary>长数值</summary>
public String? LongValue { get; set; }
/// <summary>种类。0普通21列表22名值</summary>
public XCode.Membership.ParameterKinds Kind { get; set; }
/// <summary>启用</summary>
public Boolean Enable { get; set; }
/// <summary>扩展1</summary>
public Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
public Decimal Ex2 { get; set; }
/// <summary>扩展3</summary>
public Double Ex3 { get; set; }
/// <summary>扩展4</summary>
public String? Ex4 { get; set; }
/// <summary>扩展5</summary>
public String? Ex5 { get; set; }
/// <summary>扩展6</summary>
public String? Ex6 { get; set; }
/// <summary>创建者</summary>
public String? CreateUser { get; set; }
/// <summary>创建用户</summary>
public Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
public String? CreateIP { get; set; }
/// <summary>创建时间</summary>
public DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
public String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
public Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
public String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
public DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IParameter model)
{
ID = model.ID;
UserID = model.UserID;
Category = model.Category;
Name = model.Name;
Value = model.Value;
LongValue = model.LongValue;
Kind = model.Kind;
Enable = model.Enable;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
}

View File

@ -0,0 +1,106 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>角色</summary>
public partial class RoleModel : IRole
{
#region
/// <summary>编号</summary>
public Int32 ID { get; set; }
/// <summary>名称</summary>
public String Name { get; set; } = null!;
/// <summary>启用</summary>
public Boolean Enable { get; set; }
/// <summary>系统。用于业务系统开发使用,不受数据权限约束,禁止修改名称或删除</summary>
public Boolean IsSystem { get; set; }
/// <summary>权限。对不同资源的权限,逗号分隔,每个资源的权限子项竖线分隔</summary>
public String? Permission { get; set; }
/// <summary>排序</summary>
public Int32 Sort { get; set; }
/// <summary>扩展1</summary>
public Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
public Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
public Double Ex3 { get; set; }
/// <summary>扩展4</summary>
public String? Ex4 { get; set; }
/// <summary>扩展5</summary>
public String? Ex5 { get; set; }
/// <summary>扩展6</summary>
public String? Ex6 { get; set; }
/// <summary>创建者</summary>
public String? CreateUser { get; set; }
/// <summary>创建用户</summary>
public Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
public String? CreateIP { get; set; }
/// <summary>创建时间</summary>
public DateTime CreateTime { get; set; }
/// <summary>更新者</summary>
public String? UpdateUser { get; set; }
/// <summary>更新用户</summary>
public Int32 UpdateUserID { get; set; }
/// <summary>更新地址</summary>
public String? UpdateIP { get; set; }
/// <summary>更新时间</summary>
public DateTime UpdateTime { get; set; }
/// <summary>备注</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IRole model)
{
ID = model.ID;
Name = model.Name;
Enable = model.Enable;
IsSystem = model.IsSystem;
Permission = model.Permission;
Sort = model.Sort;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
UpdateUser = model.UpdateUser;
UpdateUserID = model.UpdateUserID;
UpdateIP = model.UpdateIP;
UpdateTime = model.UpdateTime;
Remark = model.Remark;
}
#endregion
}

View File

@ -0,0 +1,66 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>租户。多租户SAAS平台用于隔离业务数据</summary>
public partial class TenantModel : ITenant
{
#region
/// <summary>编号</summary>
public Int32 Id { get; set; }
/// <summary>编码。唯一编码</summary>
public String? Code { get; set; }
/// <summary>名称。显示名称</summary>
public String? Name { get; set; }
/// <summary>启用</summary>
public Boolean Enable { get; set; }
/// <summary>管理者</summary>
public Int32 ManagerId { get; set; }
/// <summary>角色组。租户可选的角色集合,不同级别的租户所拥有的角色不一样,高级功能也会不同</summary>
public String? RoleIds { get; set; }
/// <summary>图标。附件路径</summary>
public String? Logo { get; set; }
/// <summary>数据库。分库用的数据库名</summary>
public String? DatabaseName { get; set; }
/// <summary>数据表。分表用的数据表前缀</summary>
public String? TableName { get; set; }
/// <summary>过期时间。达到该时间后,自动禁用租户,空表示永不过期</summary>
public DateTime Expired { get; set; }
/// <summary>描述</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(ITenant model)
{
Id = model.Id;
Code = model.Code;
Name = model.Name;
Enable = model.Enable;
ManagerId = model.ManagerId;
RoleIds = model.RoleIds;
Logo = model.Logo;
DatabaseName = model.DatabaseName;
TableName = model.TableName;
Expired = model.Expired;
Remark = model.Remark;
}
#endregion
}

View File

@ -0,0 +1,50 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>租户关系。用户选择租户进入系统后,以租户关系角色组替代自有角色组来进行鉴权</summary>
public partial class TenantUserModel : ITenantUser
{
#region
/// <summary>编号</summary>
public Int32 Id { get; set; }
/// <summary>租户</summary>
public Int32 TenantId { get; set; }
/// <summary>用户</summary>
public Int32 UserId { get; set; }
/// <summary>启用</summary>
public Boolean Enable { get; set; }
/// <summary>角色。用户在该租户所对应的主要角色,替换用户自身的角色组</summary>
public Int32 RoleId { get; set; }
/// <summary>角色组。次要角色集合</summary>
public String? RoleIds { get; set; }
/// <summary>描述</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(ITenantUser model)
{
Id = model.Id;
TenantId = model.TenantId;
UserId = model.UserId;
Enable = model.Enable;
RoleId = model.RoleId;
RoleIds = model.RoleIds;
Remark = model.Remark;
}
#endregion
}

View File

@ -0,0 +1,98 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Runtime.Serialization;
using System.Web.Script.Serialization;
using System.Xml.Serialization;
namespace XCode.Membership666;
/// <summary>用户日志</summary>
public partial class UserLogModel : IUserLog
{
#region
/// <summary>编号</summary>
public Int64 ID { get; set; }
/// <summary>数据时间。按月分表</summary>
public DateTime DataTime { get; set; }
/// <summary>类别</summary>
public String? Category { get; set; }
/// <summary>操作</summary>
public String? Action { get; set; }
/// <summary>链接</summary>
public Int32 LinkID { get; set; }
/// <summary>成功</summary>
public Boolean Success { get; set; }
/// <summary>用户名</summary>
public String? UserName { get; set; }
/// <summary>扩展1</summary>
public Int32 Ex1 { get; set; }
/// <summary>扩展2</summary>
public Int32 Ex2 { get; set; }
/// <summary>扩展3</summary>
public Double Ex3 { get; set; }
/// <summary>扩展4</summary>
public String? Ex4 { get; set; }
/// <summary>扩展5</summary>
public String? Ex5 { get; set; }
/// <summary>扩展6</summary>
public String? Ex6 { get; set; }
/// <summary>性能追踪。用于APM性能追踪定位还原该事件的调用链</summary>
public String? TraceId { get; set; }
/// <summary>创建者</summary>
public String? CreateUser { get; set; }
/// <summary>创建用户</summary>
public Int32 CreateUserID { get; set; }
/// <summary>创建地址</summary>
public String? CreateIP { get; set; }
/// <summary>时间</summary>
public DateTime CreateTime { get; set; }
/// <summary>详细信息</summary>
public String? Remark { get; set; }
#endregion
#region
/// <summary>拷贝模型对象</summary>
/// <param name="model">模型</param>
public void Copy(IUserLog model)
{
ID = model.ID;
DataTime = model.DataTime;
Category = model.Category;
Action = model.Action;
LinkID = model.LinkID;
Success = model.Success;
UserName = model.UserName;
Ex1 = model.Ex1;
Ex2 = model.Ex2;
Ex3 = model.Ex3;
Ex4 = model.Ex4;
Ex5 = model.Ex5;
Ex6 = model.Ex6;
TraceId = model.TraceId;
CreateUser = model.CreateUser;
CreateUserID = model.CreateUserID;
CreateIP = model.CreateIP;
CreateTime = model.CreateTime;
Remark = model.Remark;
}
#endregion
}

View File

@ -5,7 +5,7 @@ using System.Runtime.Serialization;
using System.Web.Script.Serialization; using System.Web.Script.Serialization;
using System.Xml.Serialization; using System.Xml.Serialization;
namespace XCode.Membership; namespace XCode.Membership666;
/// <summary>用户。用户帐号信息</summary> /// <summary>用户。用户帐号信息</summary>
public partial class UserModel : IUser public partial class UserModel : IUser

View File

@ -8,7 +8,7 @@
<!--基类。可能包含基类和接口,其中{name}替换为Table.Name--> <!--基类。可能包含基类和接口,其中{name}替换为Table.Name-->
<BaseClass>Entity</BaseClass> <BaseClass>Entity</BaseClass>
<!--命名空间--> <!--命名空间-->
<Namespace>XCode.Membership</Namespace> <Namespace>XCode.Membership666</Namespace>
<!--输出目录--> <!--输出目录-->
<Output>..\..\XUnitTest.XCode\Code</Output> <Output>..\..\XUnitTest.XCode\Code</Output>
<!--是否使用中文文件名。默认false--> <!--是否使用中文文件名。默认false-->
@ -245,7 +245,7 @@
</Table> </Table>
<Table Name="Log" Description="日志" ConnName="Log" InsertOnly="True"> <Table Name="Log" Description="日志" ConnName="Log" InsertOnly="True">
<Columns> <Columns>
<Column Name="ID" DataType="Int64" PrimaryKey="True" DataScale="time" Description="编号" /> <Column Name="ID" DataType="Int64" PrimaryKey="True" DataScale="timeShard:yyMMdd" Description="编号。按天分表" />
<Column Name="Category" DataType="String" Description="类别" /> <Column Name="Category" DataType="String" Description="类别" />
<Column Name="Action" DataType="String" Description="操作" /> <Column Name="Action" DataType="String" Description="操作" />
<Column Name="LinkID" DataType="Int32" Description="链接" /> <Column Name="LinkID" DataType="Int32" Description="链接" />
@ -315,5 +315,61 @@
<Index Columns="UserId" /> <Index Columns="UserId" />
</Indexes> </Indexes>
</Table> </Table>
<Table Name="UserLog" Description="用户日志" ConnName="Log">
<Columns>
<Column Name="ID" DataType="Int64" Identity="True" PrimaryKey="True" Description="编号" />
<Column Name="DataTime" DataType="DateTime" DataScale="timeShard:yyMM" Description="数据时间。按月分表" />
<Column Name="Category" DataType="String" Description="类别" />
<Column Name="Action" DataType="String" Description="操作" />
<Column Name="LinkID" DataType="Int32" Description="链接" />
<Column Name="Success" DataType="Boolean" Description="成功" />
<Column Name="UserName" DataType="String" Description="用户名" />
<Column Name="Ex1" DataType="Int32" Description="扩展1" Category="扩展" />
<Column Name="Ex2" DataType="Int32" Description="扩展2" Category="扩展" />
<Column Name="Ex3" DataType="Double" Description="扩展3" Category="扩展" />
<Column Name="Ex4" DataType="String" Description="扩展4" Category="扩展" />
<Column Name="Ex5" DataType="String" Description="扩展5" Category="扩展" />
<Column Name="Ex6" DataType="String" Description="扩展6" Category="扩展" />
<Column Name="TraceId" DataType="String" Description="性能追踪。用于APM性能追踪定位还原该事件的调用链" />
<Column Name="CreateUser" DataType="String" Description="创建者" Category="扩展" />
<Column Name="CreateUserID" DataType="Int32" Map="User@Id@$" Description="创建用户" Category="扩展" />
<Column Name="CreateIP" DataType="String" Description="创建地址" Category="扩展" />
<Column Name="CreateTime" DataType="DateTime" Nullable="False" Description="时间" />
<Column Name="Remark" DataType="String" Length="2000" Description="详细信息" />
</Columns>
<Indexes>
<Index Columns="Action,Category,ID" />
<Index Columns="Category,LinkID,ID" />
<Index Columns="CreateUserID,ID" />
</Indexes>
</Table>
<Table Name="MemberLog" Description="成员日志" ConnName="Log">
<Columns>
<Column Name="ID" DataType="Int64" Identity="True" PrimaryKey="True" Description="编号" />
<Column Name="Ds" DataType="String" DataScale="time" Description="数据分区" />
<Column Name="Category" DataType="String" Description="类别" />
<Column Name="Action" DataType="String" Description="操作" />
<Column Name="LinkID" DataType="Int32" Description="链接" />
<Column Name="Success" DataType="Boolean" Description="成功" />
<Column Name="UserName" DataType="String" Description="用户名" />
<Column Name="Ex1" DataType="Int32" Description="扩展1" Category="扩展" />
<Column Name="Ex2" DataType="Int32" Description="扩展2" Category="扩展" />
<Column Name="Ex3" DataType="Double" Description="扩展3" Category="扩展" />
<Column Name="Ex4" DataType="String" Description="扩展4" Category="扩展" />
<Column Name="Ex5" DataType="String" Description="扩展5" Category="扩展" />
<Column Name="Ex6" DataType="String" Description="扩展6" Category="扩展" />
<Column Name="TraceId" DataType="String" Description="性能追踪。用于APM性能追踪定位还原该事件的调用链" />
<Column Name="CreateUser" DataType="String" Description="创建者" Category="扩展" />
<Column Name="CreateUserID" DataType="Int32" Map="User@Id@$" Description="创建用户" Category="扩展" />
<Column Name="CreateIP" DataType="String" Description="创建地址" Category="扩展" />
<Column Name="CreateTime" DataType="DateTime" Nullable="False" Description="时间" />
<Column Name="Remark" DataType="String" Length="2000" Description="详细信息" />
</Columns>
<Indexes>
<Index Columns="Action,Category,ID" />
<Index Columns="Category,LinkID,ID" />
<Index Columns="CreateUserID,ID" />
</Indexes>
</Table>
</Tables> </Tables>
</EntityModel> </EntityModel>

View File

@ -8,7 +8,7 @@
<!--基类。可能包含基类和接口,其中{name}替换为Table.Name--> <!--基类。可能包含基类和接口,其中{name}替换为Table.Name-->
<BaseClass>Entity</BaseClass> <BaseClass>Entity</BaseClass>
<!--命名空间--> <!--命名空间-->
<Namespace>XCode.Membership</Namespace> <Namespace>XCode.Membership666</Namespace>
<!--输出目录--> <!--输出目录-->
<Output>..\..\XUnitTest.XCode\Code</Output> <Output>..\..\XUnitTest.XCode\Code</Output>
<!--是否使用中文文件名。默认false--> <!--是否使用中文文件名。默认false-->
@ -245,7 +245,7 @@
</Table> </Table>
<Table Name="Log" Description="日志" ConnName="Log" InsertOnly="True"> <Table Name="Log" Description="日志" ConnName="Log" InsertOnly="True">
<Columns> <Columns>
<Column Name="ID" DataType="Int64" PrimaryKey="True" DataScale="time" Description="编号" /> <Column Name="ID" DataType="Int64" PrimaryKey="True" DataScale="timeShard:yyMMdd" Description="编号。按天分表" />
<Column Name="Category" DataType="String" Description="类别" /> <Column Name="Category" DataType="String" Description="类别" />
<Column Name="Action" DataType="String" Description="操作" /> <Column Name="Action" DataType="String" Description="操作" />
<Column Name="LinkID" ColumnName="link_id" DataType="Int32" Description="链接" /> <Column Name="LinkID" ColumnName="link_id" DataType="Int32" Description="链接" />
@ -315,5 +315,61 @@
<Index Name="IX_TenantUser_UserId" Columns="UserId" /> <Index Name="IX_TenantUser_UserId" Columns="UserId" />
</Indexes> </Indexes>
</Table> </Table>
<Table Name="UserLog" TableName="user_log" Description="用户日志" ConnName="Log">
<Columns>
<Column Name="ID" DataType="Int64" Identity="True" PrimaryKey="True" Description="编号" />
<Column Name="DataTime" ColumnName="data_time" DataType="DateTime" DataScale="timeShard:yyMM" Description="数据时间。按月分表" />
<Column Name="Category" DataType="String" Description="类别" />
<Column Name="Action" DataType="String" Description="操作" />
<Column Name="LinkID" ColumnName="link_id" DataType="Int32" Description="链接" />
<Column Name="Success" DataType="Boolean" Description="成功" />
<Column Name="UserName" ColumnName="user_name" DataType="String" Description="用户名" />
<Column Name="Ex1" DataType="Int32" Description="扩展1" Category="扩展" />
<Column Name="Ex2" DataType="Int32" Description="扩展2" Category="扩展" />
<Column Name="Ex3" DataType="Double" Description="扩展3" Category="扩展" />
<Column Name="Ex4" DataType="String" Description="扩展4" Category="扩展" />
<Column Name="Ex5" DataType="String" Description="扩展5" Category="扩展" />
<Column Name="Ex6" DataType="String" Description="扩展6" Category="扩展" />
<Column Name="TraceId" ColumnName="trace_id" DataType="String" Description="性能追踪。用于APM性能追踪定位还原该事件的调用链" />
<Column Name="CreateUser" ColumnName="create_user" DataType="String" Description="创建者" Category="扩展" />
<Column Name="CreateUserID" ColumnName="create_user_id" DataType="Int32" Map="User@Id@$" Description="创建用户" Category="扩展" />
<Column Name="CreateIP" ColumnName="create_ip" DataType="String" Description="创建地址" Category="扩展" />
<Column Name="CreateTime" ColumnName="create_time" DataType="DateTime" Nullable="False" Description="时间" />
<Column Name="Remark" DataType="String" Length="2000" Description="详细信息" />
</Columns>
<Indexes>
<Index Name="IX_UserLog_Action_Category_ID" Columns="Action,Category,ID" />
<Index Name="IX_UserLog_Category_LinkID_ID" Columns="Category,LinkID,ID" />
<Index Name="IX_UserLog_CreateUserID_ID" Columns="CreateUserID,ID" />
</Indexes>
</Table>
<Table Name="MemberLog" TableName="member_log" Description="成员日志" ConnName="Log">
<Columns>
<Column Name="ID" DataType="Int64" Identity="True" PrimaryKey="True" Description="编号" />
<Column Name="Ds" DataType="String" DataScale="time" Description="数据分区" />
<Column Name="Category" DataType="String" Description="类别" />
<Column Name="Action" DataType="String" Description="操作" />
<Column Name="LinkID" ColumnName="link_id" DataType="Int32" Description="链接" />
<Column Name="Success" DataType="Boolean" Description="成功" />
<Column Name="UserName" ColumnName="user_name" DataType="String" Description="用户名" />
<Column Name="Ex1" DataType="Int32" Description="扩展1" Category="扩展" />
<Column Name="Ex2" DataType="Int32" Description="扩展2" Category="扩展" />
<Column Name="Ex3" DataType="Double" Description="扩展3" Category="扩展" />
<Column Name="Ex4" DataType="String" Description="扩展4" Category="扩展" />
<Column Name="Ex5" DataType="String" Description="扩展5" Category="扩展" />
<Column Name="Ex6" DataType="String" Description="扩展6" Category="扩展" />
<Column Name="TraceId" ColumnName="trace_id" DataType="String" Description="性能追踪。用于APM性能追踪定位还原该事件的调用链" />
<Column Name="CreateUser" ColumnName="create_user" DataType="String" Description="创建者" Category="扩展" />
<Column Name="CreateUserID" ColumnName="create_user_id" DataType="Int32" Map="User@Id@$" Description="创建用户" Category="扩展" />
<Column Name="CreateIP" ColumnName="create_ip" DataType="String" Description="创建地址" Category="扩展" />
<Column Name="CreateTime" ColumnName="create_time" DataType="DateTime" Nullable="False" Description="时间" />
<Column Name="Remark" DataType="String" Length="2000" Description="详细信息" />
</Columns>
<Indexes>
<Index Name="IX_MemberLog_Action_Category_ID" Columns="Action,Category,ID" />
<Index Name="IX_MemberLog_Category_LinkID_ID" Columns="Category,LinkID,ID" />
<Index Name="IX_MemberLog_CreateUserID_ID" Columns="CreateUserID,ID" />
</Indexes>
</Table>
</Tables> </Tables>
</EntityModel> </EntityModel>

View File

@ -288,6 +288,17 @@ public partial class Log
} }
#endregion #endregion
#region
/// <summary>清理指定时间段内的数据</summary>
/// <param name="start">开始时间。未指定时清理小于指定时间的所有数据</param>
/// <param name="end">结束时间</param>
/// <returns>清理行数</returns>
public static Int32 DeleteWith(DateTime start, DateTime end)
{
return Delete(_.ID.Between(start, end, Meta.Factory.Snow));
}
#endregion
#region #region
/// <summary>取得日志字段信息的快捷方式</summary> /// <summary>取得日志字段信息的快捷方式</summary>
public partial class _ public partial class _

View File

@ -13,23 +13,10 @@
<Compile Remove="Code\class_user_normal.cs" /> <Compile Remove="Code\class_user_normal.cs" />
<Compile Remove="Code\class_user_pure.cs" /> <Compile Remove="Code\class_user_pure.cs" />
<Compile Remove="Code\class_user_save.cs" /> <Compile Remove="Code\class_user_save.cs" />
<Compile Remove="Code\Dtos\IUser.cs" />
<Compile Remove="Code\Dtos\UserDto.cs" />
<Compile Remove="Code\EntityInterfaces\ILog.cs" />
<Compile Remove="Code\EntityInterfaces\IUser.cs" />
<Compile Remove="Code\EntityModels\LogModel.cs" />
<Compile Remove="Code\EntityModels\UserModel.cs" />
<Compile Remove="Code\Entity\日志.Biz.cs" />
<Compile Remove="Code\Entity\日志.cs" />
<Compile Remove="Code\Entity\用户.Biz.cs" />
<Compile Remove="Code\Entity\用户.Biz2.cs" />
<Compile Remove="Code\Entity\用户.cs" />
<Compile Remove="Code\entity_log_normal.cs" /> <Compile Remove="Code\entity_log_normal.cs" />
<Compile Remove="Code\entity_log_normal_biz.cs" /> <Compile Remove="Code\entity_log_normal_biz.cs" />
<Compile Remove="Code\entity_user_normal.cs" /> <Compile Remove="Code\entity_user_normal.cs" />
<Compile Remove="Code\entity_user_normal_biz.cs" /> <Compile Remove="Code\entity_user_normal_biz.cs" />
<Compile Remove="Code\Models\IUserModel.cs" />
<Compile Remove="Code\Models\UserModel.cs" />
<Compile Remove="DataAccessLayer\DAL_EnvironmentVariable.cs" /> <Compile Remove="DataAccessLayer\DAL_EnvironmentVariable.cs" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
@ -48,6 +35,32 @@
<EmbeddedResource Include="Configuration\AreaX.sql" /> <EmbeddedResource Include="Configuration\AreaX.sql" />
<EmbeddedResource Include="TestEntity\MenuX.sql" /> <EmbeddedResource Include="TestEntity\MenuX.sql" />
</ItemGroup> </ItemGroup>
<ItemGroup>
<Compile Remove="Code\Dtos\**" />
<None Include="Code\Dtos\**">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<Compile Remove="Code\Entity\**" />
<None Include="Code\Entity\**">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<Compile Remove="Code\EntityInterfaces\**" />
<None Include="Code\EntityInterfaces\**">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<Compile Remove="Code\EntityModels\**" />
<None Include="Code\EntityModels\**">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<Compile Remove="Code\EntityModels\**" />
<None Include="Code\EntityModels\**">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<Compile Remove="Code\Models\**" />
<None Include="Code\Models\**">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
</ItemGroup>
<ItemGroup> <ItemGroup>
<None Include="Code\BuildTT\UserTT.cs"> <None Include="Code\BuildTT\UserTT.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
@ -61,39 +74,6 @@
<None Include="Code\class_user_save.cs"> <None Include="Code\class_user_save.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None> </None>
<None Include="Code\Dtos\IUser.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\Dtos\UserDto.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\EntityInterfaces\ILog.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\EntityInterfaces\IUser.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\EntityModels\LogModel.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\EntityModels\UserModel.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\Entity\日志.Biz.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\Entity\日志.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\Entity\用户.Biz2.cs">
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
</None>
<None Include="Code\Entity\用户.Biz.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\Entity\用户.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\entity_log_normal.cs"> <None Include="Code\entity_log_normal.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None> </None>
@ -109,12 +89,6 @@
<None Include="Code\class_user_normal.cs"> <None Include="Code\class_user_normal.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory> <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None> </None>
<None Include="Code\Models\IUserModel.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
<None Include="Code\Models\UserModel.cs">
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
</None>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.10.0" /> <PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.10.0" />