using SqlSugar; using System; using System.Collections.Generic; using System.Linq; using System.Reflection; using System.Text; using System.Threading.Tasks; namespace OrmTest { public class DemoH_Tenant { public static void Init() { Console.WriteLine(""); Console.WriteLine("#### SimpleClient Start ####"); var rep1=new Repository(); rep1.GetList(); var rep2 = rep1.ChangeRepository>(); Console.WriteLine("#### SimpleClient End ####"); } public class Repository : SimpleClient where T : class, new() { public Repository(ISqlSugarClient context = null) : base(context)//注意这里要有默认值等于null { if (context == null) { var db = new SqlSugarClient(new List { new ConnectionConfig() { ConfigId=1, DbType = SqlSugar.DbType.SqlServer, InitKeyType = InitKeyType.Attribute, IsAutoCloseConnection = true, ConnectionString = Config.ConnectionString }, new ConnectionConfig() { ConfigId="2", DbType = SqlSugar.DbType.SqlServer, InitKeyType = InitKeyType.Attribute, IsAutoCloseConnection = true, ConnectionString = Config.ConnectionString2 } }); var configId = typeof(T).GetCustomAttribute().configId; base.Context = db.GetConnection(configId); base.Context.CodeFirst.InitTables(); db.Aop.OnLogExecuting = (s, p) => { Console.WriteLine(s); }; } } /// /// 扩展方法,自带方法不能满足的时候可以添加新方法 /// /// public List CommQuery(string sql) { //base.Context.Queryable().ToList();可以拿到SqlSugarClient 做复杂操作 return base.Context.Queryable().Where(sql).ToList(); } } [TenantAttribute("1")] public class C1Table { public string Id { get; set; } } [TenantAttribute("2")] public class C2Table { public string Id { get; set; } } } }