From c8017efb9b2c37d7de53fb57c1dff5c21444a091 Mon Sep 17 00:00:00 2001 From: sunkaixuan <610262374@qq.com> Date: Sun, 27 Feb 2022 00:24:12 +0800 Subject: [PATCH] Update core --- .../SqlSeverTest/CustomDbTest/Config.cs | 31 + .../CustomDbTest/CustomDbTest.csproj | 21 + .../CustomDbTest/Demo0_SqlSugarClient.cs | 454 ++++++++++++++ .../CustomDbTest/Demo1_Queryable.cs | 573 ++++++++++++++++++ .../CustomDbTest/Demo2_Updateable.cs | 118 ++++ .../CustomDbTest/Demo3_Insertable.cs | 326 ++++++++++ .../CustomDbTest/Demo4_Deleteable.cs | 59 ++ .../CustomDbTest/DemoD_DbFirst.cs | 75 +++ .../CustomDbTest/Models/AttributeTable.cs | 20 + .../CustomDbTest/Models/Custom.cs | 14 + .../CustomDbTest/Models/DataDictionary.cs | 34 ++ .../CustomDbTest/Models/EntityMapper.cs | 15 + .../CustomDbTest/Models/Mapper.cs | 56 ++ .../SqlSeverTest/CustomDbTest/Models/Order.cs | 24 + .../CustomDbTest/Models/OrderItem.cs | 20 + .../CustomDbTest/Models/SubInsertTest.cs | 108 ++++ .../CustomDbTest/Models/TestTree.cs | 17 + .../SqlSeverTest/CustomDbTest/Models/Tree.cs | 20 + .../CustomDbTest/Models/ViewOrder.cs | 13 + .../SqlSeverTest/CustomDbTest/Program.cs | 32 + .../SqlSeverTest/CustomDbTest/Test.accdb | Bin 0 -> 565248 bytes .../SqlSeverTest/SqlSeverTest.sln | 80 +++ 22 files changed, 2110 insertions(+) create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Config.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/CustomDbTest.csproj create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo0_SqlSugarClient.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo1_Queryable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo2_Updateable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo3_Insertable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo4_Deleteable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/DemoD_DbFirst.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/AttributeTable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Custom.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/DataDictionary.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/EntityMapper.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Mapper.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Order.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/OrderItem.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/SubInsertTest.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/TestTree.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Tree.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/ViewOrder.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Program.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Test.accdb diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Config.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Config.cs new file mode 100644 index 000000000..6db01b79f --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Config.cs @@ -0,0 +1,31 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + /// + /// Setting up the database name does not require you to create the database + /// 只需要设置IP和账户密码 ,自动建库 + /// + public class Config + { + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString = "server=localhost;Database=SqlSugar4xTest;Uid=root;Pwd=haosql; AllowLoadLocalInfile=true"; + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString2 = "server=localhost;Database=SqlSugar4xTest2;Uid=root;Pwd=haosql"; + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString3 = "server=localhost;Database=SqlSugar4xTest3;Uid=root;Pwd=haosql"; + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/CustomDbTest.csproj b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/CustomDbTest.csproj new file mode 100644 index 000000000..1022e0b54 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/CustomDbTest.csproj @@ -0,0 +1,21 @@ + + + + Exe + netcoreapp3.1 + AnyCPU;ARM32 + + + + + + + + + + + Always + + + + diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo0_SqlSugarClient.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo0_SqlSugarClient.cs new file mode 100644 index 000000000..3c9597a88 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo0_SqlSugarClient.cs @@ -0,0 +1,454 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel.DataAnnotations; +using System.ComponentModel.DataAnnotations.Schema; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using SqlSugar; +namespace OrmTest +{ + public class Demo0_SqlSugarClient + { + + public static void Init() + { + SqlSugarClient();//Create db + DbContext();//Optimizing SqlSugarClient usage + SingletonPattern();//Singleten Pattern + DistributedTransactionExample(); + MasterSlave();//Read-write separation + CustomAttribute(); + } + + private static void MasterSlave() + { + Console.WriteLine(""); + Console.WriteLine("#### MasterSlave Start ####"); + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + ConnectionString = Config.ConnectionString,//Master Connection + DbType = DbType.Custom, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + SlaveConnectionConfigs = new List() { + new SlaveConnectionConfig() { HitRate=10, ConnectionString=Config.ConnectionString2 } , + new SlaveConnectionConfig() { HitRate=10, ConnectionString=Config.ConnectionString2 } + } + }); + + + db.Aop.OnLogExecuted = (s, p) => + { + Console.WriteLine(db.Ado.Connection.ConnectionString); + }; + Console.WriteLine("Master:"); + db.Insertable(new Order() { Name = "abc", CustomId = 1, CreateTime = DateTime.Now }).ExecuteCommand(); + Console.WriteLine("Slave:"); + db.Queryable().First(); + Console.WriteLine("#### MasterSlave End ####"); + } + + private static void SqlSugarClient() + { + //Create db + Console.WriteLine("#### SqlSugarClient Start ####"); + + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Custom, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + AopEvents = new AopEvents + { + OnLogExecuting = (sql, p) => + { + Console.WriteLine(sql); + Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); + } + } + }); + + //If no exist create datebase + //db.DbMaintenance.CreateDatabase(); + + //Use db query + var dt = db.Ado.GetDataTable("select 1"); + + //Create tables + db.CodeFirst.InitTables(typeof(OrderItem),typeof(Order)); + var id = db.Insertable(new Order() { Name = "order1", CustomId = 1, Price = 0, CreateTime = DateTime.Now }).ExecuteReturnIdentity(); + + //Insert data + db.Insertable(new OrderItem() { OrderId = id, Price = 0, CreateTime=DateTime.Now }).ExecuteCommand(); + Console.WriteLine("#### SqlSugarClient End ####"); + + } + + private static void DbContext() + { + Console.WriteLine(""); + Console.WriteLine("#### DbContext Start ####"); + var insertObj = new Order { Name = "jack", CreateTime = DateTime.Now }; + var InsertObjs = new Order[] { insertObj }; + + DbContext context = new DbContext(); + + context.Db.CodeFirst.InitTables();//Create Tables + ; + var orderDb = context.OrderDb; + + //Select + var data1 = orderDb.GetById(1); + var data2 = orderDb.GetList(); + var data3 = orderDb.GetList(it => it.Id == 1); + var data4 = orderDb.GetSingle(it => it.Id == 1); + var p = new PageModel() { PageIndex = 1, PageSize = 2 }; + var data5 = orderDb.GetPageList(it => it.Name == "xx", p); + Console.Write(p.TotalCount); + var data6 = orderDb.GetPageList(it => it.Name == "xx", p, it => it.Name, OrderByType.Asc); + Console.Write(p.TotalCount); + List conModels = new List(); + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.Equal, FieldValue = "1" });//id=1 + var data7 = orderDb.GetPageList(conModels, p, it => it.Name, OrderByType.Asc); + orderDb.AsQueryable().Where(x => x.Id == 1).ToList(); + + //Insert + orderDb.Insert(insertObj); + orderDb.InsertRange(InsertObjs); + var id = orderDb.InsertReturnIdentity(insertObj); + orderDb.AsInsertable(insertObj).ExecuteCommand(); + + + //Delete + orderDb.Delete(insertObj); + orderDb.DeleteById(11111); + orderDb.DeleteById(new int[] { 1111, 2222 }); + orderDb.Delete(it => it.Id == 1111); + orderDb.AsDeleteable().Where(it => it.Id == 1111).ExecuteCommand(); + + //Update + orderDb.Update(insertObj); + orderDb.UpdateRange(InsertObjs); + orderDb.Update(it => new Order() { Name = "a", }, it => it.Id == 1); + orderDb.AsUpdateable(insertObj).UpdateColumns(it => new { it.Name }).ExecuteCommand(); + + //Use Inherit DbContext + OrderDal dal = new OrderDal(); + var data = dal.GetById(1); + var list = dal.GetList(); + + Console.WriteLine("#### DbContext End ####"); + } + + private static void CustomAttribute() + { + Console.WriteLine(""); + Console.WriteLine("#### Custom Attribute Start ####"); + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + ConnectionString = Config.ConnectionString, + DbType = DbType.Custom, + IsAutoCloseConnection = true, + InitKeyType = InitKeyType.Attribute, + ConfigureExternalServices = new ConfigureExternalServices() + { + EntityService = (property, column) => + { + + var attributes = property.GetCustomAttributes(true);//get all attributes + + if (attributes.Any(it => it is KeyAttribute))// by attribute set primarykey + { + column.IsPrimarykey = true; + } + }, + EntityNameService = (type, entity) => + { + var attributes = type.GetCustomAttributes(true); + if (attributes.Any(it => it is TableAttribute)) + { + entity.DbTableName = (attributes.First(it => it is TableAttribute) as TableAttribute).Name; + } + } + } + }); + db.CodeFirst.InitTables();//Create Table + + db.Insertable(new AttributeTable() { Id = Guid.NewGuid().ToString(), Name = "Name" }).ExecuteCommand(); + var list = db.Queryable().ToList(); + + Console.WriteLine("#### Custom Attribute End ####"); + } + + + private static void SingletonPattern() + { + Console.WriteLine(""); + Console.WriteLine("#### Singleton Pattern Start ####"); + Console.WriteLine("Db_Id:" + singleDb.ContextID); + Console.WriteLine("Db_Id:" + singleDb.ContextID); + var task = new Task(() => + { + Console.WriteLine("Task DbId:" + singleDb.ContextID); + new Task(() => + { + Console.WriteLine("_Task_Task DbId:" + singleDb.ContextID); + Console.WriteLine("_Task_Task DbId:" + singleDb.ContextID); + + }).Start(); + Console.WriteLine("Task DbId:" + singleDb.ContextID); + }); + task.Start(); + task.Wait(); + System.Threading.Thread.Sleep(500); + Console.WriteLine(string.Join(",", singleDb.TempItems.Keys)); + + Console.WriteLine("#### Singleton Pattern end ####"); + } + + static SqlSugarScope singleDb = new SqlSugarScope( + new ConnectionConfig() + { + ConfigId = 1, + DbType = DbType.Custom, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + AopEvents = new AopEvents() + { + OnLogExecuting = (sql, p) => { Console.WriteLine(sql); } + } + }); + + + private static void DistributedTransactionExample() + { + //Console.WriteLine(""); + //Console.WriteLine("#### Distributed TransactionExample Start ####"); + //SqlSugarClient db = new SqlSugarClient(new List() + //{ + // new ConnectionConfig(){ ConfigId="1", DbType=DbType.Custom, ConnectionString=Config.ConnectionString,InitKeyType=InitKeyType.Attribute,IsAutoCloseConnection=true }, + // new ConnectionConfig(){ ConfigId="2", DbType=DbType.Custom, ConnectionString=Config.ConnectionString2 ,InitKeyType=InitKeyType.Attribute ,IsAutoCloseConnection=true} + //}); + + ////use db1 + //db.CodeFirst.SetStringDefaultLength(200).InitTables(typeof(Order), typeof(OrderItem));// + //db.Insertable(new Order() { Name = "order1", CreateTime = DateTime.Now }).ExecuteCommand(); + //Console.WriteLine(db.CurrentConnectionConfig.DbType + ":" + db.Queryable().Count()); + + ////use db2 + //db.ChangeDatabase("2"); + //db.DbMaintenance.CreateDatabase();//Create Database2 + //db.CodeFirst.SetStringDefaultLength(200).InitTables(typeof(Order), typeof(OrderItem)); + //db.Insertable(new Order() { Name = "order1", CreateTime = DateTime.Now }).ExecuteCommand(); + //Console.WriteLine(db.CurrentConnectionConfig.DbType + ":" + db.Queryable().Count()); + + //// Example 1 + //Console.WriteLine("Example 1"); + //try + //{ + // db.BeginTran(); + + // db.ChangeDatabase("1");//use db1 + // db.Deleteable().ExecuteCommand(); + // Console.WriteLine("---Delete all " + db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + + // db.ChangeDatabase("2");//use db2 + // db.Deleteable().ExecuteCommand(); + // Console.WriteLine("---Delete all " + db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + + // throw new Exception(); + // db.CommitTran(); + //} + //catch + //{ + // db.RollbackTran(); + // Console.WriteLine("---Roll back"); + // db.ChangeDatabase("1");//use db1 + // Console.WriteLine(db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + + // db.ChangeDatabase("2");//use db2 + // Console.WriteLine(db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + //} + + + + //// Example 2 + //Console.WriteLine("Example 2"); + + //var result = db.UseTran(() => + //{ + + // db.ChangeDatabase("1");//use db1 + // db.Deleteable().ExecuteCommand(); + // Console.WriteLine("---Delete all " + db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + + // db.ChangeDatabase("2");//use db2 + // db.Deleteable().ExecuteCommand(); + // Console.WriteLine("---Delete all " + db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + // throw new Exception(""); + + //}); + //if (result.IsSuccess == false) + //{ + // Console.WriteLine("---Roll back"); + // db.ChangeDatabase("1");//use db1 + // Console.WriteLine(db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + + // db.ChangeDatabase("2");//use db2 + // Console.WriteLine(db.CurrentConnectionConfig.DbType); + // Console.WriteLine(db.Queryable().Count()); + //} + + //// Example 3 + //Console.WriteLine("Example 3"); + //Task> result2 = AsyncTranDemo(db); + //result2.Wait(); + + //// Example 4 + //Console.WriteLine("Example 4"); + //var mysqldb = db.GetConnection("1");//获取ConfigId为1的数据库对象 + //var sqlServerdb = db.GetConnection("2");//获取默认对象 + //Console.WriteLine(mysqldb.Queryable().Count()); + //Console.WriteLine(sqlServerdb.Queryable().Count()); + //try + //{ + // db.BeginTran(); + + // sqlServerdb.Deleteable().ExecuteCommand(); + // mysqldb.Deleteable().ExecuteCommand(); + // Console.WriteLine(mysqldb.Queryable().Count()); + // Console.WriteLine(sqlServerdb.Queryable().Count()); + + // throw new Exception(""); + // db.CommitTran(); + //} + //catch (Exception) + //{ + // db.RollbackTran();//数据回滚 + // Console.WriteLine(mysqldb.Queryable().Count()); + // Console.WriteLine(sqlServerdb.Queryable().Count()); + //} + //Console.WriteLine("#### Distributed TransactionExample End ####"); + } + + /// + ///Async tran demo + /// + /// + /// + private static async Task> AsyncTranDemo(SqlSugarClient db) + { + //need await all + var result2 =await db.UseTranAsync(async () => + { + //need await all + + db.ChangeDatabase("1");//use db1 + await db.Deleteable().ExecuteCommandAsync(); + Console.WriteLine("---Delete all " + db.CurrentConnectionConfig.DbType); + Console.WriteLine(db.Queryable().Count()); + + db.ChangeDatabase("2");//use db2 + await db.Deleteable().ExecuteCommandAsync(); + Console.WriteLine("---Delete all " + db.CurrentConnectionConfig.DbType); + Console.WriteLine(db.Queryable().Count()); + throw new Exception(""); + + }); + Console.WriteLine("---Roll back"); + db.ChangeDatabase("1");//use sqlserver + Console.WriteLine(db.CurrentConnectionConfig.DbType); + Console.WriteLine(db.Queryable().Count()); + + db.ChangeDatabase("2");//use mysql + Console.WriteLine(db.CurrentConnectionConfig.DbType); + Console.WriteLine(db.Queryable().Count()); + return result2; + } + } + + /// + /// DbContext Example 1 + /// + public class DbContext + { + + public SqlSugarClient Db; + public DbContext() + { + Db = new SqlSugarClient(new ConnectionConfig() + { + ConnectionString = Config.ConnectionString, + DbType = DbType.Custom, + IsAutoCloseConnection = true, + InitKeyType = InitKeyType.Attribute, + AopEvents = new AopEvents() + { + OnLogExecuting = (sql, p) => + { + Console.WriteLine(sql); + } + } + }); + } + public SimpleClient OrderDb => new SimpleClient(Db); + public SimpleClient OrderItemDb => new SimpleClient(Db); + } + + + public class OrderDal : DbContext + { + + } + /// + /// DbContext Example 2 + /// + /// + public class DbContext where T : class, new() + { + + public SqlSugarClient Db; + public DbContext() + { + Db = new SqlSugarClient(new ConnectionConfig() + { + ConnectionString = Config.ConnectionString, + DbType = DbType.Custom, + IsAutoCloseConnection = true, + InitKeyType = InitKeyType.Attribute, + AopEvents = new AopEvents() + { + OnLogExecuting = (sql, p) => + { + Console.WriteLine(sql); + } + } + }); + } + public SimpleClient CurrentDb => new SimpleClient(Db); + public virtual T GetById(int id) + { + return CurrentDb.GetById(id); + } + public virtual List GetList() + { + return CurrentDb.GetList(); + } + public virtual bool Delete(int id) + { + return CurrentDb.DeleteById(id); + } + } + +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo1_Queryable.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo1_Queryable.cs new file mode 100644 index 000000000..9fcd3d05a --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo1_Queryable.cs @@ -0,0 +1,573 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Data; +using System.Dynamic; +using System.Linq; +using System.Text; +namespace OrmTest +{ + public class Demo1_Queryable + { + + public static void Init() + { + EasyExamples(); + //QueryConditions(); + JoinTable(); + //Async(); + //NoEntity(); + //Mapper(); + //SqlFuncTest(); + //Subquery(); + //ReturnType(); + //ConfiQuery(); + } + + private static void ConfiQuery() + { + var db = GetInstance(); + List datas = new List(); + datas.Add(new DataDictionary() { Code="1", Name="男",Type="sex" }); + datas.Add(new DataDictionary() { Code = "2", Name = "女", Type = "sex" }); + datas.Add(new DataDictionary() { Code = "1", Name = "南通市", Type = "city" }); + datas.Add(new DataDictionary() { Code = "2", Name = "苏州市", Type = "city" }); + datas.Add(new DataDictionary() { Code = "1", Name = "江苏省", Type = "province" }); + datas.Add(new DataDictionary() { Code = "2", Name = "湖南省", Type = "province" }); + db.CodeFirst.InitTables(); + db.CodeFirst.InitTables(); + db.DbMaintenance.TruncateTable(); + db.Insertable(datas).ExecuteCommand(); + + if (!db.ConfigQuery.Any()) + { + var types= db.Queryable().Select(it => it.Type).Distinct().ToList(); + foreach (var type in types) + { + db.ConfigQuery.SetTable(it => it.Code, it => it.Name, type, it => it.Type == type); + } + + db.ConfigQuery.SetTable(it => it.Id, it => it.Name, "01", it => it.Id > 1); + db.ConfigQuery.SetTable(it => it.Id, it => it.Name, "02", it => it.Id > 2); + db.ConfigQuery.SetTable(it => it.Id, it => it.Name, null); + } + + + var res=db.Queryable().Select(it => new Person() + { + Id=it.Id.SelectAll(), + SexName=it.SexId.GetConfigValue("sex"), + ProviceName = it.SexId.GetConfigValue("province"), + CityName = it.SexId.GetConfigValue("city"), + }).ToList();//也支持支持写在Where或者Orderby + + var list = db.Queryable().Select(it => new OrderItem + { + ItemId = it.ItemId.SelectAll(), + OrderName = it.OrderId.GetConfigValue("01") + }).ToList(); + var list2 = db.Queryable().Select(it => new OrderItem + { + ItemId = it.ItemId.SelectAll(), + OrderName = it.OrderId.GetConfigValue("02") + }).ToList(); + var list3 = db.Queryable().Select(it => new OrderItem + { + ItemId = it.ItemId.SelectAll(), + OrderName = it.OrderId.GetConfigValue() + }).ToList(); + + var list4 = db.Queryable().Select(it => new OrderItem + { + ItemId = it.ItemId.SelectAll(), + OrderName = it.OrderId.GetConfigValue() + }) + .Where(it=>it.OrderId.GetConfigValue()== "order1") + .OrderBy(it=>it.OrderId.GetConfigValue()).ToList(); + + var list5 = db.Queryable((o, i) => o.Id == i.OrderId) + .OrderBy((o,i)=>i.OrderId.GetConfigValue(),OrderByType.Desc) + .Select((o,i)=>new ViewOrder() { + Id= o.Id.SelectAll(), + Name=i.OrderId.GetConfigValue() + }) + .ToList(); + } + + private static void EasyExamples() + { + Console.WriteLine(""); + Console.WriteLine("#### Examples Start ####"); + var db = GetInstance(); + var dbTime = db.GetDate(); + var getAll = db.Queryable().ToList(); + var getTake = db.Queryable().Take(2).ToList(); + var getSkip = db.Queryable().Skip(2).ToList(); + var getOrderBy = db.Queryable().OrderBy(it => it.Name,OrderByType.Desc).ToList(); + var getOrderBy2 = db.Queryable().OrderBy(it => it.Id).OrderBy(it => it.Name, OrderByType.Desc).ToList(); + var getOrderBy3 = db.Queryable().OrderBy(it =>new { it.Name,it.Id}).ToList(); + var getRandom = db.Queryable().OrderBy(it => SqlFunc.GetRandom()).First(); + var getByPrimaryKey = db.Queryable().InSingle(2); + var getSingleOrDefault = db.Queryable().Where(it => it.Id == 1).Single(); + var getFirstOrDefault = db.Queryable().First(); + var getByWhere = db.Queryable().Where(it => it.Id == 1 || it.Name == "a").ToList(); + var getByWhere2 = db.Queryable().Where(it => it.Id == DateTime.Now.Year).ToList(); + var getByFuns = db.Queryable().Where(it => SqlFunc.IsNullOrEmpty(it.Name)).ToList(); + // var getByFuns2 = db.Queryable().GroupBy(it => it.Name).Select(it => SqlFunc.AggregateDistinctCount(it.Price)).ToList(); + var getDicionary = db.Queryable().ToDictionary(it => it.Id, it => it.Name); + var getDicionaryList = db.Queryable().ToDictionaryList(); + var getTest = db.Queryable().Where(it =>string.IsNullOrWhiteSpace( it.Name)).ToList(); + // var test01 = db.Queryable().PartitionBy(it => it.Id).ToList(); + var q1 = db.Queryable().Take(1); + var q2 = db.Queryable().Take(2); + //var test02 = db.Union(q1, q2).ToList(); + var test03 = db.Queryable().Take(1).ToList(); + var dp = DateTime.Now; + var test05 = db.Queryable().Where(it => it.CreateTime.Month== dp.Month).ToList(); + var test06 = db.Queryable() + .ToPivotTable(it => it.Id, it => it.Name, it => it.Sum(x => x.Price)); + + var test07 = db.Queryable() + .ToPivotList(it => it.Id, it => it.Name, it => it.Sum(x => x.Price)); + + var test08 = db.Queryable() + .ToPivotJson(it => it.Id, it => it.Name, it => it.Sum(x => x.Price)); + + //var test09 = db.Queryable().PartitionBy(it=>it.Id).ToPageListAsync(1,2,0); + //test09.Wait(); + + int c = 0; + var test10 = db.Queryable().OrderBy(it=>it.Id).ToPageList(3,5, ref c); + var test11 = db.Queryable().GroupBy(it=>new { it.CreateTime.Year }).Select(it=>it.CreateTime.Year).ToList(); + // var test12 = db.Queryable().GroupBy(it => it.CreateTime.Date ).Select(it => it.CreateTime.Date).ToList(); + //var test13 = db.Queryable().GroupBy(it => new { it.CreateTime.Date ,it.CreateTime.Year,it.CreateTime.Minute }) + // .Select(it => new { it.CreateTime.Date, it.CreateTime.Year, it.CreateTime.Minute }).ToList(); + //var test14 = db.Queryable() + // .GroupBy(it => it.CreateTime.Year ) + // .GroupBy(it => it.CreateTime.Second) + // .GroupBy(it => it.CreateTime.Date) + // .Select(it => new { + // it.CreateTime.Year, + // it.CreateTime.Second, + // it.CreateTime.Date + // }).ToList(); + var test15 = db.Queryable((o, i) => new JoinQueryInfos( + JoinType.Left, o.Name == SqlFunc.ToString(SqlFunc.MergeString(",", i.Name, ",")) + )) + .Select().ToList(); + // var test16 = db.Queryable().Select(it => SqlFunc.SqlServer_DateDiff("day", DateTime.Now.AddDays(-1), DateTime.Now)).ToList(); + //var test17 = + // db.Queryable() + // .Select() + // .MergeTable() + // .Select(it => new ViewOrder() + // { + // Name = SqlFunc.Subqueryable().Select(s => s.Name) + // }).ToList(); ; + //var test18 = db.UnionAll( + // db.Queryable() , + // db.Queryable() + // ) + // .Select(it=>new ViewOrder(){ + // Name=SqlFunc.Subqueryable().Select(s=>s.Name) + // }).ToList(); + var test19 = db.Queryable().Select().ToList(); + var test20 = db.Queryable().LeftJoin((o, cs) =>o.Id==cs.Id) + .ToDictionary(it => it.Id, it => it.Name); + + //var test21 = db.Queryable().Where(it=>it.Id.ToString()==1.ToString()).Select(it => it.CreateTime.ToString("24")).First(); + Console.WriteLine("#### Examples End ####"); + } + + private static void ReturnType() + { + Console.WriteLine(""); + Console.WriteLine("#### ReturnType Start ####"); + var db = GetInstance(); + List list = db.Queryable().ToList(); + + var x2=db.Ado.SqlQueryAsync("select * from [Order] "); + x2.Wait(); + var x22 = db.Ado.GetScalarAsync("select * from [Order] "); + x22.Wait(); + var x222 = db.Ado.ExecuteCommandAsync("select * from [Order] "); + x222.Wait(); + Order item = db.Queryable().First(it => it.Id == 1); + + DataTable dataTable = db.Queryable().Select(it => it.Id).ToDataTable(); + + var json = db.Queryable().ToJson(); + + List listInt = db.Queryable().Select(it => it.Id).ToList(); + + var dynamic = db.Queryable().Select().ToList(); + + var viewModel = db.Queryable((o, i, c) => new JoinQueryInfos( + JoinType.Left, o.Id == i.OrderId , + JoinType.Left, o.CustomId == c.Id + )) + .Select().ToList(); + + var newDynamic = db.Queryable((o, i, c) => new JoinQueryInfos( + JoinType.Left, o.Id == i.OrderId, + JoinType.Left, o.CustomId == c.Id + )) + .Select((o, i, c) => new { orderName = o.Name, cusName=c.Name }).ToList(); + + var newClass = db.Queryable((o, i, c) => new JoinQueryInfos( + JoinType.Left, o.Id == i.OrderId, + JoinType.Left, o.CustomId == c.Id + )) + .Select((o, i, c) => new ViewOrder { Name=o.Name, CustomName=c.Name }).ToList(); + + + var oneClass = db.Queryable((o, i, c) => new JoinQueryInfos( + JoinType.Left, o.Id == i.OrderId, + JoinType.Left, o.CustomId == c.Id + )) + .Select((o, i, c) => c).ToList(); + + var twoClass = db.Queryable((o, i, c) => new JoinQueryInfos( + JoinType.Left, o.Id == i.OrderId, + JoinType.Left, o.CustomId == c.Id + )) + .Select((o, i, c) => new { o,i}).ToList(); + + List> ListDic = db.Queryable((o, i, c) => new JoinQueryInfos( + JoinType.Left, o.Id == i.OrderId, + JoinType.Left, o.CustomId == c.Id + )) + .Select().ToList().Select(it => it.ToDictionary(x => x.Key, x => x.Value)).ToList(); + Console.WriteLine("#### ReturnType End ####"); + } + + private static void Subquery() + { + Console.WriteLine(""); + Console.WriteLine("#### Subquery Start ####"); + var db = GetInstance(); + + var list = db.Queryable().Take(10).Select(it => new + { + customName=SqlFunc.Subqueryable().Where("it.CustomId=id").Select(s=>s.Name), + customName2 = SqlFunc.Subqueryable().Where("it.CustomId = id").Where(s => true).Select(s => s.Name) + }).ToList(); + + var list1 = db.Queryable().Select(it => new + { + id = SqlFunc.Subqueryable().Where(s => s.Id == 1).Sum(s => s.Id) * 1 + }).ToList(); + + var list2 = db.Queryable().Where(it => + SqlFunc.Subqueryable() + .LeftJoin((i,z)=>i.ItemId==z.ItemId) + .InnerJoin((i,z,y) => i.ItemId == z.ItemId) + .InnerJoin((i,z,y,h) => i.ItemId == z.ItemId) + .InnerJoin((i, z, y, h, n) => i.ItemId == z.ItemId) + .Where((i, z) => i.ItemId == z.ItemId) + .Any() + ).ToList(); + + var list3 = db.Queryable().Select(it => new + { + customName = SqlFunc.Subqueryable().Where(s=>s.Id==it.CustomId).GroupBy(s=>s.Name).Having(s=>SqlFunc.AggregateCount(s.Id)>0).Select(s => s.Name) + }).ToList(); + + + var exp = Expressionable.Create().And(s => s.Id==1).ToExpression(); + var list4 = db.Queryable().Select(it => new + { + customName = SqlFunc.Subqueryable().Where(exp).Where(exp).GroupBy(s => s.Name).Having(s => SqlFunc.AggregateCount(s.Id) > 0).Select(s => s.Name) + }).ToList(); + + + var list5 = db.Queryable().Where(it => + SqlFunc.Subqueryable() + .LeftJoin((i, y) => i.ItemId == y.ItemId) + .InnerJoin((i, z) => i.ItemId == z.ItemId) + .Where(i => i.ItemId == 1) + .Any() + ).ToList(); + Console.WriteLine("#### Subquery End ####"); + } + + private static void SqlFuncTest() + { + Console.WriteLine(""); + Console.WriteLine("#### SqlFunc Start ####"); + var db = GetInstance(); + var index= db.Queryable().Select(it => SqlFunc.CharIndex("a", "cccacc")).First(); + var list = db.Queryable().Select(it =>new ViewOrder() + { + + Id = SqlFunc.AggregateSum(SqlFunc.IF(it.Id > 0).Return(1).End(0)) + }).ToList(); + var list2 = db.Queryable().Where(it=>it.CreateTime.Date==it.CreateTime).Select(it => new + { + date = it.CreateTime.Date, + datetime = DateTime.Now.Date + }).ToList(); + Console.WriteLine("#### SqlFunc End ####"); + } + + private static void Mapper() + { + Console.WriteLine(""); + Console.WriteLine("#### Mapper Start ####"); + var db = GetInstance(); + //Creater Table + db.CodeFirst.InitTables(typeof(Tree)); + db.DbMaintenance.TruncateTable("tree"); + db.Insertable(new Tree() { Id = 1, Name = "root" }).ExecuteCommand(); + db.Insertable(new Tree() { Id = 11, Name = "child1",ParentId=1 }).ExecuteCommand(); + db.Insertable(new Tree() { Id = 12, Name = "child2",ParentId=1 }).ExecuteCommand(); + db.Insertable(new Tree() { Id = 2, Name = "root" }).ExecuteCommand(); + db.Insertable(new Tree() { Id = 22, Name = "child3", ParentId = 2 }).ExecuteCommand(); + + // Same property name mapping,Both entities have parentId + var list = db.Queryable().Mapper(it => it.Parent, it => it.ParentId).ToList(); + + + //If both entities have parentId, I don't want to associate with parentId. + var list1 =db.Queryable() + //parent=(select * from parent where id=it.parentid) + .Mapper(it=>it.Parent,it=>it.ParentId, it=>it.Parent.Id) + //Child=(select * from parent where ParentId=it.id) + .Mapper(it => it.Child, it => it.Id, it => it.Parent.ParentId) + .ToList(); + + + db.Insertable(new Tree() { Id = 222, Name = "child11", ParentId = 11 }).ExecuteCommand(); + var tree = db.Queryable().ToTree(it => it.Child, it => it.ParentId, 0); + var allchilds= db.Queryable().ToChildList(it => it.ParentId, 0); + var allchilds1 = db.Queryable().ToChildList(it => it.ParentId, 1); + var allchilds2= db.Queryable().ToChildList(it => it.ParentId, 2); + var parentList = db.Queryable().ToParentList(it => it.ParentId, 22); + var parentList2 = db.Queryable().ToParentList(it => it.ParentId, 222); + var parentList3 = db.Queryable().ToParentList(it => it.ParentId, 2); + + //one to one + var list2 = db.Queryable().Mapper(it => it.Order, it => it.OrderId).ToList(); + + //one to many + var list3 = db.Queryable().Mapper(it => it.Items, it => it.Items.First().OrderId).ToList(); + + //many to many + db.CodeFirst.InitTables(); + + db.Insertable(new A() { Name = "A" }).ExecuteCommand(); + db.Insertable(new B() { Name = "B" }).ExecuteCommand(); + db.Insertable(new ABMapping() { AId = 1, BId = 1 }).ExecuteCommand(); + + var list4 = db.Queryable() + .Mapper(it => it.A, it => it.AId) + .Mapper(it => it.B, it => it.BId).ToList(); + + //Manual mode + var result = db.Queryable().Take(10).Select().Mapper((itemModel, cache) => + { + var allItems = cache.Get(orderList => { + var allIds = orderList.Select(it => it.Id).ToList(); + return db.Queryable().Where(it => allIds.Contains(it.OrderId)).ToList();//Execute only once + }); + itemModel.Items = allItems.Where(it => it.OrderId==itemModel.Id).ToList();//Every time it's executed + }).ToList(); + + Console.WriteLine("#### End Start ####"); + } + + private static void NoEntity() + { + Console.WriteLine(""); + Console.WriteLine("#### No Entity Start ####"); + var db = GetInstance(); + + var list = db.Queryable().AS("order ").Where("id=id", new { id = 1 }).ToList(); + + var list2 = db.Queryable("o").AS("order").AddJoinInfo("OrderDetail", "i", "o.id=i.OrderId").Where("id=id", new { id = 1 }).Select("o.*").ToList(); + Console.WriteLine("#### No Entity End ####"); + } + + private static void JoinTable() + { + Console.WriteLine(""); + Console.WriteLine("#### Join Table Start ####"); + var db = GetInstance(); + + //Simple join + var list = db.Queryable((o, i, c) => o.Id == i.OrderId&&c.Id == o.CustomId) + .Select() + .ToList(); + + // //Join table + // var list2 = db.Queryable((o, i, c) => new JoinQueryInfos( + // JoinType.Left, o.Id == i.OrderId, + // JoinType.Left, c.Id == o.CustomId + // )) + //.Select().ToList(); + + //Join queryable + var query1 = db.Queryable((o, i) => new JoinQueryInfos( + JoinType.Left, o.Id == i.OrderId + )) + .Where(o => o.Name == "jack"); + + var query2 = db.Queryable(); + var list3=db.Queryable(query1, query2,JoinType.Left, (p1, p2) => p1.CustomId == p2.Id).Select().ToList(); + + + var query3 = db.Union( + db.Queryable().Where(it => it.Name.Contains("a")), + db.Queryable().Where(it => it.Name.Contains("b")) + ).ToList(); + + + + //var query4 = db.Queryable( + // db.Queryable().Where(it => it.Name.Contains("a")), + // db.Queryable().Where(it => it.CreateTime>DateTime.Now), + // db.Queryable().Where(it => it.Name.Contains("b")), + // JoinType.Left, (o, i, c) => o.Id==i.OrderId, + // JoinType.Left,(o,i,c)=>o.CustomId==c.Id + + // ).Select(o=>o).ToList(); + + + //var query5 = db.Queryable() + // .InnerJoin((o, cus) => o.CustomId == cus.Id) + // .InnerJoin((o, cus, oritem) => o.Id == oritem.OrderId) + // .Where((o) => o.Id == 1) + // .Select((o, cus) => new ViewOrder { Id=o.Id, CustomName = cus.Name }) + // .ToList(); + + //var query6 = db.Queryable(db.Queryable()).LeftJoin((m, i) => m.Id == i.OrderId) + // .ToList(); + + + //var query7 = db.Queryable(db.Queryable().Select().MergeTable()).LeftJoin((m, i) => m.Id == i.OrderId) + // .ToList(); + + + //var query8 = db.Queryable() + // .LeftJoin(db.Queryable().Where(it=>it.Id==1),(o,i)=>o.CustomId==i.Id) + // .LeftJoin(db.Queryable().Where(it=>it.OrderId==2),(o,i,item)=>item.OrderId==o.Id) + // .LeftJoin(db.Queryable().Where(it => it.Id >0), (o, i, item, od) => od.Id == o.Id) + // .Select(o => o).ToList(); + + Console.WriteLine("#### Join Table End ####"); + } + + private static void QueryConditions() + { + Console.WriteLine(""); + Console.WriteLine("#### Query Conditions Start ####"); + + SqlSugarClient db = GetInstance(); + + /*** By expression***/ + + //id=@id + var list = db.Queryable().Where(it => it.Id == 1).ToList(); + //id=@id or name like '%'+@name+'%' + var list2 = db.Queryable().Where(it => it.Id == 1 || it.Name.Contains("jack")).ToList(); + + + //Create expression + var exp = Expressionable.Create() + .And(it => it.Id == 1) + .Or(it => it.Name.Contains("jack")).ToExpression(); + var list3 = db.Queryable().Where(exp).ToList(); + + + /*** By sql***/ + + //id=@id + var list4 = db.Queryable().Where("id=@id", new { id = 1 }).ToList(); + //id=@id or name like '%'+@name+'%' + var list5 = db.Queryable().Where("id=@id or name like '%'+@name+'%' ", new { id = 1, name = "jack" }).ToList(); + + + + /*** By dynamic***/ + + //id=1 + var conModels = new List(); + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.Equal, FieldValue = "1" });//id=1 + var student = db.Queryable().Where(conModels).ToList(); + + //Complex use case + List Order = new List(); + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.Equal, FieldValue = "1" });//id=1 + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.Like, FieldValue = "1" });// id like '%1%' + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.IsNullOrEmpty }); + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.In, FieldValue = "1,2,3" }); + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.NotIn, FieldValue = "1,2,3" }); + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.NoEqual, FieldValue = "1,2,3" }); + conModels.Add(new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.IsNot, FieldValue = null });// id is not null + + conModels.Add(new ConditionalCollections() + { + ConditionalList = new List>()// (id=1 or id=2 and id=1) + { + //new KeyValuePair( WhereType.And ,new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.Equal, FieldValue = "1" }), + new KeyValuePair (WhereType.Or,new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.Equal, FieldValue = "2" }), + new KeyValuePair ( WhereType.And,new ConditionalModel() { FieldName = "id", ConditionalType = ConditionalType.Equal, FieldValue = "2" }) + } + }); + var list6 = db.Queryable().Where(conModels).ToList(); + + /*** Conditional builder ***/ + + // use whereif + string name = ""; + int id = 1; + var query = db.Queryable() + .WhereIF(!string.IsNullOrEmpty(name), it => it.Name.Contains(name)) + .WhereIF(id > 0, it => it.Id == id).ToList(); + //clone new Queryable + var query2 = db.Queryable().Where(it => it.Id == 1); + var list7 = query2.Clone().Where(it => it.Name == "jack").ToList();//id=1 and name = jack + var list8 = query2.Clone().Where(it => it.Name == "tom").ToList();//id=1 and name = tom + + Console.WriteLine("#### Condition Screening End ####"); + + + + } + + private static void Async() + { + Console.WriteLine(""); + Console.WriteLine("#### Async Start ####"); + + SqlSugarClient db = GetInstance(); + var task1 = db.Queryable().FirstAsync(); + task1.Wait(); + var task2 = db.Queryable().Where(it => it.Id == 1).ToListAsync(); + + + task2.Wait(); + + Console.WriteLine("#### Async End ####"); + } + + private static SqlSugarClient GetInstance() + { + return new SqlSugarClient(new ConnectionConfig() + { + DbType = SqlSugar.DbType.Custom, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + AopEvents = new AopEvents + { + OnLogExecuting = (sql, p) => + { + Console.WriteLine(sql); + Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); + } + } + }); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo2_Updateable.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo2_Updateable.cs new file mode 100644 index 000000000..f32584fd8 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo2_Updateable.cs @@ -0,0 +1,118 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo2_Updateable + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Updateable Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Custom, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + AopEvents = new AopEvents + { + OnLogExecuting = (sql, p) => + { + Console.WriteLine(sql); + Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); + } + } + }); + + + + /*** 1.entity or List ***/ + + var updateObj = new Order() { Id = 1, Name = "order1" }; + //var updateObjs = new List { + // new Order() { Id = 11, Name = "order11" }, + // new Order() { Id = 12, Name = "order12" } + //}; + + //update all columns by primary key + var result = db.Updateable(updateObj).ExecuteCommand();//update single + //var result2 = db.Updateable(updateObjs).ExecuteCommand();//update List + + //Ignore Name and Price + var result3 = db.Updateable(updateObj).IgnoreColumns(it => new { it.CreateTime, it.Price }).ExecuteCommand(); + + //only update Name and CreateTime + var result4 = db.Updateable(updateObj).UpdateColumns(it => new { it.Name, it.CreateTime }).ExecuteCommand(); + + //If there is no primary key + var result5 = db.Updateable(updateObj).WhereColumns(it => new { it.Id }).ExecuteCommand();//update single by id + //var result6 = db.Updateable(updateObjs).WhereColumns(it => new { it.Id }).ExecuteCommand();//update List by id + + //Re set value + //var result66 = db.Updateable(new List { updateObj }).ReSetValue(it => it.Id = 112).IgnoreColumns(it => new { it.CreateTime, it.Price }).ExecuteCommand(); + + + + /*** 2.by expression ***/ + + //update name,createtime + var result7 = db.Updateable(it => new Order() { Name = "a", CreateTime = DateTime.Now }).Where(it => it.Id == 11).ExecuteCommand(); + var result71 = db.Updateable().SetColumns(it => new Order() { Name = "a", CreateTime = DateTime.Now }).Where(it => it.Id == 11).ExecuteCommand(); + //only update name + var result8 = db.Updateable(it => it.Name == "Name" + "1").Where(it => it.Id == 1).ExecuteCommand(); + var result81 = db.Updateable().SetColumns(it => it.Name == "Name" + "1").Where(it => it.Id == 1).ExecuteCommand(); + // + + + + + /*** 3.by Dictionary ***/ + var dt = new Dictionary(); + dt.Add("id", 1); + dt.Add("name", "abc"); + dt.Add("createTime", DateTime.Now); + var dtList = new List>(); + dtList.Add(dt); + + + // var t666 = db.Updateable(dtList).AS("[Order]").WhereColumns("id").ExecuteCommand(); + + + + /*** 4.Other instructions ***/ + + var caseValue = "1"; + //Do not update NULL columns + db.Updateable(updateObj).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommand(); + + //if 1 update name else if 2 update name,createtime + db.Updateable(updateObj) + .UpdateColumnsIF(caseValue == "1", it => new { it.Name }) + .UpdateColumnsIF(caseValue == "2", it => new { it.Name, it.CreateTime }) + .ExecuteCommand(); + //Use Lock + db.Updateable(updateObj).With(SqlWith.UpdLock).ExecuteCommand(); + + //Where Sql + //db.Updateable(updateObj).Where("id=@x", new { x = "1" }).ExecuteCommand(); + + + var levelCode = "123213123131321"; + db.Updateable(a => a.Name == "a") + .Where(a => SqlFunc.StartsWith(a.Name, levelCode)) + .AddQueue(); + db.SaveQueues(); + + //var dataTable = db.Queryable().Select("id,name,1 as price").Take(2).ToDataTable(); + //db.Fastest().BulkUpdate("Order", dataTable,new string[] {"id" },new string[] {"name" }); + Console.WriteLine("#### Updateable End ####"); + } + + } +} \ No newline at end of file diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo3_Insertable.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo3_Insertable.cs new file mode 100644 index 000000000..b5ac40e31 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo3_Insertable.cs @@ -0,0 +1,326 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo3_Insertable + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Insertable Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Custom, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + AopEvents = new AopEvents + { + OnLogExecuting = (sql, p) => + { + Console.WriteLine(sql); + Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); + } + } + }); + + var insertObj = new Order() { Id = 1, Name = "order1", Price = 0 }; + //var insertObjs = new List { + // new Order() { Id = 11, Name = "XX", Price=0 }, + // new Order() { Id = 12, Name = "XX2" , Price=0} + //}; + + //var x=db.Insertable(insertObjs).RemoveDataCache().IgnoreColumns(it=>it.CreateTime).UseParameter().ExecuteCommand(); + + //Ignore CreateTime + db.Insertable(insertObj).IgnoreColumns(it => new { it.CreateTime }).ExecuteReturnIdentity();//get identity + db.Insertable(insertObj).IgnoreColumns("CreateTime").ExecuteReturnIdentity(); + + //Only insert Name and Price + db.Insertable(insertObj).InsertColumns(it => new { it.Name, it.Price }).ExecuteReturnIdentity(); + db.Insertable(insertObj).InsertColumns("Name", "Price").ExecuteReturnIdentity(); + + //ignore null columns + // db.Insertable(insertObjs).ExecuteCommand();//get change row count + + //Use Lock + db.Insertable(insertObj).With(SqlWith.UpdLock).ExecuteCommand(); + + //insertObjs = new List { + // new Order() { Id = 11, Name = "order11", Price=1 }, + // new Order() { Id = 12, Name = "order12" , Price=20, CreateTime=DateTime.Now, CustomId=1} + //}; + //db.Insertable(insertObjs).UseSqlServer().ExecuteBulkCopy(); + var dt = db.Queryable().Take(5).ToDataTable(); + dt.TableName = "Order"; + //db.Insertable(dt).UseSqlServer().ExecuteBulkCopy(); + // db.CodeFirst.InitTables(); + // db.CodeFirst.InitTables(); + // db.DbMaintenance.TruncateTable("RootTable0"); + // db.DbMaintenance.TruncateTable("TwoItem"); + // db.DbMaintenance.TruncateTable("TwoItem2"); + // db.DbMaintenance.TruncateTable("TwoItem3"); + // db.DbMaintenance.TruncateTable("ThreeItem2"); + // Console.WriteLine("SubInsert Start"); + + // db.Insertable(new Order() + // { + // Name = "订单 1", + // CustomId = 1, + // Price = 100, + // CreateTime = DateTime.Now, + // Id = 0, + // Items = new List() { + // new OrderItem(){ + // CreateTime=DateTime.Now, + // OrderId=0, + // Price=1, + // ItemId=1 + // }, + // new OrderItem(){ + // CreateTime=DateTime.Now, + // OrderId=0, + // Price=2, + // ItemId=2 + // } + // } + // }) + // .AddSubList(it => it.Items.First().OrderId).ExecuteCommand(); + + + + // db.Insertable(new List() { + // new RootTable0() + // { + // Name="aa", + // TwoItem2=new TwoItem2() { + // Id="1", + // ThreeItem2=new List(){ + // new ThreeItem2(){ Name="a", TwoItem2Id="1" }, + // new ThreeItem2(){ Id=2, Name="a2", TwoItem2Id="2" } + // } + // }, + // TwoItem=new TwoItem() + // { + // Name ="itema" , + // RootId=2 + // }, + // TwoItem3=new List(){ + // new TwoItem3(){ Id=0, Name="a",Desc="" }, + + // } + // }, + // new RootTable0() + // { + // Name="bb", + // TwoItem2=new TwoItem2() { + // Id="2" + // }, + // TwoItem=new TwoItem() + // { + // Name ="itemb" , + // RootId=2, + + // }, + // TwoItem3=new List(){ + // new TwoItem3(){ Id=1, Name="b",Desc="" }, + // new TwoItem3(){ Id=2, Name="b1",Desc="1" }, + // } + // } + // }) + //.AddSubList(it => it.TwoItem.RootId) + //.AddSubList(it => new SubInsertTree() + //{ + // Expression = it.TwoItem2.RootId, + // ChildExpression = new List() { + // new SubInsertTree(){ + // Expression=it.TwoItem2.ThreeItem2.First().TwoItem2Id + // } + // } + //}) + //.AddSubList(it => it.TwoItem3) + //.ExecuteCommand(); + + // SubNoIdentity(db); + // SubIdentity(db); + + + + + //db.Fastest().BulkCopy(insertObjs); + + + //var dataTable= db.Queryable().Select("id,name,Price").Take(2).ToDataTable(); + //int result= db.Fastest().BulkCopy("order", dataTable); + Console.WriteLine("#### Insertable End ####"); + + } + + private static void SubNoIdentity(SqlSugarClient db) + { + db.CodeFirst.InitTables(); + db.DbMaintenance.TruncateTable("Country"); + db.DbMaintenance.TruncateTable("Province"); + db.DbMaintenance.TruncateTable("City"); + db.Insertable(new List() + { + new Country(){ + Id=1, + Name="中国", + Provinces=new List(){ + new Province{ + Id=1001, + Name="江苏", + citys=new List(){ + new City(){ Id=1001001, Name="南通" }, + new City(){ Id=1001002, Name="南京" } + } + }, + new Province{ + Id=1002, + Name="上海", + citys=new List(){ + new City(){ Id=1002001, Name="徐汇" }, + new City(){ Id=1002002, Name="普陀" } + } + }, + new Province{ + Id=1003, + Name="北京", + citys=new List(){ + new City(){ Id=1003001, Name="北京A" }, + new City(){ Id=1003002, Name="北京B" } + } + } + } + }, + new Country(){ + Name="美国", + Id=2, + Provinces=new List() + { + new Province(){ + Name="美国小A", + Id=20001 + }, + new Province(){ + Name="美国小b", + Id=20002 + } + } + }, + new Country(){ + Name="英国", + Id=3 + } + }) + .AddSubList(it => new SubInsertTree() + { + Expression = it.Provinces.First().CountryId, + ChildExpression = new List() { + new SubInsertTree(){ + Expression=it.Provinces.First().citys.First().ProvinceId + } + } + }) + .ExecuteCommand(); + + var list = db.Queryable() + .Mapper(it => it.Provinces, it => it.Provinces.First().CountryId) + .Mapper(it => + { + foreach (var item in it.Provinces) + { + item.citys = db.Queryable().Where(y => y.ProvinceId == item.Id).ToList(); + } + }) + .ToList(); + } + private static void SubIdentity(SqlSugarClient db) + { + db.CodeFirst.InitTables(); + db.DbMaintenance.TruncateTable("Country1"); + db.DbMaintenance.TruncateTable("Province1"); + db.DbMaintenance.TruncateTable("City1"); + db.Insertable(new List() + { + new Country1(){ + Id=1, + Name="中国", + Provinces=new List(){ + new Province1{ + Id=1001, + Name="江苏", + citys=new List(){ + new City1(){ Id=1001001, Name="南通" }, + new City1(){ Id=1001002, Name="南京" } + } + }, + new Province1{ + Id=1002, + Name="上海", + citys=new List(){ + new City1(){ Id=1002001, Name="徐汇" }, + new City1(){ Id=1002002, Name="普陀" } + } + }, + new Province1{ + Id=1003, + Name="北京", + citys=new List(){ + new City1(){ Id=1003001, Name="北京A" }, + new City1(){ Id=1003002, Name="北京B" } + } + } + } + }, + new Country1(){ + Name="美国", + Id=2, + Provinces=new List() + { + new Province1(){ + Name="美国小A", + Id=20001 + }, + new Province1(){ + Name="美国小b", + Id=20002 + } + } + }, + new Country1(){ + Name="英国", + Id=3 + } + }) + .AddSubList(it => new SubInsertTree() + { + Expression = it.Provinces.First().CountryId, + ChildExpression = new List() { + new SubInsertTree(){ + Expression=it.Provinces.First().citys.First().ProvinceId + } + } + }) + .ExecuteCommand(); + + var list = db.Queryable() + .Mapper(it => it.Provinces, it => it.Provinces.First().CountryId) + .Mapper(it => + { + foreach (var item in it.Provinces) + { + item.citys = db.Queryable().Where(y => y.ProvinceId == item.Id).ToList(); + } + }) + .ToList(); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo4_Deleteable.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo4_Deleteable.cs new file mode 100644 index 000000000..a36b58cd4 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Demo4_Deleteable.cs @@ -0,0 +1,59 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo4_Deleteable + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Deleteable Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Custom, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + AopEvents = new AopEvents + { + OnLogExecuting = (sql, p) => + { + Console.WriteLine(sql); + Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); + } + } + }); + //by entity + db.Deleteable().Where(new Order() { Id = 1111 }).ExecuteCommand(); + + //by primary key + db.Deleteable().In(1111).ExecuteCommand(); + + //by primary key array + db.Deleteable().In(new int[] { 1111, 2222 }).ExecuteCommand(); + + //by expression + db.Deleteable().Where(it => it.Id == 11111).ExecuteCommand(); + + //logic delete + db.CodeFirst.InitTables(); + ; + db.Deleteable().Where(it=>it.Id==1).IsLogic().ExecuteCommand(); + Console.WriteLine("#### Deleteable End ####"); + + } + } + public class LogicTest + { + [SugarColumn(IsPrimaryKey =true,IsIdentity =true)] + public int Id { get; set; } + + public bool isdeleted { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/DemoD_DbFirst.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/DemoD_DbFirst.cs new file mode 100644 index 000000000..eb9494007 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/DemoD_DbFirst.cs @@ -0,0 +1,75 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + public class DemoD_DbFirst + { + public static void Init() + { + Console.WriteLine(); + Console.WriteLine("#### DbFirst Start ####"); + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Custom, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true + }); + + db.DbFirst.CreateClassFile("c:\\Demo\\1", "Models"); + + + db.DbFirst.Where("Student").CreateClassFile("c:\\Demo\\2", "Models"); + + + db.DbFirst.Where(it => it.ToLower().StartsWith("view")).CreateClassFile("c:\\Demo\\3", "Models"); + + + db.DbFirst.Where(it => it.ToLower().StartsWith("view")).CreateClassFile("c:\\Demo\\4", "Models"); + + + db.DbFirst.IsCreateAttribute().CreateClassFile("c:\\Demo\\5", "Models"); + + + db.DbFirst.IsCreateDefaultValue().CreateClassFile("c:\\Demo\\6", "Demo.Models"); + + + db.DbFirst. SettingClassTemplate(old => { return old;}) + .SettingNamespaceTemplate(old =>{ return old;}) + .SettingPropertyDescriptionTemplate(old => + { + return @" /// + /// Desc_New:{PropertyDescription} + /// Default_New:{DefaultValue} + /// Nullable_New:{IsNullable} + /// "; + }) + .SettingPropertyTemplate(old =>{return old;}) + .SettingConstructorTemplate(old =>{return old; }) + .CreateClassFile("c:\\Demo\\7"); + + + + foreach (var item in db.DbMaintenance.GetTableInfoList()) + { + string entityName = item.Name.ToUpper();/*Format class name*/ + db.MappingTables.Add(entityName , item.Name); + foreach (var col in db.DbMaintenance.GetColumnInfosByTableName(item.Name)) + { + db.MappingColumns.Add(col.DbColumnName.ToUpper() /*Format class property name*/, col.DbColumnName, entityName); + } + } + db.DbFirst.IsCreateAttribute().CreateClassFile("c:\\Demo\\8", "Models"); + + + //Use Razor Template + //db.DbFirst.UseRazorAnalysis(RazorFirst.DefaultRazorClassTemplate).CreateClassFile(""); + + Console.WriteLine("#### DbFirst End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/AttributeTable.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/AttributeTable.cs new file mode 100644 index 000000000..fa153072f --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/AttributeTable.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel.DataAnnotations; +using System.ComponentModel.DataAnnotations.Schema; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + [Table( "MyAttributeTable")] + //[SugarTable("CustomAttributeTable")] + public class AttributeTable + { + + [Key] + //[SugarColumn(IsPrimaryKey =true)] + public string Id { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Custom.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Custom.cs new file mode 100644 index 000000000..3b8871c57 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Custom.cs @@ -0,0 +1,14 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Custom + { + public int Id { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/DataDictionary.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/DataDictionary.cs new file mode 100644 index 000000000..5b0b31b39 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/DataDictionary.cs @@ -0,0 +1,34 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DataDictionary + { + public string Code { get; set; } + public string Name { get; set; } + public string Type { get; set; } + } + + public class Person + { + //数据库字段 + [SqlSugar.SugarColumn(IsPrimaryKey =true,IsIdentity =true)] + public int Id { get; set; } + public string Name { get; set; } + public int SexId { get; set; } + public int CityId { get; set; } + public int ProviceId { get; set; } + + //非数据库字段 + [SqlSugar.SugarColumn(IsIgnore =true)] + public string SexName { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public string CityName { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public string ProviceName { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/EntityMapper.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/EntityMapper.cs new file mode 100644 index 000000000..b597012fb --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/EntityMapper.cs @@ -0,0 +1,15 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using SqlSugar; +namespace OrmTest +{ + [SugarTable("MyEntityMapper")] + public class EntityMapper + { + [SugarColumn(ColumnName ="MyName")] + public string Name { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Mapper.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Mapper.cs new file mode 100644 index 000000000..bbf4e9af4 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Mapper.cs @@ -0,0 +1,56 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + [SugarTable("OrderDetail")] + public class OrderItemInfo + { + [SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int ItemId { get; set; } + public int OrderId { get; set; } + public decimal? Price { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public DateTime? CreateTime { get; set; } + [SugarColumn(IsIgnore = true)] + public Order Order { get; set; } + } + [SugarTable("Order")] + public class OrderInfo + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + public string Name { get; set; } + [SugarColumn(IsIgnore = true)] + public List Items { get; set; } + } + public class ABMapping + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int AId { get; set; } + public int BId { get; set; } + [SugarColumn(IsIgnore = true)] + public A A { get; set; } + [SugarColumn(IsIgnore = true)] + public B B { get; set; } + + } + public class A + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + public string Name { get; set; } + [SugarColumn(IsIgnore = true)] + public List BList { get; set; } + } + public class B + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Order.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Order.cs new file mode 100644 index 000000000..d7ff068b8 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Order.cs @@ -0,0 +1,24 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + + public class Order + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + + public string Name { get; set; } + public decimal Price { get; set; } + [SugarColumn(IsNullable = true)] + public DateTime CreateTime { get; set; } + [SugarColumn(IsNullable =true)] + public int CustomId { get; set; } + [SugarColumn(IsIgnore = true)] + public List Items { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/OrderItem.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/OrderItem.cs new file mode 100644 index 000000000..fb7d0a7d9 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/OrderItem.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + [SqlSugar.SugarTable("OrderDetail")] + public class OrderItem + { + [SqlSugar.SugarColumn(IsPrimaryKey =true, IsIdentity =true)] + public int ItemId { get; set; } + public int OrderId { get; set; } + public decimal? Price { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public DateTime? CreateTime { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public string OrderName { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/SubInsertTest.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/SubInsertTest.cs new file mode 100644 index 000000000..702f93a93 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/SubInsertTest.cs @@ -0,0 +1,108 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class RootTable0 + { + [SqlSugar.SugarColumn(IsPrimaryKey =true,IsIdentity =true)] + public int Id { get; set; } + public string Name { get; set; } + [SqlSugar.SugarColumn(IsIgnore =true)] + public TwoItem TwoItem { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public TwoItem2 TwoItem2 { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public List TwoItem3 { get; set; } + } + public class TwoItem + { + [SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + public int RootId { get; set; } + public string Name { get; set; } + } + public class TwoItem2 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public string Id { get; set; } + public int RootId { get; set; } + [SqlSugar.SugarColumn(IsIgnore =true)] + public List ThreeItem2 { get; set; } + } + public class TwoItem3 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public int Id { get; set; } + public string Name { get; set; } + public string Desc { get; set; } + } + public class ThreeItem2 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + + public int Id { get; set; } + public string Name { get; set; } + public string TwoItem2Id { get; set; } + } + + public class Country + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public int Id { get; set; } + public string Name { get; set; } + + [SqlSugar.SugarColumn(IsIgnore = true)] + public List Provinces { get; set; } + } + + public class Province + { + [SqlSugar.SugarColumn(IsPrimaryKey =true)] + public int Id { get; set; } + public string Name { get; set; } + public int CountryId { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public List citys { get; set; } + } + + public class City + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public int Id { get; set; } + public int ProvinceId { get; set; } + public string Name { get; set; } + } + + + public class Country1 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true,IsIdentity =true)] + public int Id { get; set; } + public string Name { get; set; } + + [SqlSugar.SugarColumn(IsIgnore = true)] + public List Provinces { get; set; } + } + + public class Province1 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true,IsIdentity =true)] + public int Id { get; set; } + public string Name { get; set; } + public int CountryId { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public List citys { get; set; } + } + + public class City1 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true,IsIdentity =true)] + public int Id { get; set; } + public int ProvinceId { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/TestTree.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/TestTree.cs new file mode 100644 index 000000000..b8250828a --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/TestTree.cs @@ -0,0 +1,17 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class TestTree + { + [SqlSugar.SugarColumn(ColumnDataType = "hierarchyid")] + public string TreeId { get; set; } + [SqlSugar.SugarColumn(ColumnDataType = "Geography")] + public string GId { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Tree.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Tree.cs new file mode 100644 index 000000000..d2878de64 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/Tree.cs @@ -0,0 +1,20 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Tree + { + [SqlSugar.SugarColumn(IsPrimaryKey =true)] + public int Id { get; set; } + public string Name { get; set; } + public int ParentId { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public Tree Parent { get; set; } + [SqlSugar.SugarColumn(IsIgnore = true)] + public List Child { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/ViewOrder.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/ViewOrder.cs new file mode 100644 index 000000000..fcd465747 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Models/ViewOrder.cs @@ -0,0 +1,13 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class ViewOrder:Order + { + public string CustomName { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Program.cs b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Program.cs new file mode 100644 index 000000000..f8c56cbd7 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Program.cs @@ -0,0 +1,32 @@ +using SqlSugar; +using System; + +namespace OrmTest +{ + class Program + { + /// + /// Set up config.cs file and start directly F5 + /// 设置Config.cs文件直接F5启动例子 + /// + /// + static void Main(string[] args) + { + //Set Custom Db + InstanceFactory.CustomDbName = "MySql"; + InstanceFactory.CustomDllName = "SqlSugar.MySqlConnectorCore"; + InstanceFactory.CustomNamespace = "SqlSugar.MySqlConnector"; + + Demo0_SqlSugarClient.Init(); + Demo1_Queryable.Init(); + Demo2_Updateable.Init(); + Demo3_Insertable.Init(); + Demo4_Deleteable.Init(); + DemoD_DbFirst.Init(); + Console.WriteLine("all successfully."); + Console.ReadKey(); + } + + + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Test.accdb b/Src/Asp.NetCore2/SqlSeverTest/CustomDbTest/Test.accdb new file mode 100644 index 0000000000000000000000000000000000000000..e6e26135e393f89ae1bba1ba954b16d6a66c26c4 GIT binary patch literal 565248 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 btn9BBY9oJYiLB(W7ic3Zj*S1t@%29eHfKDA literal 0 HcmV?d00001 diff --git a/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln b/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln index 94ca3d2e1..879a236f6 100644 --- a/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln +++ b/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln @@ -37,142 +37,222 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "SqlSugar.AccessCore", "SqlS EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AccessTest", "AccessTest\AccessTest.csproj", "{DC928353-9E17-418C-99F3-C831A0F44FB2}" EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "CustomDbTest", "CustomDbTest\CustomDbTest.csproj", "{7CAAE872-4A27-4373-B44C-504C5E6DDB85}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Any CPU = Debug|Any CPU + Debug|ARM32 = Debug|ARM32 Debug|x86 = Debug|x86 Release|Any CPU = Release|Any CPU + Release|ARM32 = Release|ARM32 Release|x86 = Release|x86 EndGlobalSection GlobalSection(ProjectConfigurationPlatforms) = postSolution {B44F2513-E55B-480F-A41C-685DDD083355}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {B44F2513-E55B-480F-A41C-685DDD083355}.Debug|Any CPU.Build.0 = Debug|Any CPU + {B44F2513-E55B-480F-A41C-685DDD083355}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {B44F2513-E55B-480F-A41C-685DDD083355}.Debug|ARM32.Build.0 = Debug|Any CPU {B44F2513-E55B-480F-A41C-685DDD083355}.Debug|x86.ActiveCfg = Debug|Any CPU {B44F2513-E55B-480F-A41C-685DDD083355}.Debug|x86.Build.0 = Debug|Any CPU {B44F2513-E55B-480F-A41C-685DDD083355}.Release|Any CPU.ActiveCfg = Release|Any CPU {B44F2513-E55B-480F-A41C-685DDD083355}.Release|Any CPU.Build.0 = Release|Any CPU + {B44F2513-E55B-480F-A41C-685DDD083355}.Release|ARM32.ActiveCfg = Release|Any CPU + {B44F2513-E55B-480F-A41C-685DDD083355}.Release|ARM32.Build.0 = Release|Any CPU {B44F2513-E55B-480F-A41C-685DDD083355}.Release|x86.ActiveCfg = Release|Any CPU {B44F2513-E55B-480F-A41C-685DDD083355}.Release|x86.Build.0 = Release|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Debug|Any CPU.Build.0 = Debug|Any CPU + {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Debug|ARM32.Build.0 = Debug|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Debug|x86.ActiveCfg = Debug|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Debug|x86.Build.0 = Debug|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Release|Any CPU.ActiveCfg = Release|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Release|Any CPU.Build.0 = Release|Any CPU + {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Release|ARM32.ActiveCfg = Release|Any CPU + {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Release|ARM32.Build.0 = Release|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Release|x86.ActiveCfg = Release|Any CPU {1E032FA3-627E-4D59-9C11-C8D8114F24FF}.Release|x86.Build.0 = Release|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Debug|Any CPU.Build.0 = Debug|Any CPU + {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Debug|ARM32.Build.0 = Debug|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Debug|x86.ActiveCfg = Debug|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Debug|x86.Build.0 = Debug|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Release|Any CPU.ActiveCfg = Release|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Release|Any CPU.Build.0 = Release|Any CPU + {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Release|ARM32.ActiveCfg = Release|Any CPU + {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Release|ARM32.Build.0 = Release|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Release|x86.ActiveCfg = Release|Any CPU {DEB62FB9-C743-4C2B-BC78-50FB0E8B44FE}.Release|x86.Build.0 = Release|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Debug|Any CPU.Build.0 = Debug|Any CPU + {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Debug|ARM32.Build.0 = Debug|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Debug|x86.ActiveCfg = Debug|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Debug|x86.Build.0 = Debug|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Release|Any CPU.ActiveCfg = Release|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Release|Any CPU.Build.0 = Release|Any CPU + {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Release|ARM32.ActiveCfg = Release|Any CPU + {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Release|ARM32.Build.0 = Release|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Release|x86.ActiveCfg = Release|Any CPU {AE73F090-22EC-49E4-AFEE-879FFFA292EC}.Release|x86.Build.0 = Release|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Debug|Any CPU.Build.0 = Debug|Any CPU + {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Debug|ARM32.Build.0 = Debug|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Debug|x86.ActiveCfg = Debug|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Debug|x86.Build.0 = Debug|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Release|Any CPU.ActiveCfg = Release|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Release|Any CPU.Build.0 = Release|Any CPU + {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Release|ARM32.ActiveCfg = Release|Any CPU + {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Release|ARM32.Build.0 = Release|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Release|x86.ActiveCfg = Release|Any CPU {3247B9CB-C92D-4AE3-8A35-3131AB2BD406}.Release|x86.Build.0 = Release|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Debug|Any CPU.Build.0 = Debug|Any CPU + {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Debug|ARM32.Build.0 = Debug|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Debug|x86.ActiveCfg = Debug|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Debug|x86.Build.0 = Debug|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Release|Any CPU.ActiveCfg = Release|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Release|Any CPU.Build.0 = Release|Any CPU + {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Release|ARM32.ActiveCfg = Release|Any CPU + {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Release|ARM32.Build.0 = Release|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Release|x86.ActiveCfg = Release|Any CPU {E76C6F9B-BA90-4A5A-94D9-D3D48CBB6AA3}.Release|x86.Build.0 = Release|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Debug|Any CPU.Build.0 = Debug|Any CPU + {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Debug|ARM32.Build.0 = Debug|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Debug|x86.ActiveCfg = Debug|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Debug|x86.Build.0 = Debug|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Release|Any CPU.ActiveCfg = Release|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Release|Any CPU.Build.0 = Release|Any CPU + {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Release|ARM32.ActiveCfg = Release|Any CPU + {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Release|ARM32.Build.0 = Release|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Release|x86.ActiveCfg = Release|Any CPU {B9005A73-5307-48FB-90EA-CC18FE6926E2}.Release|x86.Build.0 = Release|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Debug|Any CPU.Build.0 = Debug|Any CPU + {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Debug|ARM32.Build.0 = Debug|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Debug|x86.ActiveCfg = Debug|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Debug|x86.Build.0 = Debug|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Release|Any CPU.ActiveCfg = Release|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Release|Any CPU.Build.0 = Release|Any CPU + {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Release|ARM32.ActiveCfg = Release|Any CPU + {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Release|ARM32.Build.0 = Release|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Release|x86.ActiveCfg = Release|Any CPU {FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}.Release|x86.Build.0 = Release|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|ARM32.Build.0 = Debug|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|x86.ActiveCfg = Debug|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|x86.Build.0 = Debug|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|Any CPU.ActiveCfg = Release|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|Any CPU.Build.0 = Release|Any CPU + {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|ARM32.ActiveCfg = Release|Any CPU + {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|ARM32.Build.0 = Release|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|x86.ActiveCfg = Release|Any CPU {21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|x86.Build.0 = Release|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|Any CPU.Build.0 = Debug|Any CPU + {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|ARM32.Build.0 = Debug|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|x86.ActiveCfg = Debug|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|x86.Build.0 = Debug|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|Any CPU.ActiveCfg = Release|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|Any CPU.Build.0 = Release|Any CPU + {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|ARM32.ActiveCfg = Release|Any CPU + {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|ARM32.Build.0 = Release|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|x86.ActiveCfg = Release|Any CPU {2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|x86.Build.0 = Release|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Debug|Any CPU.Build.0 = Debug|Any CPU + {29925F8E-6495-463A-ABBD-C050AE85E130}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {29925F8E-6495-463A-ABBD-C050AE85E130}.Debug|ARM32.Build.0 = Debug|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Debug|x86.ActiveCfg = Debug|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Debug|x86.Build.0 = Debug|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Release|Any CPU.ActiveCfg = Release|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Release|Any CPU.Build.0 = Release|Any CPU + {29925F8E-6495-463A-ABBD-C050AE85E130}.Release|ARM32.ActiveCfg = Release|Any CPU + {29925F8E-6495-463A-ABBD-C050AE85E130}.Release|ARM32.Build.0 = Release|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Release|x86.ActiveCfg = Release|Any CPU {29925F8E-6495-463A-ABBD-C050AE85E130}.Release|x86.Build.0 = Release|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {EE197EB0-C494-4478-A5CD-545E7139202E}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {EE197EB0-C494-4478-A5CD-545E7139202E}.Debug|ARM32.Build.0 = Debug|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Debug|x86.ActiveCfg = Debug|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Debug|x86.Build.0 = Debug|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Release|Any CPU.ActiveCfg = Release|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Release|Any CPU.Build.0 = Release|Any CPU + {EE197EB0-C494-4478-A5CD-545E7139202E}.Release|ARM32.ActiveCfg = Release|Any CPU + {EE197EB0-C494-4478-A5CD-545E7139202E}.Release|ARM32.Build.0 = Release|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Release|x86.ActiveCfg = Release|Any CPU {EE197EB0-C494-4478-A5CD-545E7139202E}.Release|x86.Build.0 = Release|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Debug|ARM32.Build.0 = Debug|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Debug|x86.ActiveCfg = Debug|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Debug|x86.Build.0 = Debug|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Release|Any CPU.ActiveCfg = Release|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Release|Any CPU.Build.0 = Release|Any CPU + {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Release|ARM32.ActiveCfg = Release|Any CPU + {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Release|ARM32.Build.0 = Release|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Release|x86.ActiveCfg = Release|Any CPU {D22873F3-80E1-4415-9CD6-21B1C7EEA4A0}.Release|x86.Build.0 = Release|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Debug|Any CPU.Build.0 = Debug|Any CPU + {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Debug|ARM32.Build.0 = Debug|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Debug|x86.ActiveCfg = Debug|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Debug|x86.Build.0 = Debug|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Release|Any CPU.ActiveCfg = Release|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Release|Any CPU.Build.0 = Release|Any CPU + {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Release|ARM32.ActiveCfg = Release|Any CPU + {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Release|ARM32.Build.0 = Release|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Release|x86.ActiveCfg = Release|Any CPU {1509863D-FEB5-4CC4-9C92-7EBE308B731E}.Release|x86.Build.0 = Release|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Debug|Any CPU.Build.0 = Debug|Any CPU + {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Debug|ARM32.Build.0 = Debug|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Debug|x86.ActiveCfg = Debug|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Debug|x86.Build.0 = Debug|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Release|Any CPU.ActiveCfg = Release|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Release|Any CPU.Build.0 = Release|Any CPU + {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Release|ARM32.ActiveCfg = Release|Any CPU + {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Release|ARM32.Build.0 = Release|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Release|x86.ActiveCfg = Release|Any CPU {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Release|x86.Build.0 = Release|Any CPU {DC928353-9E17-418C-99F3-C831A0F44FB2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {DC928353-9E17-418C-99F3-C831A0F44FB2}.Debug|Any CPU.Build.0 = Debug|Any CPU + {DC928353-9E17-418C-99F3-C831A0F44FB2}.Debug|ARM32.ActiveCfg = Debug|Any CPU + {DC928353-9E17-418C-99F3-C831A0F44FB2}.Debug|ARM32.Build.0 = Debug|Any CPU {DC928353-9E17-418C-99F3-C831A0F44FB2}.Debug|x86.ActiveCfg = Debug|x86 {DC928353-9E17-418C-99F3-C831A0F44FB2}.Debug|x86.Build.0 = Debug|x86 {DC928353-9E17-418C-99F3-C831A0F44FB2}.Release|Any CPU.ActiveCfg = Release|Any CPU {DC928353-9E17-418C-99F3-C831A0F44FB2}.Release|Any CPU.Build.0 = Release|Any CPU + {DC928353-9E17-418C-99F3-C831A0F44FB2}.Release|ARM32.ActiveCfg = Release|Any CPU + {DC928353-9E17-418C-99F3-C831A0F44FB2}.Release|ARM32.Build.0 = Release|Any CPU {DC928353-9E17-418C-99F3-C831A0F44FB2}.Release|x86.ActiveCfg = Release|x86 {DC928353-9E17-418C-99F3-C831A0F44FB2}.Release|x86.Build.0 = Release|x86 + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Debug|Any CPU.Build.0 = Debug|Any CPU + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Debug|ARM32.ActiveCfg = Debug|ARM32 + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Debug|ARM32.Build.0 = Debug|ARM32 + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Debug|x86.ActiveCfg = Debug|Any CPU + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Debug|x86.Build.0 = Debug|Any CPU + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Release|Any CPU.ActiveCfg = Release|Any CPU + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Release|Any CPU.Build.0 = Release|Any CPU + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Release|ARM32.ActiveCfg = Release|ARM32 + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Release|ARM32.Build.0 = Release|ARM32 + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Release|x86.ActiveCfg = Release|Any CPU + {7CAAE872-4A27-4373-B44C-504C5E6DDB85}.Release|x86.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE