From a03960ca5ffedeb9f797e9b871bc575e886d79bd Mon Sep 17 00:00:00 2001 From: sunkaixuan <610262374@qq.com> Date: Sat, 26 Feb 2022 16:33:03 +0800 Subject: [PATCH] Update core --- .../SqlSeverTest/AccessTest/AccessTest.csproj | 13 + .../SqlSeverTest/AccessTest/Config.cs | 39 ++ .../AccessTest/Demo/Demo0_SqlSugarClient.cs | 450 ++++++++++++++ .../AccessTest/Demo/Demo1_Queryable.cs | 573 ++++++++++++++++++ .../AccessTest/Demo/Demo2_Updateable.cs | 118 ++++ .../AccessTest/Demo/Demo3_Insertable.cs | 331 ++++++++++ .../AccessTest/Demo/Demo4_Deleteable.cs | 59 ++ .../AccessTest/Demo/Demo5_SqlQueryable.cs | 36 ++ .../AccessTest/Demo/Demo6_Queue.cs | 53 ++ .../SqlSeverTest/AccessTest/Demo/Demo7_Ado.cs | 57 ++ .../AccessTest/Demo/Demo8_Saveable.cs | 69 +++ .../AccessTest/Demo/Demo9_EntityMain.cs | 46 ++ .../AccessTest/Demo/DemoA_DbMain.cs | 42 ++ .../SqlSeverTest/AccessTest/Demo/DemoB_Aop.cs | 77 +++ .../AccessTest/Demo/DemoD_DbFirst.cs | 75 +++ .../AccessTest/Demo/DemoE_CodeFirst.cs | 40 ++ .../AccessTest/Demo/DemoF_Utilities.cs | 46 ++ .../AccessTest/Demo/DemoG_SimpleClient.cs | 64 ++ .../AccessTest/Demo/DemoH_Tenant.cs | 82 +++ .../AccessTest/Demo/DemoJ_Report.cs | 142 +++++ .../AccessTest/Demo/DemoL_Snowflake.cs | 49 ++ .../AccessTest/Demo/DemoM_UnitOfWork.cs | 72 +++ .../AccessTest/Demo/DemoN_SplitTable.cs | 100 +++ .../AccessTest/Demo/Democ_GobalFilter.cs | 108 ++++ .../AccessTest/Models/AttributeTable.cs | 20 + .../SqlSeverTest/AccessTest/Models/Custom.cs | 14 + .../AccessTest/Models/DataDictionary.cs | 34 ++ .../AccessTest/Models/EntityMapper.cs | 15 + .../SqlSeverTest/AccessTest/Models/Mapper.cs | 56 ++ .../SqlSeverTest/AccessTest/Models/Order.cs | 24 + .../AccessTest/Models/OrderItem.cs | 20 + .../AccessTest/Models/SubInsertTest.cs | 108 ++++ .../AccessTest/Models/TestTree.cs | 17 + .../SqlSeverTest/AccessTest/Models/Tree.cs | 20 + .../AccessTest/Models/ViewOrder.cs | 13 + .../SqlSeverTest/AccessTest/Program.cs | 28 + .../SqlSeverTest/AccessTest/Test.accdb | Bin 0 -> 565248 bytes .../SqlSeverTest/SqlSeverTest.sln | 6 + .../SqlSugar/OnlyCore/DataExtensions.cs | 17 +- .../SqlSeverTest/SqlSugar/SqlSugar.csproj | 1 + 40 files changed, 3126 insertions(+), 8 deletions(-) create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/AccessTest.csproj create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Config.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo0_SqlSugarClient.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo1_Queryable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo2_Updateable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo3_Insertable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo4_Deleteable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo5_SqlQueryable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo6_Queue.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo7_Ado.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo8_Saveable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo9_EntityMain.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoA_DbMain.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoB_Aop.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoD_DbFirst.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoE_CodeFirst.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoF_Utilities.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoG_SimpleClient.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoH_Tenant.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoJ_Report.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoL_Snowflake.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoM_UnitOfWork.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoN_SplitTable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Democ_GobalFilter.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/AttributeTable.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Custom.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/DataDictionary.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/EntityMapper.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Mapper.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Order.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/OrderItem.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/SubInsertTest.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/TestTree.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Tree.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/ViewOrder.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Program.cs create mode 100644 Src/Asp.NetCore2/SqlSeverTest/AccessTest/Test.accdb diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/AccessTest.csproj b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/AccessTest.csproj new file mode 100644 index 000000000..cbc498ef0 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/AccessTest.csproj @@ -0,0 +1,13 @@ + + + + Exe + netcoreapp3.1 + + + + + + + + diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Config.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Config.cs new file mode 100644 index 000000000..e28748fb6 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Config.cs @@ -0,0 +1,39 @@ +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 + { + public static string GetCurrentProjectPath + { + + get + { + return Environment.CurrentDirectory.Replace(@"\bin\Debug", ""); + } + } + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString = "Provider=Microsoft.ACE.OleDB.15.0;Data Source="+GetCurrentProjectPath+"\\test.accdb"; + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString2 = ConnectionString; + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString3 = ConnectionString; + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo0_SqlSugarClient.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo0_SqlSugarClient.cs new file mode 100644 index 000000000..ea2a54661 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo0_SqlSugarClient.cs @@ -0,0 +1,450 @@ +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.Access, + 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.Access, + 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.Access, + 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.Access, + 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.Access, ConnectionString=Config.ConnectionString,InitKeyType=InitKeyType.Attribute,IsAutoCloseConnection=true }, + // new ConnectionConfig(){ ConfigId="2", DbType=DbType.Access, 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.Access, + 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.Access, + 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/AccessTest/Demo/Demo1_Queryable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo1_Queryable.cs new file mode 100644 index 000000000..6efdd3730 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/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.Access, + 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/AccessTest/Demo/Demo2_Updateable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo2_Updateable.cs new file mode 100644 index 000000000..308da3060 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/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.Access, + 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 t66 = db.Updateable(dt).AS("[Order]").WhereColumns("id").ExecuteCommand(); + // 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/AccessTest/Demo/Demo3_Insertable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo3_Insertable.cs new file mode 100644 index 000000000..8fa85bb42 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo3_Insertable.cs @@ -0,0 +1,331 @@ +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.Access, + 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); + + + var dict = new Dictionary(); + dict.Add("name", "1"); + dict.Add("CreateTime", DateTime.Now); + dict.Add("Price", 1); + db.Insertable(dict).AS("[Order]").ExecuteCommand(); + + + //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/AccessTest/Demo/Demo4_Deleteable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo4_Deleteable.cs new file mode 100644 index 000000000..d4142a2fb --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/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.Access, + 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/AccessTest/Demo/Demo5_SqlQueryable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo5_SqlQueryable.cs new file mode 100644 index 000000000..c432b7d83 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo5_SqlQueryable.cs @@ -0,0 +1,36 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo5_SqlQueryable + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### SqlQueryable Start ####"); + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true + }); + + int total = 0; + var list = db.SqlQueryable("select * from [order]").ToPageList(1, 2, ref total); + + + //by expression + var list2 = db.SqlQueryable("select * from [order]").Where(it => it.Id == 1).ToPageList(1, 2); + //by sql + var list3 = db.SqlQueryable("select * from [order]").Where("id=@id", new { id = 1 }).ToPageList(1, 2); + + Console.WriteLine("#### SqlQueryable End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo6_Queue.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo6_Queue.cs new file mode 100644 index 000000000..be65207c0 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo6_Queue.cs @@ -0,0 +1,53 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo6_Queue + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Queue Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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))); + } + } + }); + db.Insertable(new Order() { Name = "a" }).AddQueue(); + db.Insertable(new Order() { Name = "b" }).AddQueue(); + db.SaveQueues(); + + + db.Insertable(new Order() { Name = "a" }).AddQueue(); + db.Insertable(new Order() { Name = "b" }).AddQueue(); + db.Insertable(new Order() { Name = "c" }).AddQueue(); + db.Insertable(new Order() { Name = "d" }).AddQueue(); + var ar = db.SaveQueuesAsync(); + ar.Wait(); + + db.Queryable().AddQueue(); + db.Queryable().AddQueue(); + db.AddQueue("select * from [Order] where id=@id", new { id = 10000 }); + db.AddQueue("select id=@id+1", new { id = 10000 }); + var result2 = db.SaveQueues(); + + Console.WriteLine("#### Queue End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo7_Ado.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo7_Ado.cs new file mode 100644 index 000000000..15843948e --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo7_Ado.cs @@ -0,0 +1,57 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo7_Ado + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Ado Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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))); + } + } + }); + //sql + var dt = db.Ado.GetDataTable("select * from [order] where @id>0 or name=@name", new List(){ + new SugarParameter("@id",1), + new SugarParameter("@name","2") + }); + + //sql + var dt2 = db.Ado.GetDataTable("select * from [order] where @id>0 or name=@name", new { id = 1, name = "2" }); + + + + + //There are many methods to under db.ado + var list = db.Ado.SqlQuery("select * from [order] "); + + var list3 = db.Ado.SqlQuery(" delete from [order] where 2=15 "); + var intValue = db.Ado.SqlQuerySingle("select 1"); + db.Ado.ExecuteCommand("delete from [order] where id>1000"); + + db.SqlQueryable(@"select * +from custom").ToList(); + //db.Ado.xxx + Console.WriteLine("#### Ado End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo8_Saveable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo8_Saveable.cs new file mode 100644 index 000000000..1e9d89709 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo8_Saveable.cs @@ -0,0 +1,69 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo8_Saveable + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Saveable Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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))); + } + } + }); + + + //insert or update + var x= db.Storageable(new Order() { Id=1, Name="jack" }).ToStorage(); + x.AsUpdateable.ExecuteCommand(); + x.AsInsertable.ExecuteCommand(); + + + var x2 = db.Storageable(new Order() { Id = 0, Name = "jack" }).ToStorage(); + x2.BulkCopy(); + x2.BulkUpdate(); + + var dt = db.Queryable().Take(1).ToDataTable(); + dt.TableName = "order"; + var addRow = dt.NewRow(); + addRow["id"] = 0; + addRow["price"] = 1; + addRow["Name"] = "a"; + dt.Rows.Add(addRow); + var x3 = + db.Storageable(dt) + .WhereColumns("id").ToStorage(); + + x3.AsInsertable.IgnoreColumns("id").ExecuteCommand(); + x3.AsUpdateable.ExecuteCommand(); + + + var x4 = + db.Storageable(dt) + .SplitDelete(it=>Convert.ToInt32( it["id"])>0) + .WhereColumns("id").ToStorage(); + x4.AsDeleteable.ExecuteCommand(); + + Console.WriteLine(""); + Console.WriteLine("#### Saveable End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo9_EntityMain.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo9_EntityMain.cs new file mode 100644 index 000000000..1526f3a8e --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Demo9_EntityMain.cs @@ -0,0 +1,46 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class Demo9_EntityMain + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### EntityMain Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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 entityInfo = db.EntityMaintenance.GetEntityInfo(); + foreach (var column in entityInfo.Columns) + { + Console.WriteLine(column.DbColumnName); + } + + var dbColumnsName = db.EntityMaintenance.GetDbColumnName("Name"); + + var dbTableName = db.EntityMaintenance.GetTableName(); + + //more https://github.com/sunkaixuan/SqlSugar/wiki/9.EntityMain + Console.WriteLine("#### EntityMain End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoA_DbMain.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoA_DbMain.cs new file mode 100644 index 000000000..2fe9bf2d4 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoA_DbMain.cs @@ -0,0 +1,42 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoA_DbMain + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### DbMain Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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 tables = db.DbMaintenance.GetTableInfoList(); + foreach (var table in tables) + { + Console.WriteLine(table.Description); + } + //more https://github.com/sunkaixuan/SqlSugar/wiki/a.DbMain + Console.WriteLine("#### DbMain End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoB_Aop.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoB_Aop.cs new file mode 100644 index 000000000..ffb1d616e --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoB_Aop.cs @@ -0,0 +1,77 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoB_Aop + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Aop Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true + }); + db.Aop.OnLogExecuted = (sql, pars) => //SQL executed event + { + Console.WriteLine("OnLogExecuted"+sql); + }; + db.Aop.OnLogExecuting = (sql, pars) => //SQL executing event (pre-execution) + { + Console.WriteLine("OnLogExecuting" + sql); + }; + db.Aop.OnError = (exp) =>//SQL execution error event + { + //exp.sql + }; + db.Aop.OnExecutingChangeSql = (sql, pars) => //SQL executing event (pre-execution,SQL script can be modified) + { + return new KeyValuePair(sql, pars); + }; + db.Aop.OnDiffLogEvent = it =>//Get data changes + { + var editBeforeData = it.BeforeData; + var editAfterData = it.AfterData; + var sql = it.Sql; + var parameter = it.Parameters; + var businessData = it.BusinessData; + var time = it.Time; + var diffType = it.DiffType;//enum insert 、update and delete + Console.WriteLine(businessData); + //Write logic + }; + + + var list= db.Queryable().ToList(); + db.Queryable().ToList(); + + //OnDiffLogEvent + var data = db.Queryable().First(); + + db.Insertable(list.Take(5).ToList()).EnableDiffLogEvent().ExecuteCommand(); + + db.Insertable(new Order() { CreateTime=DateTime.Now, CustomId=1, Name="a" ,Price=1 }).EnableDiffLogEvent().ExecuteCommand(); + + data.Name = "changeName"; + db.Updateable(data).EnableDiffLogEvent("--update Order--").ExecuteCommand(); + + db.Updateable(list.Take(5).ToList()).EnableDiffLogEvent("--update Order--").ExecuteCommand(); + + + db.Updateable().SetColumns(it=>it.Name=="asdfa").Where(it=>it.Id==1).EnableDiffLogEvent("--update Order--").ExecuteCommand(); + + db.Updateable().SetColumns(it => it.Name == "asdfa") + .Where(it =>SqlFunc.Subqueryable().Where(x=>x.Id==it.Id).Any()).EnableDiffLogEvent("--update Order--").ExecuteCommand(); + Console.WriteLine("#### Aop End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoD_DbFirst.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoD_DbFirst.cs new file mode 100644 index 000000000..06401ddef --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/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.Access, + 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/AccessTest/Demo/DemoE_CodeFirst.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoE_CodeFirst.cs new file mode 100644 index 000000000..dea00ef80 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoE_CodeFirst.cs @@ -0,0 +1,40 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + public class DemoE_CodeFirst + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### CodeFirst Start ####"); + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + ConnectionString = Config.ConnectionString3, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true + }); + db.DbMaintenance.CreateDatabase(); + db.CodeFirst.InitTables(typeof(CodeFirstTable1));//Create CodeFirstTable1 + db.Insertable(new CodeFirstTable1() { Name = "a", Text="a" }).ExecuteCommand(); + var list = db.Queryable().ToList(); + Console.WriteLine("#### CodeFirst end ####"); + } + } + + public class CodeFirstTable1 + { + [SugarColumn(IsIdentity = true, IsPrimaryKey = true)] + public int Id { get; set; } + public string Name { get; set; } + [SugarColumn(ColumnDataType = "Nvarchar(255)")]//custom + public string Text { get; set; } + [SugarColumn(IsNullable = true)] + public DateTime CreateTime { get; set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoF_Utilities.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoF_Utilities.cs new file mode 100644 index 000000000..5b58191e1 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoF_Utilities.cs @@ -0,0 +1,46 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoF_Utilities + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Utilities Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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))); + } + } + }); + + + List ids = Enumerable.Range(1, 100).ToList(); + db.Utilities.PageEach(ids, 10, list => + { + Console.WriteLine(string.Join("," ,list)); + }); + + var list2= db.Utilities.DataTableToList(db.Ado.GetDataTable("select * from [order]")); + + //more https://github.com/sunkaixuan/SqlSugar/wiki/f.Utilities + Console.WriteLine("#### Utilities End ####"); + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoG_SimpleClient.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoG_SimpleClient.cs new file mode 100644 index 000000000..584e7afbc --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoG_SimpleClient.cs @@ -0,0 +1,64 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoG_SimpleClient + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### SimpleClient Start ####"); + + var order = new OrderDal(); + order.GetList(); + order.GetById(1); + order.MyTest(); + Console.WriteLine("#### SimpleClient End ####"); + } + public class OrderDal:Repository + { + public void MyTest() + { + base.CommQuery("1=1"); + base.ChangeRepository>().CommQuery("1=1"); + } + } + public class Repository : SimpleClient where T : class, new() + { + public Repository(ISqlSugarClient context = null) : base(context)//注意这里要有默认值等于null + { + if (context == null) + { + var db = new SqlSugarClient(new ConnectionConfig() + { + DbType = SqlSugar.DbType.Access, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true, + ConnectionString = Config.ConnectionString + }); + base.Context = db; + 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(); + } + + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoH_Tenant.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoH_Tenant.cs new file mode 100644 index 000000000..9d79fe887 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoH_Tenant.cs @@ -0,0 +1,82 @@ +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("#### DemoH_Tenant Start ####"); + new C1Service().Test(); + Console.WriteLine("#### DemoH_Tenant End ####"); + } + public class C1Service : Repository + { + public void Test() + { + db.BeginTran(); + base.GetList(); //调用内部仓储方法 + base.ChangeRepository>().GetList();//调用外部仓储 + db.CommitTran(); + } + } + public class Repository : SimpleClient where T : class, new() + { + //单例实同db同上下文共享 + public static SqlSugarScope db = new SqlSugarScope(new List { + new ConnectionConfig() + { + ConfigId="1", + DbType = SqlSugar.DbType.Access, + IsAutoCloseConnection = true, + ConnectionString = Config.ConnectionString + }, + new ConnectionConfig() + { + ConfigId="2", + DbType = SqlSugar.DbType.Access, + IsAutoCloseConnection = true, + ConnectionString = Config.ConnectionString2 + } + }); + public Repository(ISqlSugarClient context = null) : base(context)//注意这里要有默认值等于null + { + if (context == null) + { + var configId = typeof(T).GetCustomAttribute().configId; + Context = db.GetConnection(configId); + Context.CodeFirst.InitTables(); + } + } + + /// + /// 扩展方法,自带方法不能满足的时候可以添加新方法 + /// + /// + 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; } + } + } +} \ No newline at end of file diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoJ_Report.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoJ_Report.cs new file mode 100644 index 000000000..f9db75423 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoJ_Report.cs @@ -0,0 +1,142 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoJ_Report + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### DemoJ_Report Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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))); + } + } + }); + Demo1(db); + Demo2(db); + Demo3(db); + } + + private static void Demo1(SqlSugarClient db) + { + var list = new List() { 1, 2, 3,1,2 }; + var query1 = db.Queryable(); + var queryable2 = db.Reportable(list).ToQueryable(); + var x = db.Queryable(query1, queryable2, (x1, x2) => x1.Id.Equals(x2.ColumnName)) + .Select((x1, x2) => new { x = x1.Id, x2 = x2.ColumnName }).ToList(); + } + private static void Demo2(SqlSugarClient db) + { + var list = db.Queryable().ToList(); + var query1 = db.Queryable(); + var queryable2 = db.Reportable(list).ToQueryable(); + var x = db.Queryable(query1, queryable2, (x1, x2) => x1.Id.Equals(x2.OrderId)) + .Select((x1, x2) => new { name = x1.Name,id=x1.Id, orderid = x2.OrderId }).ToList(); + } + private static void Demo3(SqlSugarClient db) + { + db.CodeFirst.InitTables(); + db.Deleteable().ExecuteCommand(); + db.Insertable(new operateinfo() + { + id=1, + operate_type=1, + operate_time=Convert.ToDateTime("2021-1-1") + }).ExecuteCommand(); + db.Insertable(new operateinfo() + { + id = 1, + operate_type = 1, + operate_time = Convert.ToDateTime("2021-1-2") + }).ExecuteCommand(); + db.Insertable(new operateinfo() + { + id = 1, + operate_type = 1, + operate_time = Convert.ToDateTime("2021-3-1") + }).ExecuteCommand(); + db.Insertable(new operateinfo() + { + id = 1, + operate_type = 1, + operate_time = Convert.ToDateTime("2021-3-2") + }).ExecuteCommand(); + db.Insertable(new operateinfo() + { + id = 1, + operate_type = 1, + operate_time = Convert.ToDateTime("2021-4-2") + }).ExecuteCommand(); + + + var queryableLeft = db.Reportable(ReportableDateType.MonthsInLast1years).ToQueryable(); + var queryableRight = db.Queryable(); + var list= db.Queryable(queryableLeft, queryableRight, JoinType.Left, + (x1, x2) => x2.operate_time.ToString("yyyy-MM")== x1.ColumnName .ToString("yyyy-MM")) + .GroupBy((x1,x2)=>x1.ColumnName) + .Where(x1=>SqlFunc.Between(x1.ColumnName,"2021-01-01",DateTime.Now)) + .Select((x1, x2) => new + { + count=SqlFunc.AggregateSum(SqlFunc.IIF(x2.id>0,1,0)) , + date=x1.ColumnName.ToString("yyyy-MM") + + }).ToList(); + } + + + public partial class operateinfo + { + public operateinfo() + { + + + } + /// + /// Desc:操作序号 + /// Default: + /// Nullable:False + /// + public int id { get; set; } + + /// + /// Desc:操作时间 + /// Default: + /// Nullable:False + /// + public DateTime operate_time { get; set; } + + /// + /// Desc:操作类型 + /// Default: + /// Nullable:False + /// + public int operate_type { get; set; } + + /// + /// Desc:操作人编号 + /// Default: + /// Nullable:False + /// + public int user_id { get; set; } + + } + } + +} \ No newline at end of file diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoL_Snowflake.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoL_Snowflake.cs new file mode 100644 index 000000000..1b3a8d351 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoL_Snowflake.cs @@ -0,0 +1,49 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoL_Snowflake + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### DemoL_Snowflake ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + 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))); + } + } + }); + db.CodeFirst.InitTables(); + Console.WriteLine(db.Queryable().Count()); + var id= db.Insertable(new SnowflakeModel() + { + Name="哈哈" + }).ExecuteReturnSnowflakeId(); + var ids = db.Insertable(db.Queryable().Take(10).ToList()).ExecuteReturnSnowflakeIdList(); + Console.WriteLine(db.Queryable().Count()); + } + } + public class SnowflakeModel + { + [SugarColumn(IsPrimaryKey =true)] + public long Id { get; set; } + + public string Name{get;set; } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoM_UnitOfWork.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoM_UnitOfWork.cs new file mode 100644 index 000000000..a85d58a27 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoM_UnitOfWork.cs @@ -0,0 +1,72 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoM_UnitOfWork + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### DemoM_UnitOfWork ####"); + + + DbContext.Db.UseTran(() => + { + + var id = DbContext.CustomDal.InsertReturnIdentity(new Custom() { Id = 1, Name = "guid" }); + var id2 = DbContext.OrderDal.InsertReturnIdentity(new Order() { Name = "guid2", Price = 0, CreateTime = DateTime.Now, CustomId = 1 }); + throw new Exception(""); + }, + e => + { + //throw e; + }); + Console.WriteLine(""); + Console.WriteLine("#### Saveable End ####"); + } + public class DbContext + { + public static SqlSugarScope Db = new SqlSugarScope(new ConnectionConfig() + { + DbType = SqlSugar.DbType.Access, + ConnectionString = Config.ConnectionString, + IsAutoCloseConnection = true + }, db => { + //单例参数配置,所有上下文生效 + db.Aop.OnLogExecuting = (s, p) => + { + Console.WriteLine(s); + }; + }); + + public static DbSet OrderDal => new DbSet(); + public static DbSet CustomDal => new DbSet(); + + + public class DbSet : SimpleClient where T : class, new() + { + public DbSet(ISqlSugarClient context = null) : base(context)//需要有构造参数 + { + base.Context = DbContext.Db; + } + + /// + /// 扩展方法,自带方法不能满足的时候可以添加新方法 + /// + /// + public List CommQuery(string json) + { + //base.Context.Queryable().ToList();可以拿到SqlSugarClient 做复杂操作 + return null; + } + + } + } + + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoN_SplitTable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoN_SplitTable.cs new file mode 100644 index 000000000..079d28149 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/DemoN_SplitTable.cs @@ -0,0 +1,100 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class DemoN_SplitTable + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### CodeFirst Start ####"); + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.Access, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true + }); + db.Aop.OnLogExecuted = (s, p) => + { + Console.WriteLine(s); + Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value))); + }; + + //初始化分表 + db.CodeFirst.SplitTables().InitTables(); + + Console.WriteLine(); + + //根据最近3个表进行查询 + var list=db.Queryable() + .SplitTable(DateTime.Now.Date.AddYears(-1),DateTime.Now) + .ToList(); + + Console.WriteLine(); + + //根据时间选出的表进行查询 + var list2 = db.Queryable().SplitTable(tabs => tabs.Where(it=> it.Date>=DateTime.Now.AddYears(-2))).ToList(); + + Console.WriteLine(); + + //删除数据只在最近3张表执行操作 + var x = db.Deleteable().Where(it=>it.Pk==Guid.NewGuid()).SplitTable(tabs => tabs.Take(3)).ExecuteCommand(); + + Console.WriteLine(); + + var tableName = db.SplitHelper().GetTableName(DateTime.Now.AddDays(-111)); + + var listNull= db.Queryable().SplitTable(ta => ta.InTableNames(tableName)).ToList(); + + var tableName2 = db.SplitHelper(new OrderSpliteTest() { Time=DateTime.Now}).GetTableNames(); + var tableName3 = db.SplitHelper(new List { + new OrderSpliteTest() { Time = DateTime.Now }, + new OrderSpliteTest() { Time = DateTime.Now }, + new OrderSpliteTest() { Time = DateTime.Now.AddMonths(-10) } + }).GetTableNames(); + var x2 = db.Updateable() + .SetColumns(it=>it.Name=="a") + .Where(it => it.Pk == Guid.NewGuid()) + .SplitTable(tabs => tabs.InTableNames(tableName2)) + .ExecuteCommand(); + + Console.WriteLine(); + + //按日分表 + var x3 = db.Insertable(new OrderSpliteTest() { Name="A" }).SplitTable().ExecuteCommand(); + + Console.WriteLine(); + ////强制分表类型 + var x4 = db.Insertable(new OrderSpliteTest() { Name = "A" ,Time=DateTime.Now.AddDays(-1) }).SplitTable().ExecuteCommand(); + + //分表支持BulkCopy + db.Fastest().SplitTable().BulkCopy(new List { + new OrderSpliteTest() { Pk=Guid.NewGuid(),Name ="a", Time = DateTime.Now }, + new OrderSpliteTest() {Pk=Guid.NewGuid(),Name ="a", Time = DateTime.Now }, + new OrderSpliteTest() {Pk=Guid.NewGuid(),Name ="a", Time = DateTime.Now.AddMonths(-10) } + }); + + db.Fastest().SplitTable().BulkUpdate(db.Queryable().SplitTable(it=>it).ToList()); + db.Fastest().SplitTable().BulkUpdate(db.Queryable().SplitTable(it => it).ToList(),new string[] { "pk"},new string[] { "name"}); + Console.WriteLine("#### CodeFirst end ####"); + } + + [SplitTable(SplitType.Day)] + [SqlSugar.SugarTable("Taxxx0101_{year}{month}{day}")] + public class OrderSpliteTest + { + [SugarColumn(IsPrimaryKey =true)] + public Guid Pk{ get; set; } + public string Name { get; set; } + [SugarColumn(IsNullable =true)] + [SplitField] + public DateTime Time { get; set; } + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Democ_GobalFilter.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Democ_GobalFilter.cs new file mode 100644 index 000000000..c7cba4563 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Demo/Democ_GobalFilter.cs @@ -0,0 +1,108 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + public class DemoC_GobalFilter + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Filter Start ####"); + + TableFilterDemo(); + + NameFilterDemo(); + + Console.WriteLine("#### Filter End ####"); + } + private static void TableFilterDemo() + { + var db = GetInstance(); + //Order add filter + db.QueryFilter.Add(new TableFilterItem(it => it.Name.Contains("a"),true)); + + db.Queryable().ToList(); + + db.Queryable().ToList(); + //SELECT [Id],[Name],[Price],[CreateTime],[CustomId] FROM [Order] WHERE ([Name] like '%'+@MethodConst0+'%') + + //delete Filter + db.Deleteable().EnableQueryFilter().Where(it=>it.Id==1).ExecuteCommand(); + + db.Queryable((i, o) => i.OrderId == o.Id) + .Where(i => i.OrderId != 0) + .Select("i.*").ToList(); + //SELECT i.* FROM [OrderDetail] i ,[Order] o WHERE ( [i].[OrderId] = [o].[Id] ) AND ( [i].[OrderId] <> @OrderId0 ) AND ([o].[Name] like '%'+@MethodConst1+'%') + + //no filter + db.Queryable().Filter(null, false).ToList(); + //SELECT [Id],[Name],[Price],[CreateTime],[CustomId] FROM [Order] + + db.Queryable().LeftJoin((x, y) => x.ItemId == y.Id).ToList(); + } + + + private static void NameFilterDemo() + { + var db2 = GetInstance(); + db2.QueryFilter.Add(new SqlFilterItem() + { + FilterName = "Myfilter1", + FilterValue = it => + { + //Writable logic + return new SqlFilterResult() { Sql = " name like '%a%' " }; + }, + IsJoinQuery = false // single query + }); + db2.QueryFilter.Add(new SqlFilterItem() + { + FilterName = "Myfilter1", + FilterValue = it => + { + //Writable logic + return new SqlFilterResult() { Sql = " o.name like '%a%' " }; + }, + IsJoinQuery = true //join query + }); + + db2.Queryable() + .Where(it => it.Name == "jack") + .Filter("Myfilter1") + //IF .Filter("Myfilter",false) only execute Myfilter + .ToList(); + //SELECT [Id],[Name],[Price],[CreateTime],[CustomId] FROM [Order] + //WHERE ( [Name] = 'jack' ) AND name like '%a%' + + + db2.Queryable((o, i) => o.Id == i.OrderId) + .Where(o => o.Name == "jack") + .Filter("Myfilter1") + .Select(o => o) + .ToList(); + //SELECT o.* FROM[Order] o, [OrderDetail] i WHERE ( [o].[Id] = [i].[OrderId]) + //AND([o].[Name] = 'jack') AND o.name like '%a%' + + //no filter + db2.Queryable().Filter(null, false).ToList(); + //SELECT [Id],[Name],[Price],[CreateTime],[CustomId] FROM [Order] + } + + + public static SqlSugarClient GetInstance() + { + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() { DbType = DbType.Access, ConnectionString = Config.ConnectionString, IsAutoCloseConnection = true }); + db.Aop.OnLogExecuted = (sql, p) => + { + Console.WriteLine(sql); + Console.WriteLine(string.Join(",",p.Select(it=>it.ParameterName+":"+it.Value))); + Console.WriteLine(); + }; + return db; + } + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/AttributeTable.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/AttributeTable.cs new file mode 100644 index 000000000..fa153072f --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/Custom.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Custom.cs new file mode 100644 index 000000000..3b8871c57 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/DataDictionary.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/DataDictionary.cs new file mode 100644 index 000000000..5b0b31b39 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/EntityMapper.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/EntityMapper.cs new file mode 100644 index 000000000..b597012fb --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/Mapper.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Mapper.cs new file mode 100644 index 000000000..bbf4e9af4 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/Order.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Order.cs new file mode 100644 index 000000000..d7ff068b8 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/OrderItem.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/OrderItem.cs new file mode 100644 index 000000000..fb7d0a7d9 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/SubInsertTest.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/SubInsertTest.cs new file mode 100644 index 000000000..702f93a93 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/TestTree.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/TestTree.cs new file mode 100644 index 000000000..b8250828a --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/Tree.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/Tree.cs new file mode 100644 index 000000000..d2878de64 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Models/ViewOrder.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Models/ViewOrder.cs new file mode 100644 index 000000000..fcd465747 --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/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/AccessTest/Program.cs b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Program.cs new file mode 100644 index 000000000..f2c57517b --- /dev/null +++ b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Program.cs @@ -0,0 +1,28 @@ +using System; + +namespace OrmTest +{ + class Program + { + /// + /// Set up config.cs file and start directly F5 + /// 设置Config.cs文件直接F5启动例子 + /// + /// + static void Main(string[] args) + { + Demo0_SqlSugarClient.Init(); + Demo1_Queryable.Init(); + Demo2_Updateable.Init(); + Demo3_Insertable.Init(); + Demo4_Deleteable.Init(); + Demo5_SqlQueryable.Init(); + Demo7_Ado.Init(); + DemoD_DbFirst.Init(); + Console.WriteLine("all successfully."); + Console.ReadKey(); + } + + + } +} diff --git a/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Test.accdb b/Src/Asp.NetCore2/SqlSeverTest/AccessTest/Test.accdb new file mode 100644 index 0000000000000000000000000000000000000000..b7d48092fafd9e5a212f4b3c0a4b815e31afbec9 GIT binary patch literal 565248 zcmeF42Vhji*2m}WZhEpCiXcdd5PC~Os3N3NVhSM?5rwo3MAA$`d#H(mpS^dUyXA90U$?kEZHl_+=u6M=9Jem{@m2SIo%F!F8!j&U&qt5G zoc`NM59B{G=c{o&zPRYuWB)t&lX?4|R2)BX_1N3qdiS=`hjht2*|=?V-Sev!{CmG6 zhhF*Kkr#$_xnT2|RsXp0mmiO-Saj~sFPxZo+~Ozt4$6Azo9EqMdm^5kdilz3v0r~a zqV$#7;Yy{BOoApnNPq-LfCNZ@1W14cNPq-LfCP30ffC~gyTh;nG>ZD>+Cv6%a<^c*p4V-cW4$@n4tfUpC?C^F(D%DvBlz-YIQm50>BT`~G z@EFRB(M89IR*_13gavtYhKEC9MEH_2WAsEC(c%#ep=IV<3>`x!thF*@NUkvwBMynR zjG;`AcqA6m!-XP-^l(DGU=OX8X4eAA79&bB5BC)?1u^CDs%ut+urk$kSn9?~9kfUa z#3iX16&B>N#juNq-Is@%lvIOLWvW_LgO^*CsYVsAvQ!D)OH?V&2Do3qw?WijhGHK1K}MiS1m{G@;_UxM4I*RkJq2` z5U*Sj8wDLD&*i+YtRbtDA1-1k4J_4iw8?-Dsmj7|4SUi3K`mT?1VVdCgd>V zNR3G4>I#-?R=gYz{ZagUhu=>-nf&%`Rc4EClyV?;n9k3J|8|^lDiZ&raKrnW?bi#Vicg?A-#^1 zy=Btf5Xkaw3{%ZT(ls}`=h_P$Uqd>-IIKRu?p>qX1gDnWRU=gAQ<848Kd$?+rV5gj zw@aL|1&EI&^(?IHk3%Z`eRhHIzfu2k!V5w1$D$)=fqBvj}-+HAOR8} z0TLhq5+DH*AOR8}fjx_W&G<4-G>XH>bl|9?+4)wgeC?h6#lHyS?HIrmXYB=}0Ye)O zh^KkjB)-4XZVgu(=9qt22x9;}Djkl51D_a#VN}{XwBOPr0s-|Px_=zoYgb_3VrUPC z<cmIM~XVzkbFLYCOI(o-s7yCC?Q~F$`@EcgrAkogQRvz~FYJ9#D?-4R;3*WJmi3 zs*~|V!5W%P3GsA72D0n%ltP|kc!!Z&jXvWcg?A*{0p_v5)qLwoO~+{Lft42UghJOt zzgEveT9*vCk)|CdpI(^lnEy$D1W14cNPq-LfCNZ@1W4ddNx)`2EB#3|0;c-Xl{7oV zRzKcfWc2^T(Ek^MemP-LtPK6&z#m1Nt>}Srn|1-(Lsne~?EXVGyZ`=PzGbcM?f%OH z0yBocm+$TVTS*0Z$diMRF~VCtl<+=D5d8yVJU4iY;eTZC<4Mqu6Pm=F!TVgH*@n8*b|5JAvAXOM2lgITh`}CDe~+g{ zd^_TJSBq%&$H7Df9mi)?VLrL=#&;l2yrl2(G?{U%herB=h1LkZ4yiAHgOvJ445W)A zz)wEvBgk)iSht^|nZ1=I-${T3NPq-LfCNZ@1W14cNMJ7`U>KXk;$0t|_4hH{fRh?@TkBPT4s;* z42-s8#5O^sNW3*$gZyb`P#r|PkqZ2jN|S$b4QXZc#UvSsAS1sCICU5}!cDxIaq2-~ z`GC`~ToUwW9V$WG(!9~V!OcVwhDVzOnofsTQ$bF3PEKB4;nJlQIdck^8gT2>)9;m= zv()Qon2tr|mBnVLeN2bq@`Boh-Z1-`PL+iVbE@Z;moA+*zrqY_vpg!wE2~YXZl=@H zyvq3%UZ?I}r{znLg4U#m=~A7OYh|It#c0Z_U0PjUEMXdS+D22+FndN;(fEmZ85sqW z)6yo7Pn(>ZH!*EuK~Y*p?xce8g+&F!>}R_Fo~jcbXeNV51sR1!lZw*PiYDe{OfE

sm`@ir#6BW6z0t@ z&N1P++6XhJcD}6Xp*lI+2r$2}u&|)K7R+_9xUB?RI=^&|H&|>N!4{U6&e7?_v=LzG zJTwX&BD#$b)rHH<0P$@Es4ZPOe@t@&By+W@{e(c)gp1!AEr#nF6+M47dDah3>IyGC< z(%RzUoXX|%ON+|2a~CsU?b1SIQ#2n{s-3%vvt7q8%?VWpl5(JrS)4whqb&^%-LfM3 zqO?3nfCNZ@1W14cNZ>C>z+s#mE8Xr;hs_ZgpODs!wb0uugi3{OyOThZnR%x!BH&kc zr>-KP#yjmJ0_Jjb>LvmnvUKV$0`?B*w66%54AQBG2$%?fhXoMuK&Mk55wJ{Rr@l?i zW;zZLB%Lr3B%N>(B%KHmFc+g!qzK(1M2XM?LbM3`L5LBdH-uOb`a*~kVSflt5&A=L zi7)^{ya205+DH*AOR8}0TLhq z5+DH*_=^+3Fy}5h+8TV{p5$#io`}OZII6Aj$aW9=r)`goz%B^9J#7BsVP&`;$B^+N zVEli`1QF0)hD@}C11w>ZB^)RMTE&pbmN3N<(kvle1Y8C~GAtp}60$5ITLc&a44G;P z(=1`SCCm^3wgy9TEa4za$hCw#5nzTeB;OJWyh5_F1VaQ^C?v;NLaZgki2$30WTz## zEI}I-2n{{9FG4pN+ZRDw1PBCep&){`Bak9%Qw0&UL4gR`pg>BhjTb~nlypSUCI&Eq z7^1BPMCdMFB4}F!m_-b+iHivPT7tGdfT6??ySRwZ!xFST!hUekmKP%Q6fY5miU4DZ zA=(y01Z@@}!Z7jb3qf0Fh@cH6L>Mk!Ft`|^?KMQurV}EJ5U>6av;~I&2pB#8jSjUi(!VXP&L6CnlFq-ltt%PxX0DU3Ukb-6^) zr4T{u40DfUt)U279}#r!nGm{4$|CGz3A&cE;iBt81WjH9&3P6CO;rTVPy|g3W+TbE zI3nmKA%boRiy-KhAcAfHBIpKC48gK7N!Il)F1nUsY?7?&R0LgvBIx>p`AM>_9T9Y0 zh@i>CASGFI7C}=LAz2Ct6P4r?OBihlsUpB=C0UafL6a9jlZP2g@^}d&!URj0D8gE} z9AF8PEa5=0yO&#vIl}~kITr;&vgMT`f?Q2{j*K0Gp4=gVp4=kBXl=g_A=PUjGo*_p zbhU(i6b}+00TLhq5+DH*Ac0*%z%Wj?)_q5B<$l+4m%0AmE=in;kN^pg011!)36KB@ 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%0DOicby#?t76Rf0~^m!PcgUXDeg>t$}9)+xc& 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 literal 0 HcmV?d00001 diff --git a/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln b/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln index e0ed0e34d..e81256c61 100644 --- a/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln +++ b/Src/Asp.NetCore2/SqlSeverTest/SqlSeverTest.sln @@ -35,6 +35,8 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "MySqlConnectorTest", "MySql EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SqlSugar.AccessCore", "SqlSugar.AccessCore\SqlSugar.AccessCore.csproj", "{DD0C850D-86E5-4FFF-BFF3-8797EB448B47}" EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AccessTest", "AccessTest\AccessTest.csproj", "{DC928353-9E17-418C-99F3-C831A0F44FB2}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Any CPU = Debug|Any CPU @@ -101,6 +103,10 @@ Global {DD0C850D-86E5-4FFF-BFF3-8797EB448B47}.Debug|Any CPU.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 + {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}.Release|Any CPU.ActiveCfg = Release|Any CPU + {DC928353-9E17-418C-99F3-C831A0F44FB2}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/OnlyCore/DataExtensions.cs b/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/OnlyCore/DataExtensions.cs index 6460f2601..f6767d9d6 100644 --- a/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/OnlyCore/DataExtensions.cs +++ b/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/OnlyCore/DataExtensions.cs @@ -12,6 +12,7 @@ using Microsoft.Data.SqlClient; using System.Linq; using System.Threading.Tasks; using System.Data.OscarClient; +using System.Data.OleDb; namespace SqlSugar { @@ -1119,15 +1120,15 @@ namespace SqlSugar /// public class OleDbDataAdapter : IDataAdapter { - private SqlCommand command; + private OleDbCommand command; private string sql; - private SqlConnection _sqlConnection; + private OleDbConnection _sqlConnection; ///

/// SqlDataAdapter /// /// - public OleDbDataAdapter(SqlCommand command) + public OleDbDataAdapter(OleDbCommand command) { this.command = command; } @@ -1142,7 +1143,7 @@ namespace SqlSugar /// /// /// - public OleDbDataAdapter(string sql, SqlConnection _sqlConnection) + public OleDbDataAdapter(string sql, OleDbConnection _sqlConnection) { this.sql = sql; this._sqlConnection = _sqlConnection; @@ -1151,13 +1152,13 @@ namespace SqlSugar /// /// SelectCommand /// - public SqlCommand SelectCommand + public OleDbCommand SelectCommand { get { if (this.command == null) { - this.command = new SqlCommand(this.sql, this._sqlConnection); + this.command = new OleDbCommand(this.sql, this._sqlConnection); } return this.command; } @@ -1179,7 +1180,7 @@ namespace SqlSugar } var columns = dt.Columns; var rows = dt.Rows; - using (SqlDataReader dr = command.ExecuteReader()) + using (OleDbDataReader dr = command.ExecuteReader()) { for (int i = 0; i < dr.FieldCount; i++) { @@ -1216,7 +1217,7 @@ namespace SqlSugar { ds = new DataSet(); } - using (SqlDataReader dr = command.ExecuteReader()) + using (OleDbDataReader dr = command.ExecuteReader()) { do { diff --git a/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/SqlSugar.csproj b/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/SqlSugar.csproj index 26d93188b..1d8b4a8ec 100644 --- a/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/SqlSugar.csproj +++ b/Src/Asp.NetCore2/SqlSeverTest/SqlSugar/SqlSugar.csproj @@ -30,6 +30,7 @@ +