From 62cbc406a9f5a61eee8eb50681aa5f303e68c72e Mon Sep 17 00:00:00 2001 From: sunkaixuna <610262374@qq.com> Date: Tue, 1 Feb 2022 12:55:49 +0800 Subject: [PATCH] Add SqlSugar.Access and SqlSugar MySqlConnector --- Src/Asp.Net/MySqlConnectorTest/App.config | 22 + .../MySqlConnectorTest/Bugs/BugTest1.cs | 62 ++ Src/Asp.Net/MySqlConnectorTest/Config.cs | 34 + .../Demo/Demo0_SqlSugarClient.cs | 416 ++++++++++++ .../Demo/Demo1_Queryable.cs | 394 ++++++++++++ .../Demo/Demo2_Updateable.cs | 108 ++++ .../Demo/Demo3_Insertable.cs | 75 +++ .../Demo/Demo4_Deleteable.cs | 48 ++ .../Demo/Demo5_SqlQueryable.cs | 36 ++ .../MySqlConnectorTest/Demo/Demo6_Queue.cs | 52 ++ .../MySqlConnectorTest/Demo/Demo7_Ado.cs | 59 ++ .../MySqlConnectorTest/Demo/Demo8_Saveable.cs | 48 ++ .../Demo/Demo9_EntityMain.cs | 46 ++ .../MySqlConnectorTest/Demo/DemoA_DbMain.cs | 42 ++ .../MySqlConnectorTest/Demo/DemoB_Aop.cs | 68 ++ .../MySqlConnectorTest/Demo/DemoD_DbFirst.cs | 75 +++ .../Demo/DemoE_CodeFirst.cs | 40 ++ .../Demo/DemoF_Utilities.cs | 46 ++ .../Demo/DemoG_SimpleClient.cs | 36 ++ .../MySqlConnectorTest/Demo/DemoJ_Report.cs | 142 ++++ .../Demo/DemoN_SplitTable.cs | 89 +++ .../MySqlConnectorTest/Demo/DemoO_Fastest.cs | 60 ++ .../Demo/Democ_GobalFilter.cs | 77 +++ .../Models/AttributeTable.cs | 20 + .../MySqlConnectorTest/Models/CarType.cs | 7 + .../MySqlConnectorTest/Models/Custom.cs | 14 + .../MySqlConnectorTest/Models/EntityMapper.cs | 15 + .../MySqlConnectorTest/Models/Mapper.cs | 54 ++ .../Models/MyCustomAttributeTable.cs | 20 + .../MySqlConnectorTest/Models/Order.cs | 24 + .../MySqlConnectorTest/Models/OrderItem.cs | 20 + .../MySqlConnectorTest/Models/TestTree.cs | 17 + Src/Asp.Net/MySqlConnectorTest/Models/Tree.cs | 20 + .../Models/Unit/Custom1/EGoods.cs | 604 ++++++++++++++++++ .../Models/Unit/Custom1/EGoodsBrand.cs | 68 ++ .../Models/Unit/Custom1/EGoodsClass.cs | 261 ++++++++ .../Models/Unit/Custom1/EOrderAlbaran.cs | 404 ++++++++++++ .../Unit/Custom1/EOrderAlbaranDetail.cs | 234 +++++++ .../Models/Unit/Custom1/EOrderReturn.cs | 381 +++++++++++ .../Models/Unit/Custom1/EOrderReturnDetail.cs | 202 ++++++ .../Unit/Custom1/PurchaseDetailModel.cs | 162 +++++ .../MySqlConnectorTest/Models/ViewOrder.cs | 13 + .../MySqlConnectorTest.csproj | 138 ++++ Src/Asp.Net/MySqlConnectorTest/Program.cs | 41 ++ .../Properties/AssemblyInfo.cs | 36 ++ .../MySqlConnectorTest/UnitTest/Main.cs | 50 ++ .../MySqlConnectorTest/UnitTest/UAdo.cs | 57 ++ .../MySqlConnectorTest/UnitTest/UBulkCopy.cs | 212 ++++++ .../MySqlConnectorTest/UnitTest/UCodeFirst.cs | 92 +++ .../MySqlConnectorTest/UnitTest/UCustom06.cs | 45 ++ .../MySqlConnectorTest/UnitTest/UInsert.cs | 154 +++++ .../MySqlConnectorTest/UnitTest/UJson.cs | 39 ++ .../MySqlConnectorTest/UnitTest/UQueryable.cs | 370 +++++++++++ .../UnitTest/UQueryableAsync.cs | 43 ++ .../MySqlConnectorTest/UnitTest/UQueue.cs | 41 ++ .../MySqlConnectorTest/UnitTest/UThread.cs | 376 +++++++++++ .../MySqlConnectorTest/UnitTest/UThread2.cs | 316 +++++++++ .../MySqlConnectorTest/UnitTest/UThread3.cs | 117 ++++ .../MySqlConnectorTest/UnitTest/UValidate.cs | 19 + .../UnitTest/UnitCustom01.cs | 117 ++++ .../MySqlConnectorTest/UnitTest/Updateable.cs | 211 ++++++ .../MySqlConnectorTest/packages.config | 8 + .../Properties/AssemblyInfo.cs | 36 ++ Src/Asp.Net/SqlSugar.Access/Queryable.cs | 13 + .../SqlSugar.Access/SqlSugar.Access.csproj | 54 ++ .../MySql/CodeFirst/MySqlCodeFirst.cs | 80 +++ .../MySql/DbBind/MySqlDbBind.cs | 97 +++ .../MySql/DbFirst/MySqlDbFirst.cs | 11 + .../MySql/DbMaintenance/MySqlDbMaintenance.cs | 464 ++++++++++++++ .../MySql/MySqlProvider.cs | 140 ++++ .../MySql/Queryable/MySqlQueryable.cs | 60 ++ .../MySql/SqlBuilder/MySqlBlukCopy.cs | 202 ++++++ .../MySql/SqlBuilder/MySqlBuilder.cs | 26 + .../MySql/SqlBuilder/MySqlDeleteBuilder.cs | 7 + .../SqlBuilder/MySqlExpressionContext.cs | 154 +++++ .../MySql/SqlBuilder/MySqlFastBuilder.cs | 74 +++ .../MySql/SqlBuilder/MySqlInsertBuilder.cs | 136 ++++ .../MySql/SqlBuilder/MySqlQueryBuilder.cs | 138 ++++ .../MySql/SqlBuilder/MySqlUpdateBuilder.cs | 155 +++++ .../Properties/AssemblyInfo.cs | 36 ++ .../SqlSugar.MySqlConnector.csproj | 93 +++ .../Tools/ErrorMessage.cs | 64 ++ .../Tools/FileHelper.cs | 70 ++ .../Tools/UtilConstants.cs | 73 +++ .../Tools/UtilExtensions.cs | 123 ++++ .../Tools/UtilMethods.cs | 493 ++++++++++++++ .../Tools/ValidateExtensions.cs | 172 +++++ .../SqlSugar.MySqlConnector/packages.config | 8 + Src/Asp.Net/SqlSugar.sln | 22 +- .../SugarProvider/SqlSugarAccessory.cs | 5 + .../Infrastructure/InstanceFactory.cs | 46 +- 91 files changed, 10143 insertions(+), 6 deletions(-) create mode 100644 Src/Asp.Net/MySqlConnectorTest/App.config create mode 100644 Src/Asp.Net/MySqlConnectorTest/Bugs/BugTest1.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Config.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo0_SqlSugarClient.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo1_Queryable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo2_Updateable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo3_Insertable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo4_Deleteable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo5_SqlQueryable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo6_Queue.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo7_Ado.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo8_Saveable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Demo9_EntityMain.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoA_DbMain.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoB_Aop.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoD_DbFirst.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoE_CodeFirst.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoF_Utilities.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoG_SimpleClient.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoJ_Report.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoN_SplitTable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/DemoO_Fastest.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Demo/Democ_GobalFilter.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/AttributeTable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/CarType.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Custom.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/EntityMapper.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Mapper.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/MyCustomAttributeTable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Order.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/OrderItem.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/TestTree.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Tree.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoods.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsBrand.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsClass.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaran.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaranDetail.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturn.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturnDetail.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/PurchaseDetailModel.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Models/ViewOrder.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/MySqlConnectorTest.csproj create mode 100644 Src/Asp.Net/MySqlConnectorTest/Program.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/Properties/AssemblyInfo.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/Main.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UAdo.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UBulkCopy.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UCodeFirst.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UCustom06.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UInsert.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UJson.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryableAsync.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueue.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread2.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread3.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UValidate.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/UnitCustom01.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/UnitTest/Updateable.cs create mode 100644 Src/Asp.Net/MySqlConnectorTest/packages.config create mode 100644 Src/Asp.Net/SqlSugar.Access/Properties/AssemblyInfo.cs create mode 100644 Src/Asp.Net/SqlSugar.Access/Queryable.cs create mode 100644 Src/Asp.Net/SqlSugar.Access/SqlSugar.Access.csproj create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/CodeFirst/MySqlCodeFirst.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbBind/MySqlDbBind.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbFirst/MySqlDbFirst.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbMaintenance/MySqlDbMaintenance.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/MySqlProvider.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/Queryable/MySqlQueryable.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBlukCopy.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBuilder.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlDeleteBuilder.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlExpressionContext.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlFastBuilder.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlInsertBuilder.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlQueryBuilder.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlUpdateBuilder.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/Properties/AssemblyInfo.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/SqlSugar.MySqlConnector.csproj create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ErrorMessage.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/Tools/FileHelper.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilConstants.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilExtensions.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilMethods.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ValidateExtensions.cs create mode 100644 Src/Asp.Net/SqlSugar.MySqlConnector/packages.config diff --git a/Src/Asp.Net/MySqlConnectorTest/App.config b/Src/Asp.Net/MySqlConnectorTest/App.config new file mode 100644 index 000000000..8995ddae5 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/App.config @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + diff --git a/Src/Asp.Net/MySqlConnectorTest/Bugs/BugTest1.cs b/Src/Asp.Net/MySqlConnectorTest/Bugs/BugTest1.cs new file mode 100644 index 000000000..d7f8e6ef0 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Bugs/BugTest1.cs @@ -0,0 +1,62 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using SqlSugar; +namespace OrmTest.Test +{ + public class BugTest1 + + { + + + + public static void Init() + + { + + SqlSugarClient db = new SqlSugarClient( + + new ConnectionConfig() + + { + + ConnectionString = Config.ConnectionString, + + DbType = DbType.MySqlConnector,//设置数据库类型 + + IsAutoCloseConnection = true,//自动释放数据务,如果存在事务,在事务结束后释放 + + InitKeyType = InitKeyType.Attribute //从实体特性中读取主键自增列信息 + + }); + + db.Aop.OnError = (exp) =>//SQL报错 + + { + + string sql = exp.Sql; + + //exp.sql 这样可以拿到错误SQL + + }; + + //db.DbMaintenance.CreateDatabase(); + + db.Deleteable().ExecuteCommand(); + db.Insertable(new Order() { CreateTime = DateTime.Now.Date.AddDays(-1), Name = "1a", Price = 1, CustomId = 1 }).ExecuteCommand(); + db.Insertable(new Order() { CreateTime = DateTime.Now.Date.AddDays(-1).AddHours(23), Name = "1a", Price = 1, CustomId = 1 }).ExecuteCommand(); + + db.Insertable(new Order() { CreateTime = DateTime.Now.Date.AddDays(1), Name = "1a", Price = 1, CustomId = 1 }).ExecuteCommand(); + db.Insertable(new Order() { CreateTime = DateTime.Now.Date.AddDays(2), Name = "1a", Price = 1, CustomId = 1 }).ExecuteCommand(); + var s =DateTime.Now.Date.AddMilliseconds(-1); + var list= db.Queryable().Where(it => SqlFunc.DateIsSame(it.CreateTime,s)).ToList(); + var s2 = DateTime.Now.Date.AddDays(-1); + var lists = db.Queryable().Where(it => SqlFunc.DateIsSame(it.CreateTime, s2)).ToSql(); + Console.ReadKey(); + + } + + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Config.cs b/Src/Asp.Net/MySqlConnectorTest/Config.cs new file mode 100644 index 000000000..f2f301882 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Config.cs @@ -0,0 +1,34 @@ +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 + /// 设置好数据库名不需要你去手动建库 + /// + public class Config + { + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString = "server=localhost;Database=SqlSugar4xTest;Uid=root;Pwd=haosql"; + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString2 = "server=localhost;Database=SqlSugar4xTest2;Uid=root;Pwd=haosql"; + /// + /// Account have permission to create database + /// 用有建库权限的数据库账号 + /// + public static string ConnectionString3 = "server=localhost;Database=SqlSugar4xTest3;Uid=root;Pwd=haosql"; + + + /***注意:如果报错:指字关键词不在字典中这说明需要更新MYSQL.DATA驱动到最新,不报错就不需要更新***/ + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/Demo0_SqlSugarClient.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo0_SqlSugarClient.cs new file mode 100644 index 000000000..2004dd87b --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo0_SqlSugarClient.cs @@ -0,0 +1,416 @@ +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.MySqlConnector, + 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.MySqlConnector, + 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.MySqlConnector, + 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.MySqlConnector, + 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.MySqlConnector, ConnectionString=Config.ConnectionString,InitKeyType=InitKeyType.Attribute,IsAutoCloseConnection=true }, + new ConnectionConfig(){ ConfigId="2", DbType=DbType.MySqlConnector, 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"); + + var result2 = db.UseTranAsync(async () => + { + + 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(""); + + }); + result2.Wait(); + if (result2.Result.IsSuccess == false) + { + 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()); + } + + Console.WriteLine("#### Distributed TransactionExample End ####"); + } + } + + /// + /// DbContext Example 1 + /// + public class DbContext + { + + public SqlSugarClient Db; + public DbContext() + { + Db = new SqlSugarClient(new ConnectionConfig() + { + ConnectionString = Config.ConnectionString, + DbType = DbType.MySqlConnector, + 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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/Demo1_Queryable.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo1_Queryable.cs new file mode 100644 index 000000000..542114a6e --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo1_Queryable.cs @@ -0,0 +1,394 @@ +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(); + 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 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 getAll2 = db.Queryable().Where(it=>it.CreateTime.Day>=DateTime.Now.Date.Day).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 dp = DateTime.Now; + var test05 = db.Queryable().Where(it => it.CreateTime.Month == dp.Month).ToList(); + var fromatList = db.Queryable().Select(it => it.CreateTime.ToString("%Y-%m")).ToList(); + var test06 = db.Queryable().Where(it => it.CreateTime.Date.Day >= DateTime.Now.Date.Day).ToList(); + Console.WriteLine("#### Examples End ####"); + } + + private static void ReturnType() + { + Console.WriteLine(""); + Console.WriteLine("#### ReturnType Start ####"); + var db = GetInstance(); + List list = db.Queryable().ToList(); + + 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(); + + + var mergeList= db.Queryable() + .Select(it => new { id = it.Id }) + .MergeTable().Select().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 list2 = db.Queryable().Where(it => SqlFunc.Subqueryable().Where(i => i.OrderId == it.Id).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 list2 = db.Queryable().Select(it => new + { + date = SqlFunc.ToDateShort(it.CreateTime), + datetime = SqlFunc.ToDate(it.CreateTime) + }).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(); + db.Insertable(new Tree() { Id = 222, Name = "child222", ParentId = 22 }).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(); + //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(); + + + var tree = db.Queryable().ToTree(it => it.Child, it => it.ParentId, 0); + 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); + 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(); + + 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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/Demo2_Updateable.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo2_Updateable.cs new file mode 100644 index 000000000..8333efc99 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo2_Updateable.cs @@ -0,0 +1,108 @@ +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.MySqlConnector, + 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 + + + + + /*** 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 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.Net/MySqlConnectorTest/Demo/Demo3_Insertable.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo3_Insertable.cs new file mode 100644 index 000000000..21bc5f998 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo3_Insertable.cs @@ -0,0 +1,75 @@ +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.MySqlConnector, + 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 updateObjs = new List { + new Order() { Id = 11, Name = "order11", Price=0 }, + new Order() { Id = 12, Name = "order12" , Price=0} + }; + var x = db.Insertable(updateObjs).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(updateObjs).ExecuteCommand();//get change row count + + //Use Lock + db.Insertable(insertObj).With(SqlWith.UpdLock).ExecuteCommand(); + + db.Deleteable().ExecuteCommand(); + db.Insertable(new Order() + { + CreateTime = DateTime.Now, + CustomId = 11, + Name = "11", + Price = 11 + }).UseMySql().ExecuteBulkCopy(); + db.Insertable(new OrderItem() + { + CreateTime = DateTime.Now, + ItemId = 1, + OrderId = 1, + OrderName = "a", + Price = 11 + }).UseMySql().ExecuteBulkCopy(); + var data = db.Queryable().ToList(); + db.Insertable(data).UseMySql().ExecuteBulkCopy(); + db.Fastest().BulkUpdate(data); + Console.WriteLine("#### Insertable End ####"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/Demo4_Deleteable.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo4_Deleteable.cs new file mode 100644 index 000000000..f5d885375 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo4_Deleteable.cs @@ -0,0 +1,48 @@ +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.MySqlConnector, + 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(); + + Console.WriteLine("#### Deleteable End ####"); + + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/Demo5_SqlQueryable.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo5_SqlQueryable.cs new file mode 100644 index 000000000..f350c18aa --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/Demo6_Queue.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo6_Queue.cs new file mode 100644 index 000000000..c283022bc --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo6_Queue.cs @@ -0,0 +1,52 @@ +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.MySqlConnector, + 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 }); + var result2 = db.SaveQueues(); + + Console.WriteLine("#### Queue End ####"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/Demo7_Ado.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo7_Ado.cs new file mode 100644 index 000000000..c454ce9ff --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo7_Ado.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 Demo7_Ado + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Ado Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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" }); + + //Stored Procedure + //var dt3 = db.Ado.UseStoredProcedure().GetDataTable("sp_school", new { name = "张三", age = 0 }); + //var nameP = new SugarParameter("@name", "张三"); + //var ageP = new SugarParameter("@age", null, true);//isOutput=true + //var dt4 = db.Ado.UseStoredProcedure().GetDataTable("sp_school", nameP, ageP); + + + + //There are many methods to under db.ado + var list= db.Ado.SqlQuery("select * from `order` "); + var list2 = db.Ado.SqlQuery("select * from `order` where 1=2;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.Ado.xxx + Console.WriteLine("#### Ado End ####"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/Demo8_Saveable.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo8_Saveable.cs new file mode 100644 index 000000000..61db9a504 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo8_Saveable.cs @@ -0,0 +1,48 @@ +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.MySqlConnector, + 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 + db.Saveable(new Order() { Id=1, Name="jack" }).ExecuteReturnEntity(); + + + //insert or update + db.Saveable(new Order() { Id = 1000, Name = "jack", CreateTime=DateTime.Now }) + .InsertColumns(it => new { it.Name,it.CreateTime, it.Price})//if insert into name,CreateTime,Price + .UpdateColumns(it => new { it.Name, it.CreateTime })//if update set name CreateTime + .ExecuteReturnEntity(); + + Console.WriteLine(""); + Console.WriteLine("#### Saveable End ####"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/Demo9_EntityMain.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Demo9_EntityMain.cs new file mode 100644 index 000000000..ed304e507 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/DemoA_DbMain.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoA_DbMain.cs new file mode 100644 index 000000000..dc2aa20be --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/DemoB_Aop.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoB_Aop.cs new file mode 100644 index 000000000..58c183070 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoB_Aop.cs @@ -0,0 +1,68 @@ +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.MySqlConnector, + 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); + Console.WriteLine(editBeforeData[0].Columns[1].Value); + Console.WriteLine("to"); + Console.WriteLine(editAfterData[0].Columns[1].Value); + //Write logic + }; + + + db.Queryable().ToList(); + db.Queryable().ToList(); + + //OnDiffLogEvent + var data = db.Queryable().First(); + data.Name = "changeName"; + db.Updateable(data).EnableDiffLogEvent("--update Order--").ExecuteCommand(); + + Console.WriteLine("#### Aop End ####"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/DemoD_DbFirst.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoD_DbFirst.cs new file mode 100644 index 000000000..76528c0d2 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/DemoE_CodeFirst.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoE_CodeFirst.cs new file mode 100644 index 000000000..f91ce2f36 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/DemoF_Utilities.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoF_Utilities.cs new file mode 100644 index 000000000..4a83664d9 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.MySqlConnector, + 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.Net/MySqlConnectorTest/Demo/DemoG_SimpleClient.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoG_SimpleClient.cs new file mode 100644 index 000000000..baac2a296 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoG_SimpleClient.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 DemoG_SimpleClient + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### SimpleClient Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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))); + } + } + }); + + Console.WriteLine("#### SimpleClient End ####"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/DemoJ_Report.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoJ_Report.cs new file mode 100644 index 000000000..225b3208b --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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("#### Utilities Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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 }; + var query1 = db.Queryable(); + var queryable2 = db.Reportable(list).ToQueryable(); + var x = db.Queryable(queryable2, query1, (x2, x1) => x1.Id.Equals(x2.ColumnName)) + .Select((x2, x1) => 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.Net/MySqlConnectorTest/Demo/DemoN_SplitTable.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoN_SplitTable.cs new file mode 100644 index 000000000..70964bafa --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoN_SplitTable.cs @@ -0,0 +1,89 @@ +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.MySqlConnector, + ConnectionString = Config.ConnectionString, + InitKeyType = InitKeyType.Attribute, + IsAutoCloseConnection = true + }); + db.Aop.OnLogExecuted = (s, p) => + { + Console.WriteLine(s); + }; + + //初始化分表 + db.CodeFirst.SplitTables().InitTables(); + + Console.WriteLine(); + + //根据最近3个表进行查询 + var list=db.Queryable().Where(it=>it.Pk==Guid.NewGuid()) + .SplitTable(tabs => tabs.Take(3)) + .Where(it=>it.Time==DateTime.Now).ToOffsetPage(1,2); + + 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(-1)); + 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(); + + var tableName21 = db.SplitHelper().GetTableName(DateTime.Now.AddDays(-111)); + var listNull = db.Queryable().SplitTable(ta => ta.InTableNames(tableName21)).ToList(); + 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.Net/MySqlConnectorTest/Demo/DemoO_Fastest.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoO_Fastest.cs new file mode 100644 index 000000000..0eba37601 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/DemoO_Fastest.cs @@ -0,0 +1,60 @@ +using OrmTest; +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class TestFAST111 + { + + public int Sex { get; set; } + public DateTime Date { get; set; } + + [SqlSugar.SugarColumn(IsPrimaryKey =true)] + public string Id { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public long X { get; set; } + [SqlSugar.SugarColumn(IsNullable = true,IsJson =true,ColumnDataType ="varchar(500)")] + public string [] json { get; set; } + } + + public class DemoO_Fastest + { + public static void Init() + { + Console.WriteLine(""); + Console.WriteLine("#### Insertable Start ####"); + + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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(); + db.Fastest().BulkCopy(new List() { + new TestFAST111(){ Date=DateTime.Now, Id=Guid.NewGuid()+"", Sex=1 , X=111,json=new string[]{ "x"} } + }); + var data = new List() { + new TestFAST111(){ Date=DateTime.Now, Id=Guid.NewGuid()+"", Sex=2 , X=112,json=new string[]{ "x"} } + }; + //db.Updateable(data).ExecuteCommand(); + db.Fastest().BulkUpdate(data); + var x = db.Queryable().ToList(); + + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Demo/Democ_GobalFilter.cs b/Src/Asp.Net/MySqlConnectorTest/Demo/Democ_GobalFilter.cs new file mode 100644 index 000000000..33e6e1413 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Demo/Democ_GobalFilter.cs @@ -0,0 +1,77 @@ +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 ####"); + var db = GetInstance(); + + + var sql = db.Queryable().ToSql(); + //SELECT [Id],[Name],[Price],[CreateTime] FROM `order` WHERE isDelete=0 + Console.WriteLine(sql); + + + var sql2 = db.Queryable((main,ot)=> main.Id==ot.OrderId).ToSql(); + //SELECT [Id],[Name],[Price],[CreateTime] FROM `order` main ,[OrderDetail] ot WHERE ( [main].[Id] = [ot].[OrderId] ) AND main.isDelete=0 + Console.WriteLine(sql2); + + + var sql3 = db.Queryable().Filter("Myfilter").ToSql();// Myfilter+Gobal + //SELECT [Id],[Name],[Price],[CreateTime] FROM `order` WHERE Name='jack' AND isDelete=0 + Console.WriteLine(sql3); + + var sql4 = db.Queryable().Filter("Myfilter",isDisabledGobalFilter:true).ToSql();//only Myfilter + //SELECT [Id],[Name],[Price],[CreateTime] FROM `order` WHERE Name='jack' + Console.WriteLine(sql4); + Console.WriteLine("#### Filter End ####"); + } + + + public static SqlSugarClient GetInstance() + { + SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() { DbType = DbType.MySqlConnector, ConnectionString = Config.ConnectionString, IsAutoCloseConnection = true }); + + //single table query gobal filter + db.QueryFilter.Add(new SqlFilterItem() + { + FilterValue = filterDb => + { + //Writable logic + return new SqlFilterResult() { Sql = " isDelete=0" };//Global string perform best + } + }); + + //Multi-table query gobal filter + db.QueryFilter.Add(new SqlFilterItem() + { + FilterValue = filterDb => + { + //Writable logic + return new SqlFilterResult() { Sql = " main.isDelete=0" }; + }, + IsJoinQuery=true + }); + + //Specific filters + db.QueryFilter.Add(new SqlFilterItem() + { + FilterName= "Myfilter", + FilterValue = filterDb => + { + //Writable logic + return new SqlFilterResult() { Sql = "Name='jack'" }; + } + }); + return db; + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/AttributeTable.cs b/Src/Asp.Net/MySqlConnectorTest/Models/AttributeTable.cs new file mode 100644 index 000000000..c1a43ad12 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.Net/MySqlConnectorTest/Models/CarType.cs b/Src/Asp.Net/MySqlConnectorTest/Models/CarType.cs new file mode 100644 index 000000000..00dc12710 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/CarType.cs @@ -0,0 +1,7 @@ +namespace OrmTest +{ + public class CarType + { + public bool State { get; set; } + } +} \ No newline at end of file diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Custom.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Custom.cs new file mode 100644 index 000000000..3b8871c57 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.Net/MySqlConnectorTest/Models/EntityMapper.cs b/Src/Asp.Net/MySqlConnectorTest/Models/EntityMapper.cs new file mode 100644 index 000000000..b597012fb --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.Net/MySqlConnectorTest/Models/Mapper.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Mapper.cs new file mode 100644 index 000000000..8d7991d6c --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Mapper.cs @@ -0,0 +1,54 @@ +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; } + } + public class B + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/MyCustomAttributeTable.cs b/Src/Asp.Net/MySqlConnectorTest/Models/MyCustomAttributeTable.cs new file mode 100644 index 000000000..11359d062 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/MyCustomAttributeTable.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("CustomAttributeTable")] + //[SugarTable("CustomAttributeTable")] + public class MyCustomAttributeTable + { + + [Key] + //[SugarColumn(IsPrimaryKey =true)] + public string Id { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Order.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Order.cs new file mode 100644 index 000000000..d7ff068b8 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.Net/MySqlConnectorTest/Models/OrderItem.cs b/Src/Asp.Net/MySqlConnectorTest/Models/OrderItem.cs new file mode 100644 index 000000000..272e03c74 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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; internal set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/TestTree.cs b/Src/Asp.Net/MySqlConnectorTest/Models/TestTree.cs new file mode 100644 index 000000000..b8250828a --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.Net/MySqlConnectorTest/Models/Tree.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Tree.cs new file mode 100644 index 000000000..d2878de64 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoods.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoods.cs new file mode 100644 index 000000000..86dcf3488 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoods.cs @@ -0,0 +1,604 @@ +using SqlSugar; + +namespace HONORCSData +{ + + /// + /// 商品主表 + /// + [SugarTable("goods")] + public class EGoods + { + /// + /// 商品 + /// + public EGoods() + { + } + private int _GoodsId; + /// + /// 商品id + /// + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnName = "goods_id")] + public int GoodsId { get => _GoodsId; set => _GoodsId = value; } + private string _GoodsNo; + /// + /// 商品编号 + /// + [SugarColumn( ColumnName = "goods_no")] + public string GoodsNo { get => _GoodsNo; set => _GoodsNo = value?.Trim(); } + + private string _BarCode; + /// + /// 条码 + /// + [SugarColumn(ColumnName = "bar_code")] + public string BarCode { get => _BarCode; set => _BarCode = value?.Trim(); } + + private string _Description; + /// + /// 描述 + /// + [SugarColumn(ColumnName = "description")] + public string Description { get => _Description; set => _Description = value?.Trim(); } + + private decimal _RetailPrice; + /// + /// 零售价 + /// + [SugarColumn(ColumnName = "retail_price")] + public decimal RetailPrice { get => _RetailPrice; set => _RetailPrice = value; } + + private decimal _DeliveryPrice; + /// + /// 送货价 + /// + [SugarColumn(ColumnName = "delivery_price")] + public decimal DeliveryPrice { get => _DeliveryPrice; set => _DeliveryPrice = value; } + + private decimal _MemberPrice; + /// + /// 会员价 + /// + [SugarColumn(ColumnName = "member_price")] + public decimal MemberPrice { get => _MemberPrice; set => _MemberPrice = value; } + + private decimal _WholesalePrice; + /// + /// 批发价 + /// + [SugarColumn(ColumnName = "wholesale_price")] + public decimal WholesalePrice { get => _WholesalePrice; set => _WholesalePrice = value; } + + private decimal _ReceiptPrice; + /// + /// 发票价 + /// + [SugarColumn(ColumnName = "receipt_price")] + public decimal ReceiptPrice { get => _ReceiptPrice; set => _ReceiptPrice = value; } + + private decimal _InternetPrice; + /// + /// 网络价 + /// + [SugarColumn(ColumnName = "internet_price")] + public decimal InternetPrice { get => _InternetPrice; set => _InternetPrice = value; } + + private decimal _FriendshipPrice; + /// + /// 友情价 + /// + [SugarColumn(ColumnName = "friendship_price")] + public decimal FriendshipPrice { get => _FriendshipPrice; set => _FriendshipPrice = value; } + + private decimal _SpecialPrice; + /// + /// 特别价 + /// + [SugarColumn(ColumnName = "special_price")] + public decimal SpecialPrice { get => _SpecialPrice; set => _SpecialPrice = value; } + + private decimal _PromotionPrice; + /// + /// 促销价 + /// + [SugarColumn(ColumnName = "promotion_price")] + public decimal PromotionPrice { get => _PromotionPrice; set => _PromotionPrice = value; } + + private decimal _PurchasePrice; + /// + /// 进货价 + /// + [SugarColumn(ColumnName = "purchase_price")] + public decimal PurchasePrice { get => _PurchasePrice; set => _PurchasePrice = value; } + + private string _SpanishName; + /// + /// 西文名称 + /// + [SugarColumn(ColumnName = "spanish_name")] + public string SpanishName { get => _SpanishName; set => _SpanishName = value?.Trim(); } + + private string _Initials; + /// + /// 首字母 + /// + [SugarColumn(ColumnName = "initials")] + public string Initials { get => _Initials; set => _Initials = value?.Trim(); } + + private string _ChineseName; + /// + /// 中文名称 + /// + [SugarColumn(ColumnName = "chinese_name")] + public string ChineseName { get => _ChineseName; set => _ChineseName = value?.Trim(); } + + /// + /// 商品名称 西文中文组合 + /// + [SugarColumn(IsIgnore = true)] + public string GoodsName { get => string.Format("{0}[{1}]", _SpanishName, _ChineseName); } + + private string _ChinesePinyin; + /// + /// 拼音 + /// + [SugarColumn(ColumnName = "chinese_pinyin")] + public string ChinesePinyin { get => _ChinesePinyin; set => _ChinesePinyin = value?.Trim(); } + + private decimal _PackageNumber; + /// + /// 整包数量 + /// + [SugarColumn(ColumnName = "package_number")] + public decimal PackageNumber { get => _PackageNumber; set => _PackageNumber = value; } + + private decimal _BoxNumber; + /// + /// 整箱数量 + /// + [SugarColumn(ColumnName = "box_number")] + public decimal BoxNumber { get => _BoxNumber; set => _BoxNumber = value; } + + private double _WeightCapacity; + /// + /// 重量容量 + /// + [SugarColumn(ColumnName = "weight_capacity")] + public double WeightCapacity { get => _WeightCapacity; set => _WeightCapacity = value; } + + private bool _IsOnlyPerUnit; + /// + /// 是否只按单位 + /// + [SugarColumn(ColumnName = "is_only_per_unit")] + public bool IsOnlyPerUnit { get => _IsOnlyPerUnit; set => _IsOnlyPerUnit = value; } + + private int _GoodsClassId; + /// + /// 商品类别编号 + /// + [SugarColumn(ColumnName = "goods_class_id")] + public int GoodsClassId { get => _GoodsClassId; set => _GoodsClassId = value; } + + /// + /// 商品类别名称 + /// + [SugarColumn(IsIgnore = true)] + public string GoodsClass { get; set; } + + private string _UnitName; + /// + /// 单位名称 + /// + [SugarColumn(ColumnName = "unit_name")] + public string UnitName { get => _UnitName; set => _UnitName = value?.Trim(); } + + private System.DateTime? _GoodsAddDate; + /// + /// 商品添加日期 + /// + [SugarColumn(ColumnName = "goods_add_date")] + public System.DateTime? GoodsAddDate { get => _GoodsAddDate; set => _GoodsAddDate = value ?? default(System.DateTime); } + + private decimal _Discount; + /// + /// 折扣 + /// + [SugarColumn(ColumnName = "discount")] + public decimal Discount { get => _Discount; set => _Discount = value; } + + private decimal _DiscountPrice; + /// + /// 折扣价 + /// + [SugarColumn(ColumnName = "discount_price")] + public decimal DiscountPrice { get => _DiscountPrice; set => _DiscountPrice = value; } + + private decimal _ReceiptPercentage; + /// + /// 发票百分比 + /// + [SugarColumn(ColumnName = "receipt_percentage")] + public decimal ReceiptPercentage { get => _ReceiptPercentage; set => _ReceiptPercentage = value; } + + private System.DateTime? _ExpiryDate; + /// + /// 到期日期 + /// + [SugarColumn(ColumnName = "expiry_date")] + public System.DateTime? ExpiryDate { get => _ExpiryDate; set => _ExpiryDate = value ?? default(System.DateTime); } + + private string _SupplierId; + /// + /// 供应商编号 + /// + [SugarColumn(ColumnName = "supplier_id")] + public string SupplierId { get => _SupplierId; set => _SupplierId = value?.Trim(); } + + private int _IsGift; + /// + /// 是否有赠品 + /// + [SugarColumn(ColumnName = "is_gift")] + public int IsGift { get => _IsGift; set => _IsGift = value; } + + private int _IsPrivate; + /// + /// 是否私营 + /// + [SugarColumn(ColumnName = "is_private")] + public int IsPrivate { get => _IsPrivate; set => _IsPrivate = value; } + + private System.Boolean? _IsPriceByVolume; + /// + /// 是否以量定价 + /// + [SugarColumn(ColumnName = "is_price_by_volume")] + public System.Boolean? IsPriceByVolume { get { return this._IsPriceByVolume; } set { this._IsPriceByVolume = value ?? default(System.Boolean); } } + + private System.Boolean? _IsDiscountByQuantity; + /// + /// 是否以量定折扣 + /// + [SugarColumn(ColumnName = "is_discount_by_quantity")] + public System.Boolean? IsDiscountByQuantity { get { return this._IsDiscountByQuantity; } set { this._IsDiscountByQuantity = value ?? default(System.Boolean); } } + + private decimal _Price1; + /// + /// 价格1 + /// + [SugarColumn(ColumnName = "price1")] + public decimal Price1 { get => _Price1; set => _Price1 = value; } + + private decimal _Discount1; + /// + /// 折扣1 + /// + [SugarColumn(ColumnName = "discount1")] + public decimal Discount1 { get => _Discount1; set => _Discount1 = value; } + + private decimal _Number1; + /// + /// 数量1 + /// + [SugarColumn(ColumnName = "number1")] + public decimal Number1 { get => _Number1; set => _Number1 = value; } + + private decimal _Price2; + /// + /// 价格2 + /// + [SugarColumn(ColumnName = "price2")] + public decimal Price2 { get => _Price2; set => _Price2 = value; } + + private decimal _Discount2; + /// + /// 折扣2 + /// + [SugarColumn(ColumnName = "discount2")] + public decimal Discount2 { get => _Discount2; set => _Discount2 = value; } + + private decimal _Number2; + /// + /// 数量2 + /// + [SugarColumn(ColumnName = "number2")] + public decimal Number2 { get => _Number2; set => _Number2 = value; } + + private decimal _Price3; + /// + /// 价格3 + /// + [SugarColumn(ColumnName = "price3")] + public decimal Price3 { get => _Price3; set => _Price3 = value; } + + private decimal _Discount3; + /// + /// 折扣3 + /// + [SugarColumn(ColumnName = "discount3")] + public decimal Discount3 { get => _Discount3; set => _Discount3 = value; } + + private decimal _Number3; + /// + /// 数量3 + /// + [SugarColumn(ColumnName = "number3")] + public decimal Number3 { get => _Number3; set => _Number3 = value; } + + private decimal _Price4; + /// + /// 价格4 + /// + [SugarColumn(ColumnName = "price4")] + public decimal Price4 { get => _Price4; set => _Price4 = value; } + + private decimal _Discount4; + /// + /// 折扣4 + /// + [SugarColumn(ColumnName = "discount4")] + public decimal Discount4 { get => _Discount4; set => _Discount4 = value; } + + private decimal _Number4; + /// + /// 数量4 + /// + [SugarColumn(ColumnName = "number4")] + public decimal Number4 { get => _Number4; set => _Number4 = value; } + + private decimal _Price5; + /// + /// 价格5 + /// + [SugarColumn(ColumnName = "price5")] + public decimal Price5 { get => _Price5; set => _Price5 = value; } + + private decimal _Discount5; + /// + /// 折扣5 + /// + [SugarColumn(ColumnName = "discount5")] + public decimal Discount5 { get => _Discount5; set => _Discount5 = value; } + + private decimal _Number5; + /// + /// 数量5 + /// + [SugarColumn(ColumnName = "number5")] + public decimal Number5 { get => _Number5; set => _Number5 = value; } + + private decimal _Price6; + /// + /// 价格6 + /// + [SugarColumn(ColumnName = "price6")] + public decimal Price6 { get => _Price6; set => _Price6 = value; } + + private decimal _Discount6; + /// + /// 折扣6 + /// + [SugarColumn(ColumnName = "discount6")] + public decimal Discount6 { get => _Discount6; set => _Discount6 = value; } + + private string _WarehouseSite; + /// + /// 仓库位置 + /// + [SugarColumn(ColumnName = "warehouse_site")] + public string WarehouseSite { get => _WarehouseSite; set => _WarehouseSite = value?.Trim(); } + + private string _GoodsGrade; + /// + /// 商品等级 + /// + [SugarColumn(ColumnName = "goods_grade")] + public string GoodsGrade { get => _GoodsGrade; set => _GoodsGrade = value?.Trim(); } + + private decimal _MinStock; + /// + /// 库存下限 + /// + [SugarColumn(ColumnName = "min_stock")] + public decimal MinStock { get => _MinStock; set => _MinStock = value; } + + private decimal _MaxStock; + /// + /// 库存上限 + /// + [SugarColumn(ColumnName = "max_stock")] + public decimal MaxStock { get => _MaxStock; set => _MaxStock = value; } + + private bool _IsContainImage; + /// + /// 有图案 + /// + [SugarColumn(ColumnName = "is_contain_image")] + public bool IsContainImage { get => _IsContainImage; set => _IsContainImage = value; } + + private string _GoodsImageMd5; + /// + /// 图案的消息摘要 + /// + [SugarColumn(ColumnName = "goods_image_md5")] + public string GoodsImageMd5 { get => _GoodsImageMd5; set => _GoodsImageMd5 = value?.Trim(); } + + private System.DateTime? _ImageUpdateTime; + /// + /// 修改绘图时间 + /// + [SugarColumn(ColumnName = "image_update_time")] + public System.DateTime? ImageUpdateTime { get => _ImageUpdateTime; set => _ImageUpdateTime = value ?? default(System.DateTime); } + //private Goods.EGoodsImage _GoodsImage = new Goods.EGoodsImage(); + ///// + ///// 图片 + ///// + //[SugarColumn(IsIgnore = true)] + //public Goods.EGoodsImage GoodsImage { get=>_GoodsImage; set => _GoodsImage = value; } + + private bool _IsProhibitedChangeDiscount; + /// + /// 是否禁止更改折扣 + /// + [SugarColumn(ColumnName = "is_prohibited_change_discount")] + public bool IsProhibitedChangeDiscount { get => _IsProhibitedChangeDiscount; set => _IsProhibitedChangeDiscount = value; } + + private bool _PrintSign; + /// + /// 打印标记 + /// + [SugarColumn(ColumnName = "print_sign")] + public bool PrintSign { get => _PrintSign; set => _PrintSign = value; } + + private System.DateTime? _PrintSignTime; + /// + /// 打印标记时间 + /// + [SugarColumn(ColumnName = "print_sign_time")] + public System.DateTime? PrintSignTime { get => _PrintSignTime; set => _PrintSignTime = value ?? default(System.DateTime); } + + private bool _IsAddByAttachment; + /// + /// 是否添加为附件 + /// + [SugarColumn(ColumnName = "is_add_by_attachment")] + public bool IsAddByAttachment { get => _IsAddByAttachment; set => _IsAddByAttachment = value; } + + private string _MultipleBarcode; + /// + /// 多条码 + /// + [SugarColumn(ColumnName = "multiple_barcode")] + public string MultipleBarcode { get => _MultipleBarcode; set => _MultipleBarcode = value?.Trim(); } + + private string _PartialConsultation; + /// + /// 部分查询 + /// + [SugarColumn(ColumnName = "partial_consultation")] + public string PartialConsultation { get => _PartialConsultation; set => _PartialConsultation = value?.Trim(); } + + private System.DateTime? _StartDate; + /// + /// 起始日期 + /// + [SugarColumn(ColumnName = "start_date")] + public System.DateTime? StartDate { get => _StartDate; set => _StartDate = value ?? default(System.DateTime); } + + private int _IsLock; + /// + /// 是否锁定:1 锁定(下架) 0 未锁定(在售) + /// + [SugarColumn(ColumnName = "is_lock")] + public int IsLock { get => _IsLock; set => _IsLock = value; } + + private int _SpecialSign; + /// + /// 特殊标识 + /// + [SugarColumn(ColumnName = "special_sign")] + public int SpecialSign { get => _SpecialSign; set => _SpecialSign = value; } + + private string _Remark; + /// + /// 备注 + /// + [SugarColumn(ColumnName = "remark")] + public string Remark { get => _Remark; set => _Remark = value?.Trim(); } + + private string _DelFlag = "0"; + /// + /// 删除标记:1 删除 0 非删除 + /// + [SugarColumn(ColumnName = "del_flag")] + public string DelFlag { get => _DelFlag; set => _DelFlag = value?.Trim(); } + + private int? _BrandId; + /// + /// 商品品牌id + /// + [SugarColumn(ColumnName = "brand_id")] + public int? BrandId { get => _BrandId; set => _BrandId = value ?? default(int); } + + /// + /// 商品品牌名称 + /// + [SugarColumn(IsIgnore = true)] + public string Brand { get; set; } + + private string _Origin; + /// + /// 产地 + /// + [SugarColumn(ColumnName = "origin")] + public string Origin { get => _Origin; set => _Origin = value?.Trim(); } + + private string _ValuationMethod; + /// + /// 计价方式:1 包装 2 称重 + /// + [SugarColumn(ColumnName = "valuation_method")] + public string ValuationMethod { get => _ValuationMethod; set => _ValuationMethod = value?.Trim(); } + + private string _SyncOnlineShop; + /// + /// 是否同步网店:1 同步 0 不同步 + /// + [SugarColumn(ColumnName = "sync_online_shop")] + public string SyncOnlineShop { get => _SyncOnlineShop; set => _SyncOnlineShop = value?.Trim(); } + + private string _PackageSale; + /// + /// 是否整包销售:1 是 0 否 + /// + [SugarColumn(ColumnName = "package_sale")] + public string PackageSale { get => _PackageSale; set => _PackageSale = value?.Trim(); } + + private string _IsEnablePoints; + /// + /// 是否启用积分:1 启用 0 不启用 + /// + [SugarColumn(ColumnName = "is_enable_points")] + public string IsEnablePoints { get => _IsEnablePoints; set => _IsEnablePoints = value?.Trim(); } + + private string _PointsRule; + /// + /// 积分规则 + /// + [SugarColumn(ColumnName = "points_rule")] + public string PointsRule { get => _PointsRule; set => _PointsRule = value?.Trim(); } + + private string _PurchaseSpec; + /// + /// 进货规格 + /// + [SugarColumn(ColumnName = "purchase_spec")] + public string PurchaseSpec { get => _PurchaseSpec; set => _PurchaseSpec = value?.Trim(); } + + private System.Boolean? _IsIntervalPrice; + /// + /// 是否启用区间价格:1 启用 0 不启用 + /// + [SugarColumn(ColumnName = "is_interval_price")] + public System.Boolean? IsIntervalPrice { get { return this._IsIntervalPrice; } set { this._IsIntervalPrice = value ?? default(System.Boolean); } } + + private System.Boolean? _IsCountEarning; + /// + /// 是否计算利润(毛利润):1 启用 0 不启用 + /// + [SugarColumn(ColumnName = "is_count_earning")] + public System.Boolean? IsCountEarning { get { return this._IsCountEarning; } set { this._IsCountEarning = value ?? default(System.Boolean); } } + + private int _TenantId; + /// + /// 所属租户 + /// + [SugarColumn(ColumnName = "tenant_id")] + public int TenantId { get => _TenantId; set => _TenantId = value; } + + [SugarColumn(IsIgnore = true)] + public decimal StockNum { get; set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsBrand.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsBrand.cs new file mode 100644 index 000000000..0965b6e92 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsBrand.cs @@ -0,0 +1,68 @@ +using SqlSugar; + +namespace HONORCSData +{ + /// + /// 商品品牌 + /// + [SugarTable("goods_brand")] + public class EGoodsBrand + { + /// + /// + /// + public EGoodsBrand() + { + } + + private System.Int32 _BrandId; + /// + /// 自增编号 + /// + [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnName = "brand_id")] + public System.Int32 BrandId { get { return this._BrandId; } set { this._BrandId = value; } } + + private System.String _BrandCnName; + /// + /// 中文名称 + /// + [SugarColumn(ColumnName = "brand_cn_name")] + public System.String BrandCnName { get { return this._BrandCnName; } set { this._BrandCnName = value?.Trim(); } } + + private System.String _BranchSpanishName; + /// + /// 西文名称 + /// + [SugarColumn(ColumnName = "branch_spanish_name")] + public System.String BranchSpanishName { get { return this._BranchSpanishName; } set { this._BranchSpanishName = value?.Trim(); } } + + + private System.String _BrandNo; + /// + /// 编号 + /// + [SugarColumn(ColumnName = "brand_no")] + public System.String BrandNo { get { return this._BrandNo; } set { this._BrandNo = value?.Trim(); } } + + private System.String _BrandStatus = "1"; + /// + /// 状态:1 正常 0 禁用 + /// + [SugarColumn(ColumnName = "brand_status")] + public System.String BrandStatus { get { return this._BrandStatus; } set { this._BrandStatus = value?.Trim(); } } + + private System.String _DelFlag = "0"; + /// + /// 是否删除:1 删除 0 未删除 + /// + [SugarColumn(ColumnName = "del_flag")] + public System.String DelFlag { get { return this._DelFlag; } set { this._DelFlag = value?.Trim(); } } + + private int _TenantId; + /// + /// 所属租户 + /// + [SugarColumn(ColumnName = "tenant_id")] + public int TenantId { get => _TenantId; set => _TenantId = value; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsClass.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsClass.cs new file mode 100644 index 000000000..5d0652ee2 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EGoodsClass.cs @@ -0,0 +1,261 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace HONORCSData.Goods +{ + /// + /// 商品种类 + /// + [SugarTable("goods_class")] + public class EGoodsClass + { + private System.Int32 _GoodsClassId; + /// + /// 商品种类编号 + /// + [SugarColumn(IsPrimaryKey = true,ColumnName = "goods_class_id")] + public System.Int32 GoodsClassId { get { return this._GoodsClassId; } set { this._GoodsClassId = value; } } + + private System.String _SpanishName; + /// + /// 西文名称 + /// + [SugarColumn(ColumnName = "spanish_name")] + public System.String SpanishName { get { return this._SpanishName; } set { this._SpanishName = value?.Trim(); } } + + private System.String _ChineseName; + /// + /// 中文名称 + /// + [SugarColumn(ColumnName = "chinese_name")] + public System.String ChineseName { get { return this._ChineseName; } set { this._ChineseName = value?.Trim(); } } + + private System.Int16 _IvaId; + /// + /// iva编号 + /// + [SugarColumn(ColumnName = "iva_id")] + public System.Int16 IvaId { get { return this._IvaId; } set { this._IvaId = value; } } + + + private System.String _GoodsClassNo; + /// + /// 编号 + /// + [SugarColumn(ColumnName = "goods_class_no")] + public System.String GoodsClassNo { get { return this._GoodsClassNo; } set { this._GoodsClassNo = value?.Trim(); } } + + private System.Decimal _Discount; + /// + /// 折扣 + /// + [SugarColumn(ColumnName = "discount")] + public System.Decimal Discount { get { return this._Discount; } set { this._Discount = value; } } + + private System.Decimal _ReceiptPercentage; + /// + /// 发票百分比 + /// + [SugarColumn(ColumnName = "receipt_percentage")] + public System.Decimal ReceiptPercentage { get { return this._ReceiptPercentage; } set { this._ReceiptPercentage = value; } } + + private System.Boolean _IsOnlyPerUnit; + /// + /// 是否仅每单位 + /// + [SugarColumn(ColumnName = "is_only_per_unit")] + public System.Boolean IsOnlyPerUnit { get { return this._IsOnlyPerUnit; } set { this._IsOnlyPerUnit = value; } } + + private System.String _UnitName; + /// + /// 单位名称 + /// + [SugarColumn(ColumnName = "unit_name")] + public System.String UnitName { get { return this._UnitName; } set { this._UnitName = value?.Trim(); } } + + private System.Boolean _IsCountEarning; + /// + /// 是否计算收益 + /// + [SugarColumn(ColumnName = "is_count_earning")] + public System.Boolean IsCountEarning { get { return this._IsCountEarning; } set { this._IsCountEarning = value; } } + + private System.Boolean _IsCountStock; + /// + /// 是否计算库存 + /// + [SugarColumn(ColumnName = "is_count_stock")] + public System.Boolean IsCountStock { get { return this._IsCountStock; } set { this._IsCountStock = value; } } + + private System.Boolean _IsProhibitedChangeDiscount; + /// + /// 是否禁止更改折扣 + /// + [SugarColumn(ColumnName = "is_prohibited_change_discount")] + public System.Boolean IsProhibitedChangeDiscount { get { return this._IsProhibitedChangeDiscount; } set { this._IsProhibitedChangeDiscount = value; } } + + private System.Boolean _IsGift; + /// + /// 是否为赠品 + /// + [SugarColumn(ColumnName = "is_gift")] + public System.Boolean IsGift { get { return this._IsGift; } set { this._IsGift = value; } } + + private System.Boolean _IsPrivate; + /// + /// 是否私营 + /// + [SugarColumn(ColumnName = "is_private")] + public System.Boolean IsPrivate { get { return this._IsPrivate; } set { this._IsPrivate = value; } } + + private System.Int16 _GoodsStorehouse; + /// + /// 商品仓库 + /// + [SugarColumn(ColumnName = "goods_storehouse")] + public System.Int16 GoodsStorehouse { get { return this._GoodsStorehouse; } set { this._GoodsStorehouse = value; } } + + private System.Decimal _RetailPriceProfitPercentage; + /// + /// 零售价利润百分比 + /// + [SugarColumn(ColumnName = "retail_price_profit_percentage")] + public System.Decimal RetailPriceProfitPercentage { get { return this._RetailPriceProfitPercentage; } set { this._RetailPriceProfitPercentage = value; } } + + private System.Decimal _DeliveryPriceProfitPercentage; + /// + /// 送货价收益百分比 + /// + [SugarColumn(ColumnName = "delivery_price_profit_percentage")] + public System.Decimal DeliveryPriceProfitPercentage { get { return this._DeliveryPriceProfitPercentage; } set { this._DeliveryPriceProfitPercentage = value; } } + + private System.Decimal _MemberPriceProfitPercentage; + /// + /// 会员价百分比 + /// + [SugarColumn(ColumnName = "member_price_profit_percentage")] + public System.Decimal MemberPriceProfitPercentage { get { return this._MemberPriceProfitPercentage; } set { this._MemberPriceProfitPercentage = value; } } + + private System.Decimal _WholesalePriceProfitPercentage; + /// + /// 批发价收益百分比 + /// + [SugarColumn(ColumnName = "wholesale_price_profit_percentage")] + public System.Decimal WholesalePriceProfitPercentage { get { return this._WholesalePriceProfitPercentage; } set { this._WholesalePriceProfitPercentage = value; } } + + private System.Decimal _ReceiptPriceProfitPercentage; + /// + /// 发票价格收益百分比 + /// + [SugarColumn(ColumnName = "receipt_price_profit_percentage")] + public System.Decimal ReceiptPriceProfitPercentage { get { return this._ReceiptPriceProfitPercentage; } set { this._ReceiptPriceProfitPercentage = value; } } + + private System.Decimal _InternetPriceProfitPercentage; + /// + /// 网络价格收益百分比 + /// + [SugarColumn(ColumnName = "internet_price_profit_percentage")] + public System.Decimal InternetPriceProfitPercentage { get { return this._InternetPriceProfitPercentage; } set { this._InternetPriceProfitPercentage = value; } } + + private System.Decimal _FriendshipPriceProfitPercentage; + /// + /// 友情价收益百分比 + /// + [SugarColumn(ColumnName = "friendship_price_profit_percentage")] + public System.Decimal FriendshipPriceProfitPercentage { get { return this._FriendshipPriceProfitPercentage; } set { this._FriendshipPriceProfitPercentage = value; } } + + private System.Decimal _SpecialPriceProfitPercentage; + /// + /// 特别价格收益百分比 + /// + [SugarColumn(ColumnName = "special_price_profit_percentage")] + public System.Decimal SpecialPriceProfitPercentage { get { return this._SpecialPriceProfitPercentage; } set { this._SpecialPriceProfitPercentage = value; } } + + private System.Decimal _PromotionPriceProfitPercentage; + /// + /// 促销价格收益百分比 + /// + [SugarColumn(ColumnName = "promotion_price_profit_percentage")] + public System.Decimal PromotionPriceProfitPercentage { get { return this._PromotionPriceProfitPercentage; } set { this._PromotionPriceProfitPercentage = value; } } + + private System.Boolean _IsLock; + /// + /// 是否锁定 + /// + [SugarColumn(ColumnName = "is_lock")] + public System.Boolean IsLock { get { return this._IsLock; } set { this._IsLock = value; } } + + private System.String _Remark; + /// + /// 备注 + /// + [SugarColumn(ColumnName = "remark")] + public System.String Remark { get { return this._Remark; } set { this._Remark = value?.Trim(); } } + + private System.Int32 _ParentId; + /// + /// 上级分类id + /// + [SugarColumn(ColumnName = "parent_id")] + public System.Int32 ParentId { get { return this._ParentId; } set { this._ParentId = value; } } + + private System.String _IsEnablePoints; + /// + /// 是否启用积分:1 启用 0 不启用 + /// + [SugarColumn(ColumnName = "is_enable_points")] + public System.String IsEnablePoints { get { return this._IsEnablePoints; } set { this._IsEnablePoints = value?.Trim(); } } + + private System.String _PointsRule; + /// + /// 积分规则 + /// + [SugarColumn(ColumnName = "points_rule")] + public System.String PointsRule { get { return this._PointsRule; } set { this._PointsRule = value?.Trim(); } } + + private System.String _ValuationMethod; + /// + /// 计价方式:1 包装 2 称重 + /// + [SugarColumn(ColumnName = "valuation_method")] + public System.String ValuationMethod { get { return this._ValuationMethod; } set { this._ValuationMethod = value?.Trim(); } } + + private System.String _DelFlag; + /// + /// 删除标记:1 删除 0 未删除 + /// + [SugarColumn(ColumnName = "del_flag")] + public System.String DelFlag { get { return this._DelFlag; } set { this._DelFlag = value?.Trim(); } } + + private System.String _IsShowOnCshier = "1"; + /// + /// 收银前台是否显示:1 显示 0 不显示 + /// + [SugarColumn(ColumnName = "is_show_on_cashier")] + public System.String IsShowOnCshier { get { return this._IsShowOnCshier; } set { this._IsShowOnCshier = value?.Trim(); } } + + private System.Int32 _TenantId; + /// + /// 所属租户 + /// + [SugarColumn(ColumnName = "tenant_id")] + public System.Int32 TenantId { get { return this._TenantId; } set { this._TenantId = value; } } + } + public class EGoodsClassTree : EGoodsClass + { + /// + /// 子集 + /// + [SugarColumn(IsIgnore = true)] + public List Childrens { get; set; } + /// + /// 是否选中 + /// + [SugarColumn(IsIgnore = true)] + public bool IsSelected { get; set; } = false; + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaran.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaran.cs new file mode 100644 index 000000000..dccc953a2 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaran.cs @@ -0,0 +1,404 @@ +using SqlSugar; + +namespace HONORCSData.Order +{ + /// + /// 出库单/入库单 + /// + /// + [SugarTable("order_albaran")] + public class EOrderAlbaran + { + /// + /// 出库单/入库单 + /// + public EOrderAlbaran() + { + } + + private System.Int32 _AlbaranId; + /// + /// 主键id + /// + [SugarColumn(IsPrimaryKey =true, ColumnName = "albaran_id")] + public System.Int32 AlbaranId { get { return this._AlbaranId; } set { this._AlbaranId = value; } } + + private System.Int32? _ServerAccountId; + /// + /// 服务器端账户id + /// + [SugarColumn(ColumnName = "server_account_id")] + public System.Int32? ServerAccountId { get { return this._ServerAccountId; } set { this._ServerAccountId = value; } } + + private System.String _ClientNo; + /// + /// 客户/供应商ID + /// + [SugarColumn(ColumnName = "client_no")] + public System.String ClientNo { get { return this._ClientNo; } set { this._ClientNo = value; } } + + private System.Boolean? _IsClientWithoutIva; + /// + /// 客户是否不含iva:1 含 0 不含 + /// + [SugarColumn(ColumnName = "is_client_without_iva")] + public System.Boolean? IsClientWithoutIva { get { return this._IsClientWithoutIva; } set { this._IsClientWithoutIva = value; } } + + private System.Boolean? _IsClientWithoutIvaAndIvaInclude; + /// + /// ClienteSinIVA的IVAIncluido是否勾选:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_client_without_iva_and_iva_include")] + public System.Boolean? IsClientWithoutIvaAndIvaInclude { get { return this._IsClientWithoutIvaAndIvaInclude; } set { this._IsClientWithoutIvaAndIvaInclude = value; } } + + private System.Boolean? _IsClientReq; + /// + /// 客户是否有REQ:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_client_req")] + public System.Boolean? IsClientReq { get { return this._IsClientReq; } set { this._IsClientReq = value; } } + + private System.Boolean? _IsClientReqAndReqInclude; + /// + /// ClienteREQ的req_include是否勾选:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_client_req_and_req_include")] + public System.Boolean? IsClientReqAndReqInclude { get { return this._IsClientReqAndReqInclude; } set { this._IsClientReqAndReqInclude = value; } } + + private System.Decimal? _Discount; + /// + /// 折扣 + /// + [SugarColumn(ColumnName = "discount")] + public System.Decimal? Discount { get { return this._Discount; } set { this._Discount = value; } } + + private System.Decimal? _DirectDiscount; + /// + /// 直接折扣 + /// + [SugarColumn(ColumnName = "direct_discount")] + public System.Decimal? DirectDiscount { get { return this._DirectDiscount; } set { this._DirectDiscount = value; } } + + private System.Int16? _IvaRule; + /// + /// iva规则(id) + /// + [SugarColumn(ColumnName = "iva_rule")] + public System.Int16? IvaRule { get { return this._IvaRule; } set { this._IvaRule = value; } } + + private System.Int32? _IvaId; + /// + /// iva_id + /// + [SugarColumn(ColumnName = "iva_id")] + public System.Int32? IvaId { get { return this._IvaId; } set { this._IvaId = value; } } + + private System.Int16? _UsePrice; + /// + /// 使用价格:1 零售价 2 会员价 3 进货价 + /// + [SugarColumn(ColumnName = "use_price")] + public System.Int16? UsePrice { get { return this._UsePrice; } set { this._UsePrice = value; } } + + private System.Decimal? _Total; + /// + /// 共计 + /// + [SugarColumn(ColumnName = "total")] + public System.Decimal? Total { get { return this._Total; } set { this._Total = value; } } + + private System.Decimal? _TotalDiscount; + /// + /// 折扣总计 + /// + [SugarColumn(ColumnName = "total_discount")] + public System.Decimal? TotalDiscount { get { return this._TotalDiscount; } set { this._TotalDiscount = value; } } + + private System.Decimal? _TotalVale; + /// + /// vale代金券总计 + /// + [SugarColumn(ColumnName = "total_vale")] + public System.Decimal? TotalVale { get { return this._TotalVale; } set { this._TotalVale = value; } } + + private System.Decimal? _Profit; + /// + /// 利润 + /// + [SugarColumn(ColumnName = "profit")] + public System.Decimal? Profit { get { return this._Profit; } set { this._Profit = value; } } + + private System.Decimal? _TotalNumber; + /// + /// 总数量 + /// + [SugarColumn(ColumnName = "total_number")] + public System.Decimal? TotalNumber { get { return this._TotalNumber; } set { this._TotalNumber = value; } } + + private System.Decimal? _TotalCash; + /// + /// 总现金 + /// + [SugarColumn(ColumnName = "total_cash")] + public System.Decimal? TotalCash { get { return this._TotalCash; } set { this._TotalCash = value; } } + + private System.DateTime? _AlbaranDate; + /// + /// albaran日期 + /// + [SugarColumn(ColumnName = "albaran_date")] + public System.DateTime? AlbaranDate { get { return this._AlbaranDate; } set { this._AlbaranDate = value; } } + + private System.DateTime? _EntryTime; + /// + /// 录入时间 + /// + [SugarColumn(ColumnName = "entry_time")] + public System.DateTime? EntryTime { get { return this._EntryTime; } set { this._EntryTime = value; } } + + private System.String _OriginDocType; + /// + /// 原始文件类型 + /// + [SugarColumn(ColumnName = "origin_doc_type")] + public System.String OriginDocType { get { return this._OriginDocType; } set { this._OriginDocType = value; } } + + private System.Int32? _OriginDocId; + /// + /// 原始文件编号 + /// + [SugarColumn(ColumnName = "origin_doc_id")] + public System.Int32? OriginDocId { get { return this._OriginDocId; } set { this._OriginDocId = value; } } + + private System.String _DestinationDocType; + /// + /// 目的文件类型 + /// + [SugarColumn(ColumnName = "destination_doc_type")] + public System.String DestinationDocType { get { return this._DestinationDocType; } set { this._DestinationDocType = value; } } + + private System.Int32? _DestinationDocId; + /// + /// 目的文件编号 + /// + [SugarColumn(ColumnName = "destination_doc_id")] + public System.Int32? DestinationDocId { get { return this._DestinationDocId; } set { this._DestinationDocId = value; } } + + private System.Int16? _ChargeType; + /// + /// 收费类型 + /// + [SugarColumn(ColumnName = "charge_type")] + public System.Int16? ChargeType { get { return this._ChargeType; } set { this._ChargeType = value; } } + + private System.Decimal? _Cash; + /// + /// 收费类型 + /// + [SugarColumn(ColumnName = "cash")] + public System.Decimal? Cash { get { return this._Cash; } set { this._Cash = value; } } + + private System.Int32? _AgentId; + /// + /// 代理商id + /// + [SugarColumn(ColumnName = "agent_id")] + public System.Int32? AgentId { get { return this._AgentId; } set { this._AgentId = value; } } + + private System.Int32? _TransporterId; + /// + /// 运输商ID + /// + [SugarColumn(ColumnName = "transporter_id")] + public System.Int32? TransporterId { get { return this._TransporterId; } set { this._TransporterId = value; } } + + private System.String _CarNo; + /// + /// 车牌号 + /// + [SugarColumn(ColumnName = "car_no")] + public System.String CarNo { get { return this._CarNo; } set { this._CarNo = value; } } + + private System.Int32? _Operator; + /// + /// 操作员编号 + /// + [SugarColumn(ColumnName = "operator")] + public System.Int32? Operator { get { return this._Operator; } set { this._Operator = value; } } + + private System.Int32? _Verifier; + /// + /// 审核员编号 + /// + [SugarColumn(ColumnName = "verifier")] + public System.Int32? Verifier { get { return this._Verifier; } set { this._Verifier = value; } } + + private System.Int32? _StorehouseId; + /// + /// 仓库id + /// + [SugarColumn(ColumnName = "storehouse_id")] + public System.Int32? StorehouseId { get { return this._StorehouseId; } set { this._StorehouseId = value; } } + + private System.String _AttachedDocSymbol; + /// + /// 附加文件符号 + /// + [SugarColumn(ColumnName = "attached_doc_symbol")] + public System.String AttachedDocSymbol { get { return this._AttachedDocSymbol; } set { this._AttachedDocSymbol = value; } } + + private System.Int32? _PrePaymentMethod; + /// + /// 预付款方式 + /// + [SugarColumn(ColumnName = "pre_payment_method")] + public System.Int32? PrePaymentMethod { get { return this._PrePaymentMethod; } set { this._PrePaymentMethod = value; } } + + private System.String _ComputerName; + /// + /// 计算机名称 + /// + [SugarColumn(ColumnName = "computer_name")] + public System.String ComputerName { get { return this._ComputerName; } set { this._ComputerName = value; } } + + private System.String _Hash; + /// + /// 哈希 + /// + [SugarColumn(ColumnName = "hash")] + public System.String Hash { get { return this._Hash; } set { this._Hash = value; } } + + private System.Int32? _CifId; + /// + /// cif_id(到岸编号) + /// + [SugarColumn(ColumnName = "cif_id")] + public System.Int32? CifId { get { return this._CifId; } set { this._CifId = value; } } + + private System.String _SubStoreId; + /// + /// 子商店编号 + /// + [SugarColumn(ColumnName = "sub_store_id")] + public System.String SubStoreId { get { return this._SubStoreId; } set { this._SubStoreId = value; } } + + private System.Decimal? _AbonoTotal; + /// + /// abono总计 + /// + [SugarColumn(ColumnName = "abono_total")] + public System.Decimal? AbonoTotal { get { return this._AbonoTotal; } set { this._AbonoTotal = value; } } + + private System.Decimal? _PaymentTotal; + /// + /// 付款总计 + /// + [SugarColumn(ColumnName = "payment_total")] + public System.Decimal? PaymentTotal { get { return this._PaymentTotal; } set { this._PaymentTotal = value; } } + + private System.Boolean? _IsCharged; + /// + /// 是否已收款:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_charged")] + public System.Boolean? IsCharged { get { return this._IsCharged; } set { this._IsCharged = value; } } + + private System.Boolean? _IsLock; + /// + /// 是否锁定:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_lock")] + public System.Boolean? IsLock { get { return this._IsLock; } set { this._IsLock = value; } } + + private System.Boolean? _IsCanceled; + /// + /// 是否取消:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_canceled")] + public System.Boolean? IsCanceled { get { return this._IsCanceled; } set { this._IsCanceled = value; } } + + private System.String _IsModify; + /// + /// 是否修改:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_modify")] + public System.String IsModify { get { return this._IsModify; } set { this._IsModify = value; } } + + private System.Boolean? _IsSendEmail; + /// + /// 是否发送电子邮件:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_send_email")] + public System.Boolean? IsSendEmail { get { return this._IsSendEmail; } set { this._IsSendEmail = value; } } + + private System.String _Remark; + /// + /// 备注 + /// + [SugarColumn(ColumnName = "remark")] + public System.String Remark { get { return this._Remark; } set { this._Remark = value; } } + + private System.String _AlbaranNo; + /// + /// 订单编号 + /// + [SugarColumn(ColumnName = "albaran_no")] + public System.String AlbaranNo { get { return this._AlbaranNo; } set { this._AlbaranNo = value; } } + + private System.Int16? _AlbaranType; + /// + /// 订单类型:1 入库 2 出库 + /// + [SugarColumn(ColumnName = "albaran_type")] + public System.Int16? AlbaranType { get { return this._AlbaranType; } set { this._AlbaranType = value; } } + + private System.Int32? _CreateTime; + /// + /// 创建时间 + /// + [SugarColumn(ColumnName = "create_time")] + public System.Int32? CreateTime { get { return this._CreateTime; } set { this._CreateTime = value; } } + + private System.Int32? _UpdateTime; + /// + /// 修改时间 + /// + [SugarColumn(ColumnName = "update_time")] + public System.Int32? UpdateTime { get { return this._UpdateTime; } set { this._UpdateTime = value; } } + + private System.String _VerifyStatus; + /// + /// albaran(入库/出库单)审核状态:1 审核 0 未审核 + /// + [SugarColumn(ColumnName = "verify_status")] + public System.String VerifyStatus { get { return this._VerifyStatus; } set { this._VerifyStatus = value; } } + + private System.Int32? _VerifyTime; + /// + /// 审核日期 + /// + [SugarColumn(ColumnName = "verify_time")] + public System.Int32? VerifyTime { get { return this._VerifyTime; } set { this._VerifyTime = value; } } + + private System.Int32? _PurchaseReceiveId; + /// + /// 采购收货订单Id + /// + [SugarColumn(ColumnName = "purchase_receive_id")] + public System.Int32? PurchaseReceiveId { get { return this._PurchaseReceiveId; } set { this._PurchaseReceiveId = value; } } + + private System.String _DelFlag; + /// + /// 删除标记:1 删除 0 未删除 + /// + [SugarColumn(ColumnName = "del_flag")] + public System.String DelFlag { get { return this._DelFlag; } set { this._DelFlag = value; } } + + private System.Int32 _TenantId; + /// + /// 所属租户 + /// + [SugarColumn(ColumnName = "tenant_id")] + public System.Int32 TenantId { get { return this._TenantId; } set { this._TenantId = value; } } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaranDetail.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaranDetail.cs new file mode 100644 index 000000000..ab5c3730c --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderAlbaranDetail.cs @@ -0,0 +1,234 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace HONORCSData.Order +{ + /// + /// 出库单/入库单详情 + /// + [SugarTable("order_albaran_detail")] + public class EOrderAlbaranDetail + { + /// + /// 出库单/入库单详情 + /// + public EOrderAlbaranDetail() + { + } + + private System.Int32 _AlbaranId; + /// + /// albaran_id + /// + [SugarColumn(ColumnName = "albaran_id")] + public System.Int32 AlbaranId { get { return this._AlbaranId; } set { this._AlbaranId = value; } } + + private System.String _GoodsNo; + /// + /// 商品编号 + /// + [SugarColumn(ColumnName = "goods_no")] + public System.String GoodsNo { get { return this._GoodsNo; } set { this._GoodsNo = value; } } + + private System.String _BarCode; + /// + /// 条码 + /// + [SugarColumn(ColumnName = "bar_code")] + public System.String BarCode { get { return this._BarCode; } set { this._BarCode = value; } } + + private System.Boolean _IsBlanceBarCode; + /// + /// 是否对称条码:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_blance_bar_code")] + public System.Boolean IsBlanceBarCode { get { return this._IsBlanceBarCode; } set { this._IsBlanceBarCode = value; } } + + private System.String _SpanishName; + /// + /// 西文名称 + /// + [SugarColumn(ColumnName = "spanish_name")] + public System.String SpanishName { get { return this._SpanishName; } set { this._SpanishName = value; } } + + private System.String _ChineseName; + /// + /// 中文名称 + /// + [SugarColumn(ColumnName = "chinese_name")] + public System.String ChineseName { get { return this._ChineseName; } set { this._ChineseName = value; } } + + private System.Decimal? _Price; + /// + /// 价格 + /// + [SugarColumn(ColumnName = "price")] + public System.Decimal? Price { get { return this._Price; } set { this._Price = value; } } + + private System.Decimal? _Number; + /// + /// 数量 + /// + [SugarColumn(ColumnName = "number")] + public System.Decimal? Number { get { return this._Number; } set { this._Number = value; } } + + private System.Decimal? _Iva; + /// + /// iva + /// + [SugarColumn(ColumnName = "iva")] + public System.Decimal? Iva { get { return this._Iva; } set { this._Iva = value; } } + + private System.Decimal? _Req; + /// + /// req + /// + [SugarColumn(ColumnName = "req")] + public System.Decimal? Req { get { return this._Req; } set { this._Req = value; } } + + private System.Int32? _IvaId; + /// + /// iva_id + /// + [SugarColumn(ColumnName = "iva_id")] + public System.Int32? IvaId { get { return this._IvaId; } set { this._IvaId = value; } } + + private System.Decimal? _Discount; + /// + /// 折扣 + /// + [SugarColumn(ColumnName = "discount")] + public System.Decimal? Discount { get { return this._Discount; } set { this._Discount = value; } } + + private System.Boolean? _IsProhibitedChangeDiscount; + /// + /// 是否禁止更改折扣:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_prohibited_change_discount")] + public System.Boolean? IsProhibitedChangeDiscount { get { return this._IsProhibitedChangeDiscount; } set { this._IsProhibitedChangeDiscount = value; } } + + private System.Decimal? _CostPrice; + /// + /// 成本价 + /// + [SugarColumn(ColumnName = "cost_price")] + public System.Decimal? CostPrice { get { return this._CostPrice; } set { this._CostPrice = value; } } + + private System.String _Commentary; + /// + /// 批注 + /// + [SugarColumn(ColumnName = "commentary")] + public System.String Commentary { get { return this._Commentary; } set { this._Commentary = value; } } + + private System.Boolean? _IsTemporary; + /// + /// 是否是临时的:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_temporary")] + public System.Boolean? IsTemporary { get { return this._IsTemporary; } set { this._IsTemporary = value; } } + + private System.Int32? _OrderId; + /// + /// 订单id + /// + [SugarColumn(ColumnName = "order_id")] + public System.Int32? OrderId { get { return this._OrderId; } set { this._OrderId = value; } } + + private System.Decimal? _PackageAmount; + /// + /// 包装数量(包数) + /// + [SugarColumn(ColumnName = "package_amount")] + public System.Decimal? PackageAmount { get { return this._PackageAmount; } set { this._PackageAmount = value; } } + + private System.Decimal? _Total; + /// + /// 合计 + /// + [SugarColumn(ColumnName = "total")] + public System.Decimal? Total { get { return this._Total; } set { this._Total = value; } } + + private System.String _Remark; + /// + /// 备注 + /// + [SugarColumn(ColumnName = "remark")] + public System.String Remark { get { return this._Remark; } set { this._Remark = value; } } + + private System.String _DelFlag; + /// + /// 删除标记:1 删除 0 未删除 + /// + [SugarColumn(ColumnName = "del_flag")] + public System.String DelFlag { get { return this._DelFlag; } set { this._DelFlag = value; } } + + private System.String _UnitName; + /// + /// 单位名称 + /// + [SugarColumn(ColumnName = "unit_name")] + public System.String UnitName { get { return this._UnitName; } set { this._UnitName = value; } } + + private System.String _PurchaseSpec; + /// + /// 进货规格 + /// + [SugarColumn(ColumnName = "purchase_spec")] + public System.String PurchaseSpec { get { return this._PurchaseSpec; } set { this._PurchaseSpec = value; } } + + private System.Int32? _GoodsClassId; + /// + /// 商品类别 + /// + [SugarColumn(ColumnName = "goods_class_id")] + public System.Int32? GoodsClassId { get { return this._GoodsClassId; } set { this._GoodsClassId = value; } } + + private System.String _GoodsClassName; + /// + /// 商品类别名称 + /// + [SugarColumn(ColumnName = "goods_class_name")] + public System.String GoodsClassName { get { return this._GoodsClassName; } set { this._GoodsClassName = value; } } + + private System.Int32? _GoodsBrandId; + /// + /// 商品品牌 + /// + [SugarColumn(ColumnName = "goods_brand_id")] + public System.Int32? GoodsBrandId { get { return this._GoodsBrandId; } set { this._GoodsBrandId = value; } } + + private System.String _GoodsBrandName; + /// + /// 商品品牌名称 + /// + [SugarColumn(ColumnName = "goods_brand_name")] + public System.String GoodsBrandName { get { return this._GoodsBrandName; } set { this._GoodsBrandName = value; } } + + private System.Int32 _Id; + /// + /// 主键 + /// + [SugarColumn(IsPrimaryKey = true, ColumnName = "id")] + public System.Int32 Id { get { return this._Id; } set { this._Id = value; } } + + private System.Int32 _TenantId; + /// + /// 所属租户id + /// + [SugarColumn(ColumnName = "tenant_id")] + public System.Int32 TenantId { get { return this._TenantId; } set { this._TenantId = value; } } + + [SugarColumn(IsIgnore = true)] + public int Index { get; set; } + } + + public class ViewModelOrderAlbaranDetail: EOrderAlbaranDetail + { + + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturn.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturn.cs new file mode 100644 index 000000000..fd02d71ef --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturn.cs @@ -0,0 +1,381 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace HONORCSData.Order +{ + /// + /// 退货单 + /// + [SugarTable("order_return")] + public class EOrderReturn + { + /// + /// 退货单 + /// + + public EOrderReturn() + { + } + + private System.Int32 _OrderReturnId; + /// + /// 主键id + /// + [SugarColumn(IsPrimaryKey = true, ColumnName = "order_return_id")] + public System.Int32 OrderReturnId { get { return this._OrderReturnId; } set { this._OrderReturnId = value; } } + + private System.Int32? _ServerAccountId; + /// + /// 服务器端账户id + /// + [SugarColumn(ColumnName = "server_account_id")] + public System.Int32? ServerAccountId { get { return this._ServerAccountId; } set { this._ServerAccountId = value; } } + + private System.DateTime? _ReturnTime; + /// + /// 退货日期 + /// + [SugarColumn(ColumnName = "return_time")] + public System.DateTime? ReturnTime { get { return this._ReturnTime; } set { this._ReturnTime = value; } } + + private System.DateTime? _EntryTime; + /// + /// 录入时间 + /// + [SugarColumn(ColumnName = "entry_time")] + public System.DateTime? EntryTime { get { return this._EntryTime; } set { this._EntryTime = value; } } + + private System.String _OriginDocType; + /// + /// 原始文件类型 + /// + [SugarColumn(ColumnName = "origin_doc_type")] + public System.String OriginDocType { get { return this._OriginDocType; } set { this._OriginDocType = value; } } + + private System.Int32? _OriginDocId; + /// + /// 原始文件编号 + /// + [SugarColumn(ColumnName = "origin_doc_id")] + public System.Int32? OriginDocId { get { return this._OriginDocId; } set { this._OriginDocId = value; } } + + private System.String _DestinationDocType; + /// + /// 目的文件类型 + /// + [SugarColumn(ColumnName = "destination_doc_type")] + public System.String DestinationDocType { get { return this._DestinationDocType; } set { this._DestinationDocType = value; } } + + private System.Int32? _DestinationDocId; + /// + /// 目的文件编号 + /// + [SugarColumn(ColumnName = "destination_doc_id")] + public System.Int32? DestinationDocId { get { return this._DestinationDocId; } set { this._DestinationDocId = value; } } + + private System.Int16? _ChargeType; + /// + /// 收费类型 + /// + [SugarColumn(ColumnName = "charge_type")] + public System.Int16? ChargeType { get { return this._ChargeType; } set { this._ChargeType = value; } } + + private System.Decimal? _Cash; + /// + /// 现金 + /// + [SugarColumn(ColumnName = "cash")] + public System.Decimal? Cash { get { return this._Cash; } set { this._Cash = value; } } + + private System.Decimal? _Discount; + /// + /// 折扣 + /// + [SugarColumn(ColumnName = "discount")] + public System.Decimal? Discount { get { return this._Discount; } set { this._Discount = value; } } + + private System.Decimal? _DirectDiscount; + /// + /// 直接折扣 + /// + [SugarColumn(ColumnName = "direct_discount")] + public System.Decimal? DirectDiscount { get { return this._DirectDiscount; } set { this._DirectDiscount = value; } } + + private System.Decimal? _Total; + /// + /// 共计 + /// + [SugarColumn(ColumnName = "total")] + public System.Decimal? Total { get { return this._Total; } set { this._Total = value; } } + + private System.Decimal? _TotalDiscount; + /// + /// 折扣总计 + /// + [SugarColumn(ColumnName = "total_discount")] + public System.Decimal? TotalDiscount { get { return this._TotalDiscount; } set { this._TotalDiscount = value; } } + + private System.Decimal? _TotalVale; + /// + /// vale代金券总计 + /// + [SugarColumn(ColumnName = "total_vale")] + public System.Decimal? TotalVale { get { return this._TotalVale; } set { this._TotalVale = value; } } + + private System.Decimal? _Profit; + /// + /// 利润 + /// + [SugarColumn(ColumnName = "profit")] + public System.Decimal? Profit { get { return this._Profit; } set { this._Profit = value; } } + + private System.Decimal? _TotalPayment; + /// + /// 付款总计 + /// + [SugarColumn(ColumnName = "total_payment")] + public System.Decimal? TotalPayment { get { return this._TotalPayment; } set { this._TotalPayment = value; } } + + private System.Decimal? _TotalNumber; + /// + /// 总数量 + /// + [SugarColumn(ColumnName = "total_number")] + public System.Decimal? TotalNumber { get { return this._TotalNumber; } set { this._TotalNumber = value; } } + + private System.Decimal? _TotalCash; + /// + /// 总现金 + /// + [SugarColumn(ColumnName = "total_cash")] + public System.Decimal? TotalCash { get { return this._TotalCash; } set { this._TotalCash = value; } } + + private System.Int16? _IvaRule; + /// + /// iva规则(id) + /// + [SugarColumn(ColumnName = "iva_rule")] + public System.Int16? IvaRule { get { return this._IvaRule; } set { this._IvaRule = value; } } + + private System.Int32? _IvaId; + /// + /// iva_id + /// + [SugarColumn(ColumnName = "iva_id")] + public System.Int32? IvaId { get { return this._IvaId; } set { this._IvaId = value; } } + + private System.Int16? _UsePrice; + /// + /// 使用价格:1 零售价 2 会员价 3 进货价 + /// + [SugarColumn(ColumnName = "use_price")] + public System.Int16? UsePrice { get { return this._UsePrice; } set { this._UsePrice = value; } } + + private System.Int16? _CashdrawerId; + /// + /// 收银箱编号 + /// + [SugarColumn(ColumnName = "cashdrawer_id")] + public System.Int16? CashdrawerId { get { return this._CashdrawerId; } set { this._CashdrawerId = value; } } + + private System.String _ClientNo; + /// + /// 会员/供应商编号 + /// + [SugarColumn(ColumnName = "client_no")] + public System.String ClientNo { get { return this._ClientNo; } set { this._ClientNo = value; } } + + private System.Int32? _AgentId; + /// + /// 代理商id + /// + [SugarColumn(ColumnName = "agent_id")] + public System.Int32? AgentId { get { return this._AgentId; } set { this._AgentId = value; } } + + private System.Int32? _TransporterId; + /// + /// 运输商ID + /// + [SugarColumn(ColumnName = "transporter_id")] + public System.Int32? TransporterId { get { return this._TransporterId; } set { this._TransporterId = value; } } + + private System.String _CarNo; + /// + /// 车辆编号 + /// + [SugarColumn(ColumnName = "car_no")] + public System.String CarNo { get { return this._CarNo; } set { this._CarNo = value; } } + + private System.Int32? _OperatorId; + /// + /// 操作员编号 + /// + [SugarColumn(ColumnName = "operator_id")] + public System.Int32? OperatorId { get { return this._OperatorId; } set { this._OperatorId = value; } } + + private System.Int32? _VerifierId; + /// + /// 审核员编号 + /// + [SugarColumn(ColumnName = "verifier_id")] + public System.Int32? VerifierId { get { return this._VerifierId; } set { this._VerifierId = value; } } + + private System.Int32? _StorehouseId; + /// + /// 仓库id + /// + [SugarColumn(ColumnName = "storehouse_id")] + public System.Int32? StorehouseId { get { return this._StorehouseId; } set { this._StorehouseId = value; } } + + private System.String _AttachedDocSymbol; + /// + /// 附加文件符号 + /// + [SugarColumn(ColumnName = "attached_doc_symbol")] + public System.String AttachedDocSymbol { get { return this._AttachedDocSymbol; } set { this._AttachedDocSymbol = value; } } + + private System.Int32? _PrePaymentMethod; + /// + /// 预付款方式 + /// + [SugarColumn(ColumnName = "pre_payment_method")] + public System.Int32? PrePaymentMethod { get { return this._PrePaymentMethod; } set { this._PrePaymentMethod = value; } } + + private System.String _ReturnComputerName; + /// + /// 退款计算机名称 + /// + [SugarColumn(ColumnName = "return_computer_name")] + public System.String ReturnComputerName { get { return this._ReturnComputerName; } set { this._ReturnComputerName = value; } } + + private System.String _ComputerName; + /// + /// 计算机名称 + /// + [SugarColumn(ColumnName = "computer_name")] + public System.String ComputerName { get { return this._ComputerName; } set { this._ComputerName = value; } } + + private System.String _Hash; + /// + /// 哈希 + /// + [SugarColumn(ColumnName = "hash")] + public System.String Hash { get { return this._Hash; } set { this._Hash = value; } } + + private System.Int32? _CifId; + /// + /// cif_id(到岸编号) + /// + [SugarColumn(ColumnName = "cif_id")] + public System.Int32? CifId { get { return this._CifId; } set { this._CifId = value; } } + + private System.String _SubStoreId; + /// + /// 子商店编号 + /// + [SugarColumn(ColumnName = "sub_store_id")] + public System.String SubStoreId { get { return this._SubStoreId; } set { this._SubStoreId = value; } } + + private System.Decimal? _AbonoTotal; + /// + /// abono总计 + /// + [SugarColumn(ColumnName = "abono_total")] + public System.Decimal? AbonoTotal { get { return this._AbonoTotal; } set { this._AbonoTotal = value; } } + + private System.Boolean? _IsCharged; + /// + /// 是否已收款:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_charged")] + public System.Boolean? IsCharged { get { return this._IsCharged; } set { this._IsCharged = value; } } + + private System.Boolean? _IsLock; + /// + /// 是否锁定:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_lock")] + public System.Boolean? IsLock { get { return this._IsLock; } set { this._IsLock = value; } } + + private System.Boolean? _IsCanceled; + /// + /// 是否取消:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_canceled")] + public System.Boolean? IsCanceled { get { return this._IsCanceled; } set { this._IsCanceled = value; } } + + private System.String _IsModify; + /// + /// 是否修改:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_modify")] + public System.String IsModify { get { return this._IsModify; } set { this._IsModify = value; } } + + private System.Boolean? _IsSendEmail; + /// + /// 是否发送电子邮件:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_send_email")] + public System.Boolean? IsSendEmail { get { return this._IsSendEmail; } set { this._IsSendEmail = value; } } + + private System.String _Remark; + /// + /// 备注 + /// + [SugarColumn(ColumnName = "remark")] + public System.String Remark { get { return this._Remark; } set { this._Remark = value; } } + + private System.String _OrderReturnNo; + /// + /// 订单编号 + /// + [SugarColumn(ColumnName = "order_return_no")] + public System.String OrderReturnNo { get { return this._OrderReturnNo; } set { this._OrderReturnNo = value; } } + + private System.Int16? _OrderReturnType; + /// + /// 订单类型:1 采购 2 销售 + /// + [SugarColumn(ColumnName = "order_return_type")] + public System.Int16? OrderReturnType { get { return this._OrderReturnType; } set { this._OrderReturnType = value; } } + + private System.Int32? _CreateTime; + /// + /// 创建时间 + /// + [SugarColumn(ColumnName = "create_time")] + public System.Int32? CreateTime { get { return this._CreateTime; } set { this._CreateTime = value; } } + + private System.Int32? _UpdateTime; + /// + /// 修改时间 + /// + [SugarColumn(ColumnName = "update_time")] + public System.Int32? UpdateTime { get { return this._UpdateTime; } set { this._UpdateTime = value; } } + + private System.String _DelFlag; + /// + /// 删除标记:1 删除 0 未删除 + /// + [SugarColumn(ColumnName = "del_flag")] + public System.String DelFlag { get { return this._DelFlag; } set { this._DelFlag = value; } } + + private System.String _VerifyStatus; + /// + /// 审核状态:1 已审核 0 未审核 + /// + [SugarColumn(ColumnName = "verify_status")] + public System.String VerifyStatus { get { return this._VerifyStatus; } set { this._VerifyStatus = value?.Trim(); } } + + private System.Int32 _TenantId; + /// + /// 所属租户 + /// + [SugarColumn(ColumnName = "tenant_id")] + public System.Int32 TenantId { get { return this._TenantId; } set { this._TenantId = value; } } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturnDetail.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturnDetail.cs new file mode 100644 index 000000000..a5fe1cd6b --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/EOrderReturnDetail.cs @@ -0,0 +1,202 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace HONORCSData.Order +{ + /// + /// 退货详情 + /// + [SugarTable("order_return_detail")] + public class EOrderReturnDetail + { + /// + /// 退货详情 + /// + public EOrderReturnDetail() + { + } + + private System.Int32 _OrderReturnId; + /// + /// 退货单编号 + /// + [SugarColumn(ColumnName = "order_return_id")] + public System.Int32 OrderReturnId { get { return this._OrderReturnId; } set { this._OrderReturnId = value; } } + + private System.String _GoodsNo; + /// + /// 商品编号 + /// + [SugarColumn(ColumnName = "goods_no")] + public System.String GoodsNo { get { return this._GoodsNo; } set { this._GoodsNo = value; } } + + private System.String _BarCode; + /// + /// 条码 + /// + [SugarColumn(ColumnName = "bar_code")] + public System.String BarCode { get { return this._BarCode; } set { this._BarCode = value; } } + + private System.Boolean _IsBlanceBarCode; + /// + /// 是否对称条码:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_blance_bar_code")] + public System.Boolean IsBlanceBarCode { get { return this._IsBlanceBarCode; } set { this._IsBlanceBarCode = value; } } + + private System.String _SpanishName; + /// + /// 西文名称 + /// + [SugarColumn(ColumnName = "spanish_name")] + public System.String SpanishName { get { return this._SpanishName; } set { this._SpanishName = value; } } + + private System.String _ChineseName; + /// + /// 中文名称 + /// + [SugarColumn(ColumnName = "chinese_name")] + public System.String ChineseName { get { return this._ChineseName; } set { this._ChineseName = value; } } + + private System.Decimal? _Price; + /// + /// 价格 + /// + [SugarColumn(ColumnName = "price")] + public System.Decimal? Price { get { return this._Price; } set { this._Price = value; } } + + private System.Decimal? _Number; + /// + /// 数量 + /// + [SugarColumn(ColumnName = "number")] + public System.Decimal? Number { get { return this._Number; } set { this._Number = value; } } + + private System.Decimal? _Iva; + /// + /// iva + /// + [SugarColumn(ColumnName = "iva")] + public System.Decimal? Iva { get { return this._Iva; } set { this._Iva = value; } } + + private System.Decimal? _Req; + /// + /// req + /// + [SugarColumn(ColumnName = "req")] + public System.Decimal? Req { get { return this._Req; } set { this._Req = value; } } + + private System.Int32? _IvaId; + /// + /// iva_id + /// + [SugarColumn(ColumnName = "iva_id")] + public System.Int32? IvaId { get { return this._IvaId; } set { this._IvaId = value; } } + + private System.Decimal? _Discount; + /// + /// 折扣 + /// + [SugarColumn(ColumnName = "discount")] + public System.Decimal? Discount { get { return this._Discount; } set { this._Discount = value; } } + + private System.Boolean? _IsProhibitedChangeDiscount; + /// + /// 是否禁止更改折扣:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_prohibited_change_discount")] + public System.Boolean? IsProhibitedChangeDiscount { get { return this._IsProhibitedChangeDiscount; } set { this._IsProhibitedChangeDiscount = value; } } + + private System.Decimal? _CostPrice; + /// + /// 成本价 + /// + [SugarColumn(ColumnName = "cost_price")] + public System.Decimal? CostPrice { get { return this._CostPrice; } set { this._CostPrice = value; } } + + private System.String _Commentary; + /// + /// 批注 + /// + [SugarColumn(ColumnName = "commentary")] + public System.String Commentary { get { return this._Commentary; } set { this._Commentary = value; } } + + private System.Boolean? _IsTemporary; + /// + /// 是否是临时的:1 是 0 否 + /// + [SugarColumn(ColumnName = "is_temporary")] + public System.Boolean? IsTemporary { get { return this._IsTemporary; } set { this._IsTemporary = value; } } + + private System.Int32? _OrderId; + /// + /// 订单id + /// + [SugarColumn(ColumnName = "order_id")] + public System.Int32? OrderId { get { return this._OrderId; } set { this._OrderId = value; } } + + private System.Decimal? _PackageAmount; + /// + /// 包装数量(包数) + /// + [SugarColumn(ColumnName = "package_amount")] + public System.Decimal? PackageAmount { get { return this._PackageAmount; } set { this._PackageAmount = value; } } + + private System.Decimal? _Total; + /// + /// 合计 + /// + [SugarColumn(ColumnName = "total")] + public System.Decimal? Total { get { return this._Total; } set { this._Total = value; } } + + private System.String _Remark; + /// + /// 备注 + /// + [SugarColumn(ColumnName = "remark")] + public System.String Remark { get { return this._Remark; } set { this._Remark = value; } } + + private System.String _DelFlag; + /// + /// 删除标记:1 删除 0 未删除 + /// + [SugarColumn(ColumnName = "del_flag")] + public System.String DelFlag { get { return this._DelFlag; } set { this._DelFlag = value; } } + + private System.String _UnitName; + /// + /// 单位名称 + /// + [SugarColumn(ColumnName = "unit_name")] + public System.String UnitName { get { return this._UnitName; } set { this._UnitName = value; } } + + private System.String _PurchaseSpec; + /// + /// 进货规格 + /// + [SugarColumn(ColumnName = "purchase_spec")] + public System.String PurchaseSpec { get { return this._PurchaseSpec; } set { this._PurchaseSpec = value; } } + + private System.Int32 _Id; + /// + /// 主键 + /// + [SugarColumn(IsPrimaryKey = true, ColumnName = "id")] + public System.Int32 Id { get { return this._Id; } set { this._Id = value; } } + + private System.Int32 _TenantId; + /// + /// 所属租户id + /// + [SugarColumn(ColumnName = "tenant_id")] + public System.Int32 TenantId { get { return this._TenantId; } set { this._TenantId = value; } } + + + [SugarColumn(IsIgnore = true)] + public int Index { get; set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/PurchaseDetailModel.cs b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/PurchaseDetailModel.cs new file mode 100644 index 000000000..e714cfd4d --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Models/Unit/Custom1/PurchaseDetailModel.cs @@ -0,0 +1,162 @@ +using HONORCSData; +using HONORCSData.Goods; +using HONORCSData.Order; +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Linq.Expressions; +using System.Text; +using System.Threading.Tasks; +using HONORCSData.Order; +namespace OrmTest +{ + /// + /// 采购明细 + /// + public class PurchaseDetailModel + { + public int Index { get; set; } + + /// + /// 录入日期 + /// + public DateTime? EntryTime { get; set; } + + /// + /// 编号 + /// + public string No { get; set; } + + /// + /// 类型 + /// + public int Type { get; set; } + + public string GoodsNo { get; set; } + + public string GoodsName { get; set; } + + + public string GoodsCategory { get; set; } + + + public string BrandName { get; set; } + + + public decimal? Number { get; set; } + + + public decimal? Price { get; set; } + + public decimal TotalPrice + { + get + { + if (Number == null || Price == null) return 0; + return Number.Value * Price.Value; + } + } + + + } + public class CustomTest1 + { + /// + /// 采购明细汇总 + /// + /// + /// + /// + public static async Task GetPurchaseDetailPageAsync(SqlSugarClient Db) + { + Db.CodeFirst.InitTables(); + Db.CodeFirst.InitTables(); + //入库单 + Db.Insertable(new EOrderAlbaranDetail() + { + AlbaranId = 1, + BarCode = "a", + ChineseName = "a", + Commentary = "a", + CostPrice = 1, + DelFlag = "a", + Discount = 1, + GoodsBrandId = 1, + GoodsBrandName = "a", + GoodsClassId = 1, + GoodsClassName = "a", + GoodsNo = "a", + Id = new Random().Next(0, 99999999), + Index = 1, + IsBlanceBarCode = true, + IsProhibitedChangeDiscount = true, + IsTemporary = true, + Iva = 1, + IvaId = 1, + Number = 1, + OrderId = 1, + PackageAmount = 1, + Price = 1, + PurchaseSpec = "", + Remark = "a", + Req = 1, + SpanishName = "a", + TenantId = 1, + Total = 1, + UnitName = "a" + }).ExecuteCommand(); + var query1 = Db.Queryable((d, h, g, c, b) => new JoinQueryInfos( + JoinType.Left, h.AlbaranId == d.AlbaranId, + JoinType.Left, d.GoodsNo == g.GoodsNo, + JoinType.Left, g.GoodsClassId == c.GoodsClassId, + JoinType.Left, g.BrandId == b.BrandId + )) + .Where((d, h, g, c, b) => h.AlbaranType == null) //固定入库单 + .Select((d, h, g, c, b) => new PurchaseDetailModel + { + EntryTime = h.EntryTime, + No = h.AlbaranNo, + Type = 1, + GoodsNo = d.GoodsNo, + GoodsName = g.SpanishName, + GoodsCategory = c.SpanishName, + BrandName = b.BranchSpanishName, + Number = d.Number, + Price = d.Price + }); + + //退货单 + var query2 = Db.Queryable((d, h, g, c, b) => new JoinQueryInfos( + JoinType.Left, h.OrderReturnId == d.OrderReturnId, + JoinType.Left, d.GoodsNo == g.GoodsNo, + JoinType.Left, g.GoodsClassId == c.GoodsClassId, + JoinType.Left, g.BrandId == b.BrandId + )).Where((d, h, g, c, b) => h.OrderReturnType == 1) //固定入库单 + .Select((d, h, g, c, b) => new PurchaseDetailModel + { + EntryTime = h.EntryTime, + No = h.OrderReturnNo, + Type = 2, + GoodsNo = d.GoodsNo, + GoodsName = g.SpanishName, + GoodsCategory = c.SpanishName, + BrandName = b.BranchSpanishName, + Number = d.Number, + Price = d.Price + }); + SqlSugar.RefAsync totalNum = 0; + + var res2 = await query2.Clone().ToPageListAsync(1, 2, totalNum); + var res = await Db.UnionAll(query1, query2).ToPageListAsync(1, 2, totalNum); + + var q = Db.Queryable().Where(it => it.Id == 1).Select(it => new { id=1}); + var q2 = q.Clone(); + var x = q.ToList(); + var y = q2.ToList(); + //var res = await Db.UnionAll(query1.Clone(), query2.Clone()).ToPageListAsync(1, 10, totalNum); + + } + + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Models/ViewOrder.cs b/Src/Asp.Net/MySqlConnectorTest/Models/ViewOrder.cs new file mode 100644 index 000000000..fcd465747 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/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.Net/MySqlConnectorTest/MySqlConnectorTest.csproj b/Src/Asp.Net/MySqlConnectorTest/MySqlConnectorTest.csproj new file mode 100644 index 000000000..4b705ff09 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/MySqlConnectorTest.csproj @@ -0,0 +1,138 @@ + + + + + Debug + AnyCPU + {7F705C44-F878-4706-AB9B-8D35030A8222} + Exe + MySqlConnectorTest + MySqlConnectorTest + v4.6 + 512 + true + true + + + AnyCPU + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + AnyCPU + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + ..\packages\MySqlConnector.1.2.1\lib\net45\MySqlConnector.dll + + + + ..\packages\System.Buffers.4.4.0\lib\netstandard1.1\System.Buffers.dll + + + + + ..\packages\System.Memory.4.5.0\lib\netstandard1.1\System.Memory.dll + + + ..\packages\System.Runtime.CompilerServices.Unsafe.4.5.0\lib\netstandard1.0\System.Runtime.CompilerServices.Unsafe.dll + + + ..\packages\System.Threading.Tasks.Extensions.4.3.0\lib\portable-net45+win8+wp8+wpa81\System.Threading.Tasks.Extensions.dll + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + {d131ee06-bad4-4b80-b7de-d6f539087644} + SqlSugar.MySqlConnector + + + {489bb790-226c-4fad-8d1e-51d72a7ff8e5} + SqlSugar + + + + \ No newline at end of file diff --git a/Src/Asp.Net/MySqlConnectorTest/Program.cs b/Src/Asp.Net/MySqlConnectorTest/Program.cs new file mode 100644 index 000000000..9481f1940 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Program.cs @@ -0,0 +1,41 @@ +using System; + +namespace OrmTest +{ + class Program + { + static void Main(string[] args) + { + //Demo + Demo0_SqlSugarClient.Init(); + Demo1_Queryable.Init(); + Demo2_Updateable.Init(); + Demo3_Insertable.Init(); + DemoN_SplitTable.Init(); + Demo4_Deleteable.Init(); + Demo5_SqlQueryable.Init(); + Demo6_Queue.Init(); + Demo7_Ado.Init(); + Demo8_Saveable.Init(); + Demo9_EntityMain.Init(); + DemoA_DbMain.Init(); + DemoB_Aop.Init(); + DemoC_GobalFilter.Init(); + DemoD_DbFirst.Init(); ; + DemoE_CodeFirst.Init(); + DemoF_Utilities.Init(); + DemoG_SimpleClient.Init(); + DemoJ_Report.Init(); + //Unit test + //NewUnitTest.Init(); + + //Rest Data + NewUnitTest.RestData(); + + Console.WriteLine("all successfully."); + Console.ReadKey(); + } + + + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/Properties/AssemblyInfo.cs b/Src/Asp.Net/MySqlConnectorTest/Properties/AssemblyInfo.cs new file mode 100644 index 000000000..4ae25b1cb --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// 有关程序集的一般信息由以下 +// 控制。更改这些特性值可修改 +// 与程序集关联的信息。 +[assembly: AssemblyTitle("MySqlConnectorTest")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("MySqlConnectorTest")] +[assembly: AssemblyCopyright("Copyright © 2022")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// 将 ComVisible 设置为 false 会使此程序集中的类型 +//对 COM 组件不可见。如果需要从 COM 访问此程序集中的类型 +//请将此类型的 ComVisible 特性设置为 true。 +[assembly: ComVisible(false)] + +// 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID +[assembly: Guid("7f705c44-f878-4706-ab9b-8d35030a8222")] + +// 程序集的版本信息由下列四个值组成: +// +// 主版本 +// 次版本 +// 生成号 +// 修订号 +// +//可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值 +//通过使用 "*",如下所示: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/Main.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/Main.cs new file mode 100644 index 000000000..93119fffd --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/Main.cs @@ -0,0 +1,50 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + public partial class NewUnitTest + { + public static SqlSugarClient Db=> new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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))); + } + } + }); + + public static void RestData() + { + Db.DbMaintenance.TruncateTable(); + Db.DbMaintenance.TruncateTable(); + } + public static void Init() + { + UnitCustom01.Init(); + UCustom06.Init(); + Bulk(); + Insert(); + Queue(); + CodeFirst(); + Updateable(); + Json(); + Ado(); + Queryable(); + QueryableAsync(); + //Thread(); + //Thread2(); + //Thread3(); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UAdo.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UAdo.cs new file mode 100644 index 000000000..f2578cf29 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UAdo.cs @@ -0,0 +1,57 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + public static void Ado() + { + + var task1 = Db.Ado.GetScalarAsync("select 1"); + task1.Wait(); + UValidate.Check(1, task1.Result, "ado"); + + var task2 = Db.Ado.GetIntAsync("select 2"); + task2.Wait(); + UValidate.Check(2, task2.Result, "ado"); + + + var task3 = Db.Ado.GetLongAsync("select 3"); + task3.Wait(); + UValidate.Check(3, task3.Result, "ado"); + + + var task4 = Db.Ado.GetDataTableAsync("select 4 as id"); + task4.Wait(); + UValidate.Check(4, task4.Result.Rows[0]["id"], "ado"); + + + var task5 = Db.Ado.GetInt("select @id as id",new { id=5}); + UValidate.Check(5, task5, "ado"); + + + + var task6 = Db.Ado.SqlQuery("select @id as id", new { id = 5 }); + UValidate.Check(5, task6[0].id, "ado"); + + + var task7 = Db.Ado.SqlQueryAsync("select @id as id", new { id = 7 }); + task7.Wait(); + UValidate.Check(7, task7.Result[0].id, "ado"); + + + var task8 = Db.Ado.SqlQueryAsync("select 8 as id"); + task8.Wait(); + UValidate.Check(8, task8.Result[0].id, "ado"); + + var task9=Db.Ado.SqlQuery("select * from `order`;select * from OrderDetail"); + + var task10 = Db.Ado.SqlQueryAsync("select * from `order`;select * from OrderDetail"); + task10.Wait(); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UBulkCopy.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UBulkCopy.cs new file mode 100644 index 000000000..9ef952c56 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UBulkCopy.cs @@ -0,0 +1,212 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + public partial class NewUnitTest + { + public static string bulkData1 = @"{""data"":[{""id"":0,""robot_wx_id"":""wxid_0p3bww1ouyvi12"",""robot_serial_no"":""3927EE296470127DD1F1DF6274467A7A"",""device_user_serial_no"":""F27C2578D8004E9F8644EBC023C0A582"",""wx_account"":""lvqiujingliu1986"",""wx_password"":""8836MjQ2MWFhYWEyMzQ5"",""wx_alias"":""lvqiujingliu1986"",""nick_name"":""闾丘睛六"",""base64_nick_name"":""6Ze+5LiY552b5YWt"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/VlhejJkdGe5YhcXdIVHYibxKbntVE85ZiayxtN2NnSibSViapXLEPY2mt1kHrZbqXnfgenBnNrp8Cx95YN1Uxic2E7Gzdfk2DSnYeUuR2QVpQJ28/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""1541723256"",""update_time"":""2022-01-12T09:57:13.377"",""create_time"":""2021-12-24T16:08:20.84"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_ln20qwymng8422"",""robot_serial_no"":""39289F28EAD96B4474A608919011FDEB"",""device_user_serial_no"":""20200917101004889010110000391"",""wx_account"":""ik50u73"",""wx_password"":""3uvhM3V2aDN1dmg2Z3Fl"",""wx_alias"":""ik50u73"",""nick_name"":""缪茹茹"",""base64_nick_name"":""57yq6Iy56Iy5"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/Q7gjPhRR5ahEIP3DWyzIVvj1dPkGRTXia4hBTEY4VBCjq45jBkXc2A4ZwjWGhgKZ8AWDWt6LZpL3qic5dN2t5H5Nz1BI3iaqWlqBpZYticftusE/132"",""email"":"""",""sex"":2,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""2342964524"",""update_time"":""2022-01-11T19:26:38.86"",""create_time"":""2020-07-08T14:26:57.907"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_0prnyg6n7aat22"",""robot_serial_no"":""39281E97D2F28A1BA848EED509D1D914"",""device_user_serial_no"":""20220105175222407210210002286"",""wx_account"":"""",""wx_password"":"""",""wx_alias"":"""",""nick_name"":""烈文"",""base64_nick_name"":""54OI5paH"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/3S5EfQYud7JQ9bibib2sUHSE18HskHNF4yE6DrgvjRbBWawfreZlR6KR0ZhE5MrFWWv6b4JLHQdUUlWicqnWWvhgtdLpAlicURuHeD0k6qvX7dE/132"",""email"":"""",""sex"":2,""enabled"":true,""type"":30,""status"":10,""seal_status"":10,""protocol_type"":1,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""2483638563"",""update_time"":""2022-01-11T17:55:05.147"",""create_time"":""2021-10-15T13:30:50.637"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_rbhtxkd819ug21"",""robot_serial_no"":""3928E3EF41E241987190AAD5CD3896FA"",""device_user_serial_no"":""20211129100847022010210001354"",""wx_account"":"""",""wx_password"":"""",""wx_alias"":""jammy__C"",""nick_name"":""婕"",""base64_nick_name"":""5amV"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/CB1XmYSqgFJ9no4HR6icKgnf8uJKGX8BQUqhsR9CoyFpqh3QxJCWMmGkslicXyVjiaCZyBjC9DL7eXBicOKnbe9kun5yW8cBlqSDhR0vIjGaOuQ/132"",""email"":"""",""sex"":2,""enabled"":true,""type"":30,""status"":10,""seal_status"":10,""protocol_type"":1,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""1083130244"",""update_time"":""2022-01-10T13:06:27.823"",""create_time"":""2021-09-27T11:33:16.327"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_opxbbhmzlakx12"",""robot_serial_no"":""392734726B89AFD98BD54F87A6F7A323"",""device_user_serial_no"":""C64EA13FFEDE4AC587E3E189CC32ED2B"",""wx_account"":""lugao1106"",""wx_password"":""9591Y2UxYnd3d3cxNTQ5"",""wx_alias"":""lugao1106"",""nick_name"":""逯缟"",""base64_nick_name"":""6YCv57yf"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/6O6v8T7HbFiag6MJTQErfNdoNhG08wQx4rXApdQfjdcnxEZFcjlOmB1mFJ4OfBYhkvhibUzdCegsY0YiaYtwpEtpg/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""202535294"",""update_time"":""2022-01-11T11:18:08.897"",""create_time"":""2021-11-19T16:29:19.907"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_fvmabxeptk9n12"",""robot_serial_no"":""392857A86E6E48690FC4648588F22E24"",""device_user_serial_no"":""20220108112325107110110008239"",""wx_account"":"""",""wx_password"":"""",""wx_alias"":""jiangwi0603"",""nick_name"":""jason"",""base64_nick_name"":""amFzb24="",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/MEbn4icxcP6IDTiblzFfhfqwp0LaBAetP4Nobvk5xSTcd0jJtYljIN6BYh5nXEsCJyCGa0jSZrTczYcD0w1SaPb2eyYoKM0tLicx95Nz1q4XBQ/132"",""email"":""jiangwi0603@126.com"",""sex"":1,""enabled"":true,""type"":30,""status"":10,""seal_status"":10,""protocol_type"":1,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""3063392316"",""update_time"":""2022-01-11T11:17:28.987"",""create_time"":""2022-01-11T11:16:49.84"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_00bzjyic7zdu22"",""robot_serial_no"":""39294970652FF9BD5E3412FC24F49368"",""device_user_serial_no"":""20200825110115450710110000807"",""wx_account"":""e45r41wi"",""wx_password"":""oc77b2M3N29jNzc3bzZ1ZXg0bHo="",""wx_alias"":""e45r41wi"",""nick_name"":"" 小川小"",""base64_nick_name"":""IOWwj+W3neWwjw=="",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/FQCiayUo0amVG3s9nulZph8Jeicd1oxklDpL67Zj4dE3ntmSuiaOA54v1D0sxGXnhfeicwDHIAA9ZrbkWoYaGeWoco1rRPxyIU0Dn0cxfyY21T4/132"",""email"":"""",""sex"":1,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""1811494957"",""update_time"":""2022-01-12T01:24:19.26"",""create_time"":""2020-04-03T00:18:51.277"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_11aabdewsz3421"",""robot_serial_no"":""39277ABBFE59C0C318D9271AE004BC8D"",""device_user_serial_no"":""20211217203325799310210000217"",""wx_account"":"""",""wx_password"":"""",""wx_alias"":"""",""nick_name"":""\""碎花洋裙__"",""base64_nick_name"":""IueijuiKsea0i+ijmV9f"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/Cz96bFGqPJOeHuQLzM7M05QdN0IE6sichTg5SFCXVIqZCOXaLg1GNvkIWYVpwnfRJcTXcwia7eDkShRuPogulqXOVicgZ8pQWmAFjGxefqIYdE/132"",""email"":"""",""sex"":1,""enabled"":true,""type"":30,""status"":10,""seal_status"":10,""protocol_type"":1,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""1947658881"",""update_time"":""2022-01-11T02:25:21.407"",""create_time"":""2021-10-22T15:18:50.34"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_c6iha3x4cxp622"",""robot_serial_no"":""39288C70A34DFF820A150FF29C5E99EE"",""device_user_serial_no"":""A02A33A4DDB54CD1834A21BB55F886FC"",""wx_account"":""15525425235"",""wx_password"":""9FD7OWIyOHh4eHg1MjM1"",""wx_alias"":""a15525425235"",""nick_name"":""华秀莲"",""base64_nick_name"":""5Y2O56eA6I6y"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/zupZQgKfg5Y6IyZfrYkzNjeIGYEJmQKjOTOXD78UnvibUqunpl04aldGqSYibj44opN53QMZDxa9T3cNib4hM4vqA/0"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":4,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""925715359"",""update_time"":""2022-01-12T10:17:48.453"",""create_time"":""2021-11-23T23:14:18.97"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_4l1ivs17ftb222"",""robot_serial_no"":""39269C2B524054811AFCAED61A7C9157"",""device_user_serial_no"":""20210520150600703910110004389"",""wx_account"":""stluohuiofgin"",""wx_password"":""627qNjI3cTYyN3F0d3dnMQ=="",""wx_alias"":""stluohuiofgin"",""nick_name"":""卜爽荷"",""base64_nick_name"":""5Y2c54i96I23"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/jUwh2gwmQMpBshR4gSkRlIDKdU76eRHKsibebr0abKl8AnevI0T8GaYeHicicEiaia12efM4pBaPKxD5FLaRSZDdZRveYMZibyKQlewxck9wSia2ho/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""2973613556"",""update_time"":""2022-01-11T05:36:24.143"",""create_time"":""2021-05-20T15:05:46.317"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_hdjl4c1rvhzm22"",""robot_serial_no"":""39283929293888060537D621C0C07670"",""device_user_serial_no"":""20211211080701699410210000733"",""wx_account"":"""",""wx_password"":"""",""wx_alias"":"""",""nick_name"":""开心果2"",""base64_nick_name"":""5byA5b+D5p6cMg=="",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/CdiatnVopdM5oI6oQYoVaB7XObU6afg81hwVfJm1LvmP2dkjqT9stOJB4QGC6RSjdskuXjshDjLlt9nZCyMOiaLOOyCBmuIOV9RjEic3iaYyibDU/132"",""email"":"""",""sex"":2,""enabled"":true,""type"":30,""status"":10,""seal_status"":10,""protocol_type"":1,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""2709509370"",""update_time"":""2022-01-11T02:24:59.55"",""create_time"":""2021-09-11T06:29:24.603"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_ii0eb7q59cea22"",""robot_serial_no"":""392929B4976E9C3877F875BCDB68D7DF"",""device_user_serial_no"":""20210328130254263510110001471"",""wx_account"":""yyvliansuobh"",""wx_password"":""kd81a2Q4MWtkODFydXlwZzB0eQ=="",""wx_alias"":""yyvliansuobh"",""nick_name"":""赵苑"",""base64_nick_name"":""6LW16IuR"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/aqvibe2kL44hQrUZBd0SzpvVkwm5ORCUcSdmF2TeS29zu6ZXR5ECJt4WS3FHathburCYQGWYFaS9OfNOcjYddLTibbZM7J4zRlDFVxsqZWicMc/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""2463150744"",""update_time"":""2022-01-12T01:07:40.733"",""create_time"":""2021-03-28T13:02:39.89"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_4urf1eo9lh6922"",""robot_serial_no"":""392768D516AD31B5DD63FF7FE1F96234"",""device_user_serial_no"":""20200803170607244010110002026"",""wx_account"":""re41lii8zn"",""wx_password"":""o4d1bzRkMW80ZDF5ZDJrM3N4OTI="",""wx_alias"":""re41lii8zn"",""nick_name"":""小娥骄"",""base64_nick_name"":""5bCP5ail6aqE"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/wjAGzPlkibvAXIxFbHgobEbgqZNQOg0Ef8XEnvyX5ibciaPzdW8icS3ndjtIDicnnGZMg7IcplZGCeWdywqgkGichg6s7r1sJb3jLRcxkIQm3KA2Q/132"",""email"":"""",""sex"":2,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""2873679361"",""update_time"":""2022-01-11T21:12:34.92"",""create_time"":""2020-03-28T23:34:47.013"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_swjhsaa2gljn22"",""robot_serial_no"":""39285985503DA5A84FC9028D72D45FFA"",""device_user_serial_no"":""20211207033654739920310255216"",""wx_account"":"""",""wx_password"":"""",""wx_alias"":""LVOE1628"",""nick_name"":""静心"",""base64_nick_name"":""6Z2Z5b+D"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/hR5Gqfefr4pkPMv1E4DLyRBVryRXxe0ajpuR9JHMsiabBQXtdoic5rM9LIeEOABt6npy9eI88VJyfPjmYpuILAXA/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":30,""status"":10,""seal_status"":10,""protocol_type"":1,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""373620837"",""update_time"":""2022-01-11T04:07:13.367"",""create_time"":""2021-12-06T21:48:28.217"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_t5rkwg6psqta12"",""robot_serial_no"":""392955F2CE8D0D85AC40DB5636F5ADFC"",""device_user_serial_no"":""20210302105529014210110000115"",""wx_account"":""Rjisngzhu109588"",""wx_password"":""frapZnJhcGZyYXBwOHkxOWlp"",""wx_alias"":""Rjisngzhu109588"",""nick_name"":""陈小凤"",""base64_nick_name"":""6ZmI5bCP5Yek"",""headimg_url"":""http://wx.qlogo.cn/mmhead/ver_1/LDkfKDR0sO5SAWjHP8c93Vx3FRK4u49mZ6HRkmSt9cOZwNndopH6Gz5x4K8UFC8Iv0u2cYROuqqCvH8v3DQnLqJqanKiaM4eT05ZMbg9XUgA/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""3414889675"",""update_time"":""2022-01-11T04:25:09.963"",""create_time"":""2021-03-02T10:55:19.837"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_1du1f7hsnj8422"",""robot_serial_no"":""39280F6BA859EE89842FA77ABB0DC039"",""device_user_serial_no"":""D572F85AA4B641D49C21FE5B14508F29"",""wx_account"":""15534029941"",""wx_password"":""96FBMjViN3p6eno5OTQx"",""wx_alias"":""ydh15534029941"",""nick_name"":""祁云亭"",""base64_nick_name"":""56WB5LqR5Lqt"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/nDCibWBVKQI3aMNpuiblF6YFHvFiaDN99ZINVZAShsgyx5cGmxu2H1hw4cQtKBD1r3ESYHMUVQnIwPp6BecK3TlEFWRYYayYH8sr3ibUPKbUc9U/0"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":4,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""18446744072072878797"",""update_time"":""2022-01-11T06:28:40.86"",""create_time"":""2022-01-09T17:03:50.27"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_btoq5obkvia312"",""robot_serial_no"":""3928C99084242D85837E58D49DD12F42"",""device_user_serial_no"":""B59DD35FEB764162990BFA8559F7408F"",""wx_account"":""19103155341"",""wx_password"":""cal8Y2FsOGNhbDg3eG5jMXc="",""wx_alias"":""Ks15904265536"",""nick_name"":""司寇恋云"",""base64_nick_name"":""5Y+45a+H5oGL5LqR"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/YdJvibiaA1X7KxedvZQ0z7gibD35QYCrItx9AvgO3CnbCZNELLloFbic2xecGHZbEv6IegTUHCQzHpxDTXRwtSbqiaib603SPw2fwdyO1ux5E6oZ0/132"",""email"":"""",""sex"":2,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""1018112863"",""update_time"":""2022-01-12T04:56:09.393"",""create_time"":""2020-12-16T15:01:19.217"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_b7qz88olje4x21"",""robot_serial_no"":""39269A93540340FFB5BB6080E180FB48"",""device_user_serial_no"":""20211119182956000410210024676"",""wx_account"":"""",""wx_password"":"""",""wx_alias"":""guanmengsi_"",""nick_name"":""??梦·思小厨娘"",""base64_nick_name"":""8J+RhOaipsK35oCd5bCP5Y6o5aiY"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/OzeZ5ia3bn36BTjgLAZYAUmNNmSLgV5E1wcEcmDNNh5G4ZLjdLPw3GASUZ6iaMzDVtWCRMWibx9tIseedicicibAVVJKjT8BkaI6WrVjjNwuZUQQs/132"",""email"":"""",""sex"":2,""enabled"":true,""type"":30,""status"":10,""seal_status"":10,""protocol_type"":1,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""1753890521"",""update_time"":""2022-01-11T17:28:39.473"",""create_time"":""2021-10-12T16:41:17.513"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_pu59oaivtqs422"",""robot_serial_no"":""392838309D46DDE1A10788FD4A170D07"",""device_user_serial_no"":""20210705141209419610110001562"",""wx_account"":""dijiaohuan1958"",""wx_password"":""i2dyaTJkeWkyZHlhenVmeWx4Yg=="",""wx_alias"":""dijiaohuan1958"",""nick_name"":""经燕琴"",""base64_nick_name"":""57uP54eV55C0"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/IMGo9t3plEjOd4KA3iaaQk5NFfma3VrXkBCDia6q1R2lsxASZ3lsSahUYdvtBRyUPqteWd5tiaEmYdC6cGXeHue3IQ1f7OjYpvSSQwh7nZpbqI/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""38429044"",""update_time"":""2022-01-11T09:46:16.657"",""create_time"":""2021-07-05T14:11:39.643"",""remark"":""机器人信息·数据初始化""},{""id"":0,""robot_wx_id"":""wxid_0aax7lsdiql912"",""robot_serial_no"":""3928E79621B2BE780382762047ECE703"",""device_user_serial_no"":""986D325458CB4E69841A31720C2439C4"",""wx_account"":""18852589379"",""wx_password"":""pfolcGZvbHBmb2xhcHhuM2ZxNzE="",""wx_alias"":""XDMx3sngFNF"",""nick_name"":""柏白枫"",""base64_nick_name"":""5p+P55m95p6r"",""headimg_url"":""https://wx.qlogo.cn/mmhead/ver_1/FQ5pJrib0L2kluAGfbV5HZXH96v0rnGqwMsRNTVI8mwUwQuAYkAB3zHV3p5MGpQibCp6g9eVkCrsviaiaJ6aZzibGzibCRO9I98wWtaCu7revWkd8/132"",""email"":"""",""sex"":0,""enabled"":true,""type"":10,""status"":10,""seal_status"":10,""protocol_type"":2,""city_no"":"""",""province_no"":"""",""separation"":false,""parent_id"":0,""uin"":""160768034"",""update_time"":""2022-01-12T09:37:08.833"",""create_time"":""2020-12-04T16:30:41.407"",""remark"":""机器人信息·数据初始化""}]}"; + + public static void Bulk() + { + Db.CodeFirst.InitTables(); + Db.DbMaintenance.TruncateTable(); + var data = new UnitIdentity1() + { + Name = "jack" + }; + Db.Fastest().BulkCopy(new List() { + data + }); + var list = Db.Queryable().ToList(); + if (list.Count != 1 || data.Name != list.First().Name) + { + throw new Exception("unit Bulk"); + } + data.Name = "2"; + Db.Fastest().BulkCopy(new List() { + data, + data + }); + list = Db.Queryable().ToList(); + if (list.Count != 3 || !list.Any(it => it.Name == "2")) + { + throw new Exception("unit Bulk"); + } + Db.Fastest().BulkUpdate(new List() { + new UnitIdentity1(){ + Id=1, + Name="222" + }, + new UnitIdentity1(){ + Id=2, + Name="111" + } + }); + list = Db.Queryable().ToList(); + if (list.First(it => it.Id == 1).Name != "222") + { + throw new Exception("unit Bulk"); + } + if (list.First(it => it.Id == 2).Name != "111") + { + throw new Exception("unit Bulk"); + } + if (list.First(it => it.Id == 3).Name != "2") + { + throw new Exception("unit Bulk"); + } + Db.CodeFirst.InitTables(); + Db.DbMaintenance.TruncateTable(); + var count = Db.Fastest().AS("UnitIdentity111").BulkCopy(new List { + new UnitIdentity111111111(){ Id=1, Name="jack" } + }); + if (count == 0) + { + throw new Exception("unit Bulk"); + } + count = Db.Fastest().AS("UnitIdentity111").BulkUpdate(new List { + new UnitIdentity111111111(){ Id=1, Name="jack" } + }); + if (count == 0) + { + throw new Exception("unit Bulk"); + } + Db.CodeFirst.InitTables(); + Db.Fastest().BulkUpdate(new List { + new UnitTable001(){ Id=1, table="a" } + }); + + Db.CodeFirst.InitTables(); + Db.DbMaintenance.TruncateTable(); + Db.Fastest().BulkCopy(new List { + new UnitBulk23131() + { + Id = 1, + table = false + } + }); + var list1 = Db.Queryable().ToList(); + SqlSugar.Check.Exception(list1.First().table == true, "unit error"); + Db.Fastest().BulkUpdate(new List { + new UnitBulk23131() + { + Id = 1, + table = true + } + }); + var list2 = Db.Queryable().ToList(); + SqlSugar.Check.Exception(list2.First().table == false, "unit error"); + + Db.DbMaintenance.TruncateTable(); + Db.Fastest().BulkCopy(new List { + new UnitBulk23131() + { + Id = 1, + table = true + } + }); + var list3 = Db.Queryable().ToList(); + SqlSugar.Check.Exception(list3.First().table == false, "unit error"); + Db.Fastest().BulkUpdate(new List { + new UnitBulk23131() + { + Id = 1, + table = false + } + }); + list3 = Db.Queryable().ToList(); + SqlSugar.Check.Exception(list3.First().table == true, "unit error"); + + Db.DbMaintenance.TruncateTable(); + Db.Fastest().BulkCopy(new List { + new UnitBulk23131() + { + Id = 1, + table = null + } + }); + var list4 = Db.Queryable().ToList(); + SqlSugar.Check.Exception(list4.First().table == true, "unit error"); + + Db.CodeFirst.InitTables(); + Db.CodeFirst.InitTables(); + var rootData=Db.Utilities.DeserializeObject(bulkData1); + var inserData = rootData.data.ToList(); + var num= Db.Fastest().BulkCopy(inserData); + SqlSugar.Check.Exception(num != 20, "unit error"); + } + } + + public class Rootobject + { + public UnitDatum[] data { get; set; } + } + + public class UnitDatum + { + public int id { get; set; } + public string robot_wx_id { get; set; } + public string robot_serial_no { get; set; } + public string device_user_serial_no { get; set; } + public string wx_account { get; set; } + public string wx_password { get; set; } + public string wx_alias { get; set; } + public string nick_name { get; set; } + public string base64_nick_name { get; set; } + public string headimg_url { get; set; } + public string email { get; set; } + public int sex { get; set; } + public bool enabled { get; set; } + public int type { get; set; } + public int status { get; set; } + public int seal_status { get; set; } + public int protocol_type { get; set; } + public string city_no { get; set; } + public string province_no { get; set; } + public bool separation { get; set; } + public int parent_id { get; set; } + public string uin { get; set; } + public DateTime update_time { get; set; } + public DateTime create_time { get; set; } + public string remark { get; set; } + } + + public class UnitBulkCopy1231 + { + public string Id { get; set; } + } + public class UnitBulk23131 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public int Id { get; set; } + [SqlSugar.SugarColumn(ColumnDataType = "tinyint", Length = 1, IsNullable = true)] + public bool? table { get; set; } + } + public class UnitTable001 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public int Id { get; set; } + public string table { get; set; } + } + + public class UnitIdentity111 + { + public int Id { get; set; } + public string Name { get; set; } + } + public class UnitIdentity111111111 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public int Id { get; set; } + public string Name { get; set; } + } + public class UnitIdentity1 + { + [SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + public string Name { get; set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UCodeFirst.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UCodeFirst.cs new file mode 100644 index 000000000..1213f4394 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UCodeFirst.cs @@ -0,0 +1,92 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + public static void CodeFirst() + { + if (Db.DbMaintenance.IsAnyTable("UnitCodeTest1", false)) + Db.DbMaintenance.DropTable("UnitCodeTest1"); + Db.CodeFirst.InitTables(); + Db.CodeFirst.InitTables(); + Db.Insertable(new UnitCodeTest2222() + { + Id = 1, + Id2 = 2, + Id3 = 3, + Id4 = 4 + }).ExecuteCommand(); + var list = Db.Queryable().ToList(); + Db.CodeFirst.InitTables(); + Db.Insertable(new UnitCodeTest2a2c22() + { + a = 1, + b = new byte[] { 1, 2, 3 } + }) + .ExecuteCommand(); + var xx=Db.Queryable().Select(it => new + { + id=it.a, + b=it.b + }).ToList(); + Db.CodeFirst.InitTables(); + Db.CodeFirst.InitTables(); + Db.CodeFirst.InitTables(); + Db.CodeFirst.InitTables(); + Db.Insertable(new UnitDateOfTime2() { DateTimeOffset1 = DateTimeOffset.Now }).ExecuteCommand(); + Db.Insertable(new List { new UnitDateOfTime2() { DateTimeOffset1 = DateTimeOffset.Now }, new UnitDateOfTime2() { DateTimeOffset1 = DateTimeOffset.Now } }).ExecuteCommand(); + var list2 = Db.Queryable().ToList(); + Db.Insertable(new UnitDateOfTime222() { DateTimeOffset1 = null }).ExecuteCommand(); + + } + + public class UnitDateOfTime2 + { + [SqlSugar.SugarColumn(ColumnDataType ="datetime(3)")] + public DateTimeOffset DateTimeOffset1 { get; set; } + } + public class UnitDateOfTime222 + { + [SqlSugar.SugarColumn(ColumnDataType = "datetime(3)",IsNullable =true)] + public DateTimeOffset? DateTimeOffset1 { get; set; } + } + public class UnitTest3131 + { + public sbyte Id { get; set; } + } + public class UnitTest012213 + { + + [SugarColumn(ColumnDataType = "image,longblob")] + public byte[] x { get; set; } + } + public class UnitCodeTest1 + { + [SqlSugar.SugarColumn(IndexGroupNameList = new string[] { "group1" })] + public int Id { get; set; } + [SqlSugar.SugarColumn(DefaultValue="now()", IndexGroupNameList =new string[] {"group1" } )] + public DateTime? CreateDate { get; set; } + } + + public class UnitCodeTest2a2c22 + { + public int a { get; set; } + [SqlSugar.SugarColumn(ColumnDataType ="blob")] + public byte[] b { get; set; } + } + + public class UnitCodeTest2222 + { + public uint Id { get; set; } + public ulong Id2 { get; set; } + public ushort Id3 { get; set; } + public uint? Id4 { get; set; } + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UCustom06.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UCustom06.cs new file mode 100644 index 000000000..7b3ebf589 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UCustom06.cs @@ -0,0 +1,45 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class UCustom06 + { + public static void Init() + { + var db = NewUnitTest.Db; + + db.CodeFirst.InitTables(); + db.Insertable(new Unit06() { Company = "1", Name = "2", Work = "3" }).ExecuteCommand(); + var list = db.Queryable().Select(a => new UnitPeople + { + Name = a.Name, + Job = new UnitJobClass { Company = a.Company, Work = a.Work } + } + ).ToList(); + Check.Exception(list.First().Job.Company != "1", "unit error"); + + } + public class Unit06 + { + public string Name { get; set; } + public string Company { get; set; } + public string Work { get; set; } + } + public class UnitPeople + { + public string Name { get; set; } + public UnitJobClass Job { get; set; } + } + + public class UnitJobClass + { + public string Company { get; set; } + public string Work { get; set; } + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UInsert.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UInsert.cs new file mode 100644 index 000000000..c871531a4 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UInsert.cs @@ -0,0 +1,154 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + + +namespace OrmTest +{ + public partial class NewUnitTest + { + public class Unit4ASDF + { + [SqlSugar.SugarColumn(ColumnDataType = " bigint(20)", IsNullable = true)] + public long? Id { get; set; } + [SqlSugar.SugarColumn(ColumnDataType = " bigint(20)")] + public long Id2 { get; set; } + } + public static void Insert() + { + Db.CodeFirst.InitTables(); + Db.Insertable(new List() { + new Unit4ASDF() { Id=null, Id2=1 }, + new Unit4ASDF() { Id=2, Id2=1 }}).UseMySql().ExecuteBulkCopy(); + + var list = Db.Queryable().ToList(); + + Db.CodeFirst.InitTables(); + Db.DbMaintenance.TruncateTable("testdb"); + var list1 = new List(); + + + + for (int i = 0; i < 10; i++) + + { + + var id = i.ToString(); + + list1.Add(new testdb + + { + + id = id, + + }); + + Console.WriteLine(id + " Length:" + id.Length); + + } + + + + Db.Insertable(list1).UseMySql().ExecuteBulkCopy(); + + + + var queryList = Db.Queryable().ToList(); + + + + foreach (var item in queryList) + + { + + if (item.id.Length != 1) + + { + + throw new Exception("blue copy"); + + } + + } + + Db.CodeFirst.InitTables(); + Db.DbMaintenance.TruncateTable("Testdbbool"); + Db.Insertable(new Testdbbool() { isok = true }).UseMySql().ExecuteBulkCopy(); + Db.Fastest().BulkCopy(new List() { new Testdbbool() { isok = true }, new Testdbbool() { isok = false } }); + var list2= Db.Queryable().ToList(); + + if (!list2.Any(it => it.isok == false)) + { + throw new Exception("blue copy"); + } + + Db.CodeFirst.InitTables(); + + var x= Db.Storageable(new List() + { + new MicroBlog(){ Mid="1" }, + new MicroBlog(){ Mid="2" } + }) + .SplitInsert(it=>!it.Any()) + .WhereColumns(it=>it.Mid).ToStorage(); + + x.AsInsertable.ExecuteCommand(); + + Db.CodeFirst.InitTables(); + Db.DbMaintenance.TruncateTable(); + var fastList = new List() + { + new UnitFastest001 (){ Id=Guid.NewGuid()+"", Remark=@"aa +raa" } + }; + Db.Fastest().BulkCopy(fastList); + var searchList = Db.Queryable().ToList(); + if (searchList.Count != 1) + { + throw new Exception("unit error"); + } + } + + public class UnitFastest001 + { + public string Id { get; set; } + [SqlSugar.SugarColumn(Length =1000)] + public string Remark { get; set; } + } + public class MicroBlog + { + //[SugarColumn(IsPrimaryKey = true, IsIdentity = true)]//如果是主键,此处必须指定,否则会引发InSingle(id)方法异常。 + public string Mid { get; set; } + //public int id { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public string uid { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public string nick { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public DateTime SendTime { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public string content { get; set; } + [SqlSugar.SugarColumn(IsNullable = true)] + public string ForwardHtml { get; set; } + [SqlSugar.SugarColumn(IsNullable =true)] + public string MediaHtml { get; set; } + //public DateTime CreatedAt { get; set; } + } + public class testdb + + { + + public string id { get; set; } + + } + + public class Testdbbool + { + [SqlSugar.SugarColumn(IsPrimaryKey = true,IsIdentity =true)] + public int id { get; set; } + public bool isok { get; set; } + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UJson.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UJson.cs new file mode 100644 index 000000000..35e0d850e --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UJson.cs @@ -0,0 +1,39 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + + public static void Json() + { + Db.CodeFirst.InitTables(); + Db.DbMaintenance.TruncateTable(); + Db.Insertable(new UnitJsonTest() { Order = new Order { Id = 1, Name = "order1" } }).ExecuteCommand(); + var list = Db.Queryable().ToList(); + UValidate.Check("order1", list.First().Order.Name, "Json"); + Db.Updateable(new UnitJsonTest() { Id = 1, Order = new Order { Id = 2, Name = "order2" } }).ExecuteCommand(); + list = Db.Queryable().ToList(); + UValidate.Check("order2", list.First().Order.Name, "Json"); + + Db.Updateable().SetColumns(x => new UnitJsonTest { Order = new Order { Id = 2, Name = "order3" } }).Where(x => x.Id == 1).ExecuteCommand(); + list = Db.Queryable().ToList(); + UValidate.Check("order3", list.First().Order.Name, "Json"); + + var list2 = Db.Queryable().ToList(); + } + } + + + public class UnitJsonTest + { + [SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + [SqlSugar.SugarColumn(ColumnDataType = "varchar(4000)", IsJson = true)] + public Order Order { get; set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryable.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryable.cs new file mode 100644 index 000000000..056618b3d --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryable.cs @@ -0,0 +1,370 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + public static void Queryable() + { + + var pageindex = 1; + var pagesize = 10; + var total = 0; + var totalPage = 0; + var list = Db.Queryable().ToPageList(pageindex, pagesize, ref total, ref totalPage); + + //Db.CodeFirst.InitTables(typeof(CarType)); + //Db.Updateable() + // .SetColumns(it => new CarType { State = SqlSugar.SqlFunc.IIF(it.State == true, false, true) }).Where(it => true) + // .ExecuteCommand(); + + //Db.CodeFirst.InitTables(typeof(TestTree)); + //Db.DbMaintenance.TruncateTable(); + //Db.Ado.ExecuteCommand("insert testtree values(hierarchyid::GetRoot(),geography :: STGeomFromText ('POINT(55.9271035250276 -3.29431266523898)',4326),'name')"); + //var list2 = Db.Queryable().ToList(); + + Db.CodeFirst.InitTables(); + Db.Queryable().Where(it => it.Id.HasValue).ToList(); + + Db.Queryable().Where(it => SqlSugar.SqlFunc.Equals(it.CreateTime.Date, it.CreateTime.Date)).ToList(); + + var sql = Db.Queryable().Select(it => new UnitSelectTest() + { + + DcNull = it.Dc, + Dc = it.Int + }).ToSql().Key; + UValidate.Check(sql, "SELECT `Dc` AS `DcNull` , `Int` AS `Dc` FROM `UnitSelectTest`", "Queryable"); + + sql = Db.Updateable(new UnitSelectTest2()).ToSql().Key; + UValidate.Check(sql, @"UPDATE `UnitSelectTest2` SET + `Dc`=@Dc,`IntNull`=@IntNull WHERE `Int`=@Int", "Queryable"); + + sql = Db.Queryable().IgnoreColumns(it => it.CreateTime).ToSql().Key; + UValidate.Check(sql, "SELECT `Id`,`Name`,`Price`,`CustomId` FROM `Order` ", "Queryable"); + sql = Db.Queryable().IgnoreColumns(it => new { it.Id, it.Name }).ToSql().Key; + UValidate.Check(sql, "SELECT `Price`,`CreateTime`,`CustomId` FROM `Order` ", "Queryable"); + sql = Db.Queryable().IgnoreColumns("id").ToSql().Key; + UValidate.Check(sql, "SELECT `Name`,`Price`,`CreateTime`,`CustomId` FROM `Order` ", "Queryable"); + + var cts = IEnumerbleContains.Data(); + var list2=Db.Queryable() + .Where(p => /*ids.*/cts.Select(c => c.Id).Contains(p.Id)).ToList(); + + var cts2 = IEnumerbleContains.Data().ToList(); ; + var list3 = Db.Queryable() + .Where(p => /*ids.*/cts2.Select(c => c.Id).Contains(p.Id)).ToList(); + + + var list4 = Db.Queryable() + .Where(p => new List { 1, 2, 3 }.Where(b => b > 1).Contains(p.Id)).ToList(); + + Db.CodeFirst.InitTables(); + var list5 = Db.Queryable().Where(it => SqlSugar.SqlFunc.ToString(it.Date.Value.Year) == "1").ToList(); + var list6 = Db.Queryable().Where(it => it.Date.Value.Year == 1).ToList(); + var list7 = Db.Queryable().Where(it => it.Date.Value.Date == DateTime.Now.Date).ToList(); + + + SaleOrder saleOrderInfo = new SaleOrder(); + Db.CodeFirst.InitTables(); + var result = Db.GetSimpleClient().Update(o => new SaleOrder() + { + OrderStatus = 1, + CheckMan = saleOrderInfo.CheckMan, + CheckTime = DateTime.Now + }, o => o.OrderSn == saleOrderInfo.OrderSn && o.OrderStatus != 1); + + + var task=CustomTest1.GetPurchaseDetailPageAsync(Db); + task.Wait(); + + var list14 = Db.Queryable((o1, o2, o3) => + new JoinQueryInfos(JoinType.Inner, o1.Id == o2.Id * 2, JoinType.Inner, o1.Id == o3.Id * 4) + ) + .Select((o1, o2, o3) => new + { + id = o1.Id, + x = o1, + x2 = o2, + x3 = o3 + }).ToList(); + + + var list15 = Db.Queryable((o1, o2, o3) => + new JoinQueryInfos(JoinType.Inner, o1.Id == o2.Id * 2, JoinType.Inner, o1.Id == o3.Id * 4) + ) + .Select((o1, o2, o3) => new TestModel1 + { + id = o1.Id.SelectAll(), + x = o1, + x2 = o2, + x3 = o3 + }).ToList(); + Db.CodeFirst.InitTables(); + Db.Insertable(new UnitEnumadfa()).ExecuteCommand(); + Db.Insertable(new UnitEnumadfa() { Type = DbType.Sqlite }).ExecuteCommand(); + var listEnum = Db.Queryable().ToList(); + } + + + public class UnitEnumadfa + { + [SugarColumn(IsNullable = true)] + public DbType? Type { get; set; } + } + + public static class IEnumerbleContains + { + public static IEnumerable Data() + { + for (int i = 0; i < 100; i++) + { + yield return new Order + { + Id = i, + }; + } + } + } + [SugarTable("UnitSaleOrder")] + public class SaleOrder + { + public SaleOrder() + { + SaleDate = DateTime.Now; + Team = 1; + AddTime = DateTime.Now; + OrderStatus = 0; + Points = 0; + PayPoints = 0; + PointsExchangeMoney = decimal.Zero; + IsPushMessage = false; + CostAmount = decimal.Zero; + OrderAmount = decimal.Zero; + RealOrderAmount = decimal.Zero; + AccountsDueAmount = decimal.Zero; + SettleType = 0; + IsPushMessage = false; + } + + /// + /// 订单号 + /// + public string OrderSn { get; set; } + + /// + /// 客户编号 + /// + public string CustomerNo { get; set; } + + + /// + /// 收货人姓名 + /// + public string CustomerName { get; set; } + + /// + /// 成本总金额 + /// + public decimal CostAmount { get; set; } + + /// + /// 订单总金额 + /// + public decimal OrderAmount { get; set; } + + /// + /// 实收金额(整单优惠后) + /// + public decimal RealOrderAmount { get; set; } + + /// + /// 销货日期 + /// + public DateTime SaleDate { get; set; } + + /// + /// 下单时间 + /// + public DateTime AddTime { get; set; } + + /// + /// 媒体资源投放ID + /// + public string IndustryCode { get; set; } + + public string IndustryName { get; set; } + + /// + /// 备注 + /// + public string Remark { get; set; } + + /// + /// 班组 + /// + public int Team { get; set; } + + /// + /// 销售员编号 + /// + public string SellerNo { get; set; } + + /// + /// 销售员姓名 + /// + public string SellerName { get; set; } + + /// + /// 操作人ID + /// + public virtual string HandlerCode { get; set; } + + /// + /// 操作者 + /// + public string Handler { get; set; } + + /// + /// 发货仓库代号 + /// + public string StoreCode { get; set; } + + /// + /// 发货仓库名称 + /// + public string StoreName { get; set; } + + /// + /// 销货店铺渠道代号 + /// + public string ShopChannelCode { get; set; } + + /// + /// 销货店铺渠道名称 + /// + public string ShopChannelName { get; set; } + + /// + /// 订单产品数 + /// + public int GoodsNum { get; set; } + + /// + /// 礼品数量 + /// + public int GiftNum { get; set; } + + /// + /// 对应预订单号 + /// + public string CustomerOrderSn { get; set; } + + /// + /// 订单赠送积分 + /// + public int Points { get; set; } + + /// + /// 应收款金额 + /// + public decimal AccountsDueAmount { get; set; } + + /// + /// 来自预约单号 + /// + public string ReserationOrderSn { get; set; } + + + /// + /// 订单状态 0为未审核 1为已审核 + /// + public int OrderStatus { get; set; } + + /// + /// 审核人 + /// + public string CheckMan { get; set; } + + /// + /// 审核时间 + /// + public DateTime? CheckTime { get; set; } + + /// + /// 结算类型 0为非金工石(零售) 1为金工石 + /// + public int SettleType { get; set; } + + /// + /// 使用积分 + /// + public int PayPoints { get; set; } + + /// + /// 积分抵现金额 + /// + public decimal PointsExchangeMoney { get; set; } + + /// + /// 是否已推送微信消息 + /// + public bool IsPushMessage { get; set; } + + } + + public class SaleOrderBaseInfo + { + public int GoodsNum { get; set; } + + public int GiftNum { get; set; } + + public decimal OrderAmount { get; set; } + + } + + + public class UnitTest3 + { + public DateTime? Date { get; set; } + } + + + public class UnitSelectTest2 + { + [SqlSugar.SugarColumn(IsOnlyIgnoreUpdate = true)] + public decimal? DcNull { get; set; } + public decimal Dc { get; set; } + public int? IntNull { get; set; } + [SqlSugar.SugarColumn(IsPrimaryKey = true)] + public decimal Int { get; set; } + } + + public class UnitSelectTest + { + public decimal? DcNull { get; set; } + public decimal Dc { get; set; } + public int? IntNull { get; set; } + public decimal Int { get; set; } + } + + public class UnitGuidTable + { + public Guid? Id { get; set; } + } + } + + public class TestModel1 + { + public int id { get; set; } + public string name { get; set; } + public Order x { get; set; } + public Order x2 { get; set; } + public Order x3 { get; set; } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryableAsync.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryableAsync.cs new file mode 100644 index 000000000..7ebce71e8 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueryableAsync.cs @@ -0,0 +1,43 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using SqlSugar; +namespace OrmTest +{ + public partial class NewUnitTest + { + public static void QueryableAsync() + { + q1(); + q2(); + q3(); + } + + private static void q1() + { + RefAsync total = 0; + var count = Db.Queryable().Count(); + Task t = Db.Queryable().ToPageListAsync(1, 2, total); + t.Wait(); + UValidate.Check(count, total.Value, "QueryableAsync"); + } + private static void q2() + { + RefAsync total = 0; + var count = Db.Queryable().Count(); + Task t = Db.Queryable().ToDataTablePageAsync(1, 2, total); + t.Wait(); + UValidate.Check(count, total.Value, "QueryableAsync"); + } + private static void q3() + { + RefAsync total = 0; + var count = Db.Queryable().Count(); + Task t = Db.Queryable().ToJsonPageAsync(1, 2, total); + t.Wait(); + UValidate.Check(count, total.Value, "QueryableAsync"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueue.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueue.cs new file mode 100644 index 000000000..773d3d8ad --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UQueue.cs @@ -0,0 +1,41 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace OrmTest +{ + public partial class NewUnitTest + { + public static void Queue() + { + test1(); + test2(); + } + private static void test2() + { + var db = Db; + db.AddQueue("select 11"); + db.Queryable().Where(it => false).AddQueue(); + db.AddQueue("select 12"); + var list = db.SaveQueuesAsync(); + list.Wait(); + UValidate.Check(list.Result.Item1[0], "11", "Queue"); + UValidate.Check(list.Result.Item2.Count(), 0, "Queue"); + UValidate.Check(list.Result.Item3[0], "12", "Queue"); + } + + private static void test1() + { + var db = Db; + db.AddQueue("select 11"); + db.Queryable().Where(it => false).AddQueue(); + db.AddQueue("select 12"); + var list = db.SaveQueues(); + UValidate.Check(list.Item1[0], "11", "Queue"); + UValidate.Check(list.Item2.Count(), 0, "Queue"); + UValidate.Check(list.Item3[0], "12", "Queue"); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread.cs new file mode 100644 index 000000000..439d45de3 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread.cs @@ -0,0 +1,376 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + + public static SqlSugarClient simpleDb => new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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))); + } + } + }); + public static SqlSugarClient ssDb => new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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))); + } + } + }); + public static SqlSugarClient singleDb = new SqlSugarClient(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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))); + } + } + }); + public static SqlSugarScope singleAndSsDb = new SqlSugarScope(new ConnectionConfig() + { + DbType = DbType.MySqlConnector, + 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))); + } + } + }); + public static void Thread() + { + Simple(); + IsShardSameThread(); + Single(); + SingleAndIsShardSameThread(); + SimpleAsync(); + IsShardSameThreadAsync(); + SingleAsync(); + SingleAndIsShardSameThreadAsync(); + + } + + private static void Simple() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void SingleAndIsShardSameThread() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleAndSsDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleAndSsDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleAndSsDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void Single() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void IsShardSameThread() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + Db.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + Db.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + Db.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommand(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + + + private static void SimpleAsync() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); ; + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void SingleAndIsShardSameThreadAsync() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleAndSsDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleAndSsDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleAndSsDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void SingleAsync() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleDb.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleDb.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + singleDb.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void IsShardSameThreadAsync() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + Db.Insertable(new Order() { Name = "test", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + Db.Insertable(new Order() { Name = "test2", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + Db.Insertable(new Order() { Name = "test3", CreateTime = DateTime.Now }).ExecuteCommandAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread2.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread2.cs new file mode 100644 index 000000000..5fe4c12dd --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread2.cs @@ -0,0 +1,316 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + + public static void Thread2() + { + Simple2(); + IsShardSameThread2(); + Single2(); + SingleAndIsShardSameThread2(); + SimpleAsync2(); + IsShardSameThreadAsync2(); + SingleAsync2(); + SingleAndIsShardSameThreadAsync2(); + + } + + private static void Simple2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void SingleAndIsShardSameThread2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void Single2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void IsShardSameThread2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToList(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + + + private static void SimpleAsync2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); ; + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void SingleAndIsShardSameThreadAsync2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void SingleAsync2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + + private static void IsShardSameThreadAsync2() + { + var t1 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(1); + } + + }); + var t2 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(10); + } + + }); + var t3 = new Task(() => + { + for (int i = 0; i < 100; i++) + { + simpleDb.Queryable().Take(10).ToListAsync().Wait(); + System.Threading.Thread.Sleep(6); + } + + }); + t1.Start(); + t2.Start(); + t3.Start(); + + Task.WaitAll(t1, t2, t3); + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread3.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread3.cs new file mode 100644 index 000000000..9e0e644c4 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UThread3.cs @@ -0,0 +1,117 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + + public static void Thread3() + { + Console.WriteLine("Thread3"); + SimpleAsync3().Wait(); + IsShardSameThreadAsync3().Wait(); + SingleAsync3().Wait(); + SingleAndIsShardSameThreadAsync3().Wait(); + + } + + + + private static async Task SimpleAsync3() + { + + for (int i = 0; i < 100; i++) + { + await simpleDb.Queryable().Take(10).ToListAsync(); + } + + for (int i = 0; i < 100; i++) + { + await simpleDb.Insertable(new Order() { Name = "a", CustomId = 1 }).ExecuteCommandAsync(); + } + + List orders = new List(); + for (int i = 0; i < 100; i++) + { + orders = await simpleDb.Queryable().Take(10).ToListAsync(); + } + if (orders.Count > 0) + { + Console.WriteLine("async is ok"); + } + } + + private static async Task SingleAndIsShardSameThreadAsync3() + { + for (int i = 0; i < 100; i++) + { + await singleAndSsDb.Queryable().Take(10).ToListAsync(); + } + + for (int i = 0; i < 100; i++) + { + await singleAndSsDb.Insertable(new Order() { Name = "a", CustomId = 1 }).ExecuteCommandAsync(); + } + List orders = new List(); + for (int i = 0; i < 100; i++) + { + orders = await singleAndSsDb.Queryable().Take(10).ToListAsync(); + } + if (orders.Count > 0) + { + Console.WriteLine("async is ok"); + } + } + + private static async Task SingleAsync3() + { + for (int i = 0; i < 100; i++) + { + await singleDb.Queryable().Take(10).ToListAsync(); + } + + for (int i = 0; i < 100; i++) + { + await singleDb.Insertable(new Order() { Name = "a", CustomId = 1 }).ExecuteCommandAsync(); + } + + List orders = new List(); + for (int i = 0; i < 100; i++) + { + orders = await singleDb.Queryable().Take(10).ToListAsync(); + } + if (orders.Count > 0) + { + Console.WriteLine("async is ok"); + } + } + + private static async Task IsShardSameThreadAsync3() + { + for (int i = 0; i < 100; i++) + { + await ssDb.Queryable().Take(10).ToListAsync(); + } + + for (int i = 0; i < 100; i++) + { + await ssDb.Insertable(new Order() { Name = "a", CustomId = 1 }).ExecuteCommandAsync(); + } + + List orders = new List(); + for (int i = 0; i < 100; i++) + { + orders = await ssDb.Queryable().Take(10).ToListAsync(); + } + if (orders.Count > 0) + { + Console.WriteLine("async is ok"); + } + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UValidate.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UValidate.cs new file mode 100644 index 000000000..bc2b97fc2 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UValidate.cs @@ -0,0 +1,19 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class UValidate + { + public static void Check(object a, object b, object name) + { + if (a?.ToString()?.Trim() != b?.ToString()?.Trim()) + { + throw new Exception(name + " error"); + } + } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/UnitCustom01.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UnitCustom01.cs new file mode 100644 index 000000000..6ae20e617 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/UnitCustom01.cs @@ -0,0 +1,117 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public class UnitCustom01 + { + public static void Init() + { + var ssc = new SqlSugarClient(new ConnectionConfig() + + { + + ConnectionString = OrmTest.Config.ConnectionString, + + DbType = SqlSugar.DbType.MySqlConnector, //必填 + + IsAutoCloseConnection = true + + }); + ssc.CodeFirst.InitTables(); + var expMethods = new List(); + + expMethods.Add(new SqlFuncExternal() + + { + + UniqueMethodName = "SumSugar", + + MethodValue = (expInfo, dbType, expContext) => + + { + + if (dbType == DbType.SqlServer) + + return string.Format("SUM({0})", expInfo.Args[0].MemberName); + + else if (dbType == DbType.MySqlConnector) + + return string.Format("SUM({0})", expInfo.Args[0].MemberName); + + else + + throw new Exception("未实现"); + + } + + }); + + ssc.CurrentConnectionConfig.ConfigureExternalServices = new ConfigureExternalServices() + + { + + SqlFuncServices = expMethods //set ext method + + }; + + try + + { + ssc.Insertable(new Student() { Age = 1, Createtime = DateTime.Now, Grade = 1, Id = 1, Name = "a", Schoolid = 1 }).ExecuteCommand(); + ssc.Insertable(new Student() { Age = 1, Createtime = DateTime.Now, Grade = 1, Id = 1, Name = "a", Schoolid = 1 }).ExecuteCommand(); + var sss12 = ssc.Queryable().GroupBy(o => o.Name).Select(o => new { Age = SqlFunc.AggregateSum(o.Age) }).ToList(); + + } + + catch (Exception e) + + { + + + + } + } + } + + [SugarTable("unitstudent1111")] + public class Student + { + /// + /// + /// + [SugarColumn(ColumnName = "id", IsPrimaryKey = true, IsIdentity = true)] + public int Id { get; set; } + /// + /// + /// + [SugarColumn(ColumnName = "schoolid")] + public int? Schoolid { get; set; } + /// + /// + /// + [SugarColumn(ColumnName = "name")] + public string Name { get; set; } + /// + /// + /// + [SugarColumn(ColumnName = "createtime")] + public DateTime? Createtime { get; set; } + /// + /// + /// + [SugarColumn(ColumnName = "age")] + public int? Age { get; set; } + /// + /// + /// + [SugarColumn(ColumnName = "grade")] + public int? Grade { get; set; } + } + + +} diff --git a/Src/Asp.Net/MySqlConnectorTest/UnitTest/Updateable.cs b/Src/Asp.Net/MySqlConnectorTest/UnitTest/Updateable.cs new file mode 100644 index 000000000..2c018bcb7 --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/UnitTest/Updateable.cs @@ -0,0 +1,211 @@ +using SqlSugar; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace OrmTest +{ + public partial class NewUnitTest + { + public static void Updateable() + { + Db.CodeFirst.InitTables(typeof(UnitUser)); + Db.DbMaintenance.TruncateTable(); + Db.Insertable(new UnitUser() { USER_ID=1,USER_ACCOUNT = "a", USER_PWD = "b", USER_NAME = "c", PWD_LASTCHTIME = DateTime.Now, PWD_ERRORCOUNT = 1, PWD_LASTERRTIME = DateTime.Now }).ExecuteCommand(); + Db.Updateable(new UnitUser() { USER_ID=1, PWD_LASTERRTIME = null }).WhereColumns(it=> new{ it.PWD_ERRORCOUNT, it.PWD_LASTERRTIME }).ExecuteCommand(); + Db.CodeFirst.InitTables(typeof(UnitBoolTest)); + var x = new UnitBoolTest(); + Db.Updateable().SetColumns(it => new UnitBoolTest() { BoolValue = !it.BoolValue }).Where(it=>it.Id==1).ExecuteCommand(); + Db.Updateable().SetColumns(it => it.BoolValue == !it.BoolValue ).Where(it=>it.Id==1).ExecuteCommand(); + Db.Updateable().SetColumns(it => new UnitBoolTest() { BoolValue = x.BoolValue }).Where(it => it.Id == 1).ExecuteCommand(); + Db.Updateable().SetColumns(it => it.BoolValue == x.BoolValue).Where(it => it.Id == 1).ExecuteCommand(); + Db.Updateable().SetColumns(it => new UnitBoolTest() { BoolValue = !x.BoolValue }).Where(it => it.Id == 1).ExecuteCommand(); + Db.Updateable().SetColumns(it => it.BoolValue == !x.BoolValue).Where(it => it.Id == 1).ExecuteCommand(); + Db.Updateable(x).ReSetValue(it => it.BoolValue = it.BoolValue).ExecuteCommand(); + Db.Updateable(x).ReSetValue(it => it.BoolValue = true).ExecuteCommand(); + Db.Updateable(x).ReSetValue(it => it.BoolValue = !it.BoolValue).ExecuteCommand(); + Db.Updateable(x).UpdateColumns(it =>new { it.BoolValue }) .ExecuteCommand(); + + + + UnitSaveDiary saveDiary = new UnitSaveDiary(); + saveDiary.ID = 2; + saveDiary.TypeID = 10; + saveDiary.TypeName = "类型100"; + saveDiary.Title = "标题1000"; + saveDiary.Content = "内容"; + saveDiary.Time = DateTime.Now; + saveDiary.IsRemind = false;//无论传false/true 最终执行的结果都是以true执行的 + + var sql = Db.Updateable().SetColumns(it => new UnitDiary() + { + IsRemind = saveDiary.IsRemind, + }).Where(it => it.ID == saveDiary.ID).ToSql(); + UValidate.Check(sql.Key, @"UPDATE `Diary` SET + `IsRemind` = @Const0 WHERE ( `ID` = @ID1 )", "Updateable"); + + + sql = Db.Updateable().SetColumns(it => new UnitDiary() + { + TypeID = saveDiary.TypeID, + }).Where(it => it.ID == saveDiary.ID).ToSql(); + UValidate.Check(sql.Key, @"UPDATE `Diary` SET + `TypeID` = @Const0 WHERE ( `ID` = @ID1 )", "Updateable"); + + } + } + public class UnitSaveDiary + { + public int ID { get; set; } + public int TypeID { get; set; } + public string TypeName { get; set; } + public string Title { get; set; } + public string Content { get; set; } + public DateTime? Time { get; set; } + public bool IsRemind { get; set; } + } + /// + /// 日记表 + /// + [SugarTable("Diary")] + public class UnitDiary + { + [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] + public int ID { get; set; } + /// + /// 用户ID + /// + public int? UserID { get; set; } + /// + /// 日记类型ID + /// + public int? TypeID { get; set; } + /// + /// 日记类型名称 + /// + public string TypeName { get; set; } + /// + /// 标题 + /// + public string Title { get; set; } + /// + /// 内容 + /// + public string Content { get; set; } + /// + /// 时间 + /// + public DateTime? Time { get; set; } + /// + /// 是否提醒 + /// + public bool? IsRemind { get; set; } + /// + /// 封面图 + /// + public string Cover { get; set; } + /// + /// 是否为系统日记 1:系统日记 0:用户日记 + /// + public bool? IsSystem { get; set; } + /// + /// 权重(排序) + /// + public int? Sequence { get; set; } + /// + /// + /// + public string IP { get; set; } + /// + /// + /// + public DateTime? CreateTime { get; set; } + /// + /// + /// + public DateTime? UpdateTime { get; set; } + /// + /// + /// + public bool? IsDelete { get; set; } + } + + public class UnitBoolTest + { + [SugarColumn(IsPrimaryKey =true)] + public int Id { get; set; } + public bool BoolValue { get; set; } + public string Name { get; set; } + } + /// + /// 普通用户表 + /// + [Serializable] + public class UnitUser + { + private System.Int64? _USER_ID; + /// + /// GUID主键 + /// + [SugarColumn(IsPrimaryKey = true, IsIdentity = false)] + public System.Int64? USER_ID { get { return this._USER_ID; } set { this._USER_ID = value; } } + + private System.String _USER_ACCOUNT; + /// + /// 用户账号,不可重名,即使是假删除了,亦不可重复 + /// + public System.String USER_ACCOUNT { get { return this._USER_ACCOUNT; } set { this._USER_ACCOUNT = value; } } + + private System.String _USER_PWD; + /// + /// 用户密码 + /// + public System.String USER_PWD + { + get { return this._USER_PWD; } + set { this._USER_PWD = value; } + } + /// + /// 不允许用户密码序列化,可以反序列化 + /// + /// + public bool ShouldSerializeUSER_PWD() + { + return false; + } + + private System.String _USER_NAME; + /// + /// 用户姓名 + /// + + public System.String USER_NAME { get { return this._USER_NAME; } set { this._USER_NAME = value; } } + + private System.Int32 _USER_STATUS; + /// + /// 用户状体:10正常;20锁定;99已删除 + /// + public System.Int32 USER_STATUS { get { return this._USER_STATUS; } set { this._USER_STATUS = value; } } + + private System.DateTime _PWD_LASTCHTIME; + /// + /// 最后一次密码更新时间 + /// + public System.DateTime PWD_LASTCHTIME { get { return this._PWD_LASTCHTIME; } set { this._PWD_LASTCHTIME = value; } } + + private System.Int32? _PWD_ERRORCOUNT; + /// + /// 密码错误次数,达到定义的次数就锁定 + /// + public System.Int32? PWD_ERRORCOUNT { get { return this._PWD_ERRORCOUNT; } set { this._PWD_ERRORCOUNT = value ?? 0; } } + + private System.DateTime? _PWD_LASTERRTIME = null; + /// + /// 密码最后一次错误时间,满足定义的时间差之后,可自动解锁,如20分钟后自动解锁,亦作为累次错误次数的时间差比对基础 + /// 允许为空 + /// + public System.DateTime? PWD_LASTERRTIME { get { return this._PWD_LASTERRTIME; } set { this._PWD_LASTERRTIME = value; } } + } +} diff --git a/Src/Asp.Net/MySqlConnectorTest/packages.config b/Src/Asp.Net/MySqlConnectorTest/packages.config new file mode 100644 index 000000000..dc530130b --- /dev/null +++ b/Src/Asp.Net/MySqlConnectorTest/packages.config @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/Src/Asp.Net/SqlSugar.Access/Properties/AssemblyInfo.cs b/Src/Asp.Net/SqlSugar.Access/Properties/AssemblyInfo.cs new file mode 100644 index 000000000..4896c91f1 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.Access/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// 有关程序集的一般信息由以下 +// 控制。更改这些特性值可修改 +// 与程序集关联的信息。 +[assembly: AssemblyTitle("SqlSugar.Access")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("SqlSugar.Access")] +[assembly: AssemblyCopyright("Copyright © 2022")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// 将 ComVisible 设置为 false 会使此程序集中的类型 +//对 COM 组件不可见。如果需要从 COM 访问此程序集中的类型 +//请将此类型的 ComVisible 特性设置为 true。 +[assembly: ComVisible(false)] + +// 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID +[assembly: Guid("0a27f276-d442-4e0a-b810-32d6074f0155")] + +// 程序集的版本信息由下列四个值组成: +// +// 主版本 +// 次版本 +// 生成号 +// 修订号 +// +//可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值 +//通过使用 "*",如下所示: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/Src/Asp.Net/SqlSugar.Access/Queryable.cs b/Src/Asp.Net/SqlSugar.Access/Queryable.cs new file mode 100644 index 000000000..e5a71d518 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.Access/Queryable.cs @@ -0,0 +1,13 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace SqlSugar.Access +{ + public class AccessQueryable : QueryableProvider + { + + } +} diff --git a/Src/Asp.Net/SqlSugar.Access/SqlSugar.Access.csproj b/Src/Asp.Net/SqlSugar.Access/SqlSugar.Access.csproj new file mode 100644 index 000000000..8a9ae63be --- /dev/null +++ b/Src/Asp.Net/SqlSugar.Access/SqlSugar.Access.csproj @@ -0,0 +1,54 @@ + + + + + Debug + AnyCPU + {0A27F276-D442-4E0A-B810-32D6074F0155} + Library + Properties + SqlSugar.Access + SqlSugar.Access + v4.6 + 512 + true + + + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + + + + + + + + + + + + + + + {489bb790-226c-4fad-8d1e-51d72a7ff8e5} + SqlSugar + + + + \ No newline at end of file diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/CodeFirst/MySqlCodeFirst.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/CodeFirst/MySqlCodeFirst.cs new file mode 100644 index 000000000..bd45e64f9 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/CodeFirst/MySqlCodeFirst.cs @@ -0,0 +1,80 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace SqlSugar.MySqlConnector +{ + public class MySqlCodeFirst : CodeFirstProvider + { + public override void NoExistLogic(EntityInfo entityInfo) + { + var tableName = GetTableName(entityInfo); + //Check.Exception(entityInfo.Columns.Where(it => it.IsPrimarykey).Count() > 1, "Use Code First ,The primary key must not exceed 1"); + List columns = new List(); + if (entityInfo.Columns.HasValue()) + { + foreach (var item in entityInfo.Columns.OrderBy(it => it.IsPrimarykey ? 0 : 1)) + { + if (item.IsIgnore) + continue; + if (item.PropertyInfo!=null&&UtilMethods.GetUnderType(item.PropertyInfo.PropertyType) == UtilConstants.GuidType && item.Length == 0&&item.DataType==null) + { + item.Length = Guid.NewGuid().ToString().Length; + } + DbColumnInfo dbColumnInfo = this.EntityColumnToDbColumn(entityInfo, tableName, item); + columns.Add(dbColumnInfo); + } + } + this.Context.DbMaintenance.CreateTable(tableName, columns,true); + } + protected override DbColumnInfo EntityColumnToDbColumn(EntityInfo entityInfo, string tableName, EntityColumnInfo item) + { + var propertyType = UtilMethods.GetUnderType(item.PropertyInfo); + var result = new DbColumnInfo() + { + TableId = entityInfo.Columns.IndexOf(item), + DbColumnName = item.DbColumnName.HasValue() ? item.DbColumnName : item.PropertyName, + IsPrimarykey = item.IsPrimarykey, + IsIdentity = item.IsIdentity, + TableName = tableName, + IsNullable = item.IsNullable, + DefaultValue = item.DefaultValue, + ColumnDescription = item.ColumnDescription, + Length = item.Length, + DecimalDigits=item.DecimalDigits + }; + GetDbType(item, propertyType, result); + if (result.DataType.Equals("varchar", StringComparison.CurrentCultureIgnoreCase) && result.Length == 0) + { + result.Length = 1; + } + return result; + } + + protected override void ConvertColumns(List dbColumns) + { + foreach (var item in dbColumns) + { + if (item.DataType == "DateTime") + { + item.Length = 0; + } + } + } + + protected override void ChangeKey(EntityInfo entityInfo, string tableName, EntityColumnInfo item) + { + this.Context.DbMaintenance.UpdateColumn(tableName, EntityColumnToDbColumn(entityInfo, tableName, item)); + if (!item.IsPrimarykey) + this.Context.DbMaintenance.DropConstraint(tableName,null); + if (item.IsPrimarykey) + this.Context.DbMaintenance.AddPrimaryKey(tableName, item.DbColumnName); + } + + internal DbColumnInfo GetEntityColumnToDbColumn(EntityInfo entity, string dbTableName, EntityColumnInfo item) + { + return EntityColumnToDbColumn(entity,dbTableName,item); + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbBind/MySqlDbBind.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbBind/MySqlDbBind.cs new file mode 100644 index 000000000..eceb352a4 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbBind/MySqlDbBind.cs @@ -0,0 +1,97 @@ +using System; +using System.Collections.Generic; +using System.Linq; + +namespace SqlSugar.MySqlConnector +{ + public class MySqlDbBind : DbBindProvider + { + public override string GetDbTypeName(string csharpTypeName) + { + if (csharpTypeName == UtilConstants.ByteArrayType.Name) + { + return "blob"; + } + if (csharpTypeName == "Int32") + csharpTypeName = "int"; + if (csharpTypeName == "Int16") + csharpTypeName = "short"; + if (csharpTypeName == "Int64") + csharpTypeName = "long"; + if (csharpTypeName == "Boolean") + csharpTypeName = "bool"; + if (csharpTypeName == "SByte") + csharpTypeName = "Byte"; + if (csharpTypeName == "DateTimeOffset") + csharpTypeName = "DateTime"; + var mappings = this.MappingTypes.Where(it => it.Value.ToString().Equals(csharpTypeName, StringComparison.CurrentCultureIgnoreCase)); + return mappings.HasValue() ? mappings.First().Key : "varchar"; + } + public override List> MappingTypes + { + get + { + var extService = this.Context.CurrentConnectionConfig.ConfigureExternalServices; + if (extService != null && extService.AppendDataReaderTypeMappings.HasValue()) + { + return extService.AppendDataReaderTypeMappings.Union(MappingTypesConst).ToList(); + } + else + { + return MappingTypesConst; + } + } + } + public static List> MappingTypesConst = new List>(){ + + new KeyValuePair("int",CSharpDataType.@int), + new KeyValuePair("mediumint",CSharpDataType.@int), + new KeyValuePair("integer",CSharpDataType.@int), + + new KeyValuePair("varchar",CSharpDataType.@string), + new KeyValuePair("text",CSharpDataType.@string), + new KeyValuePair("char",CSharpDataType.@string), + new KeyValuePair("enum",CSharpDataType.@string), + new KeyValuePair("mediumtext",CSharpDataType.@string), + new KeyValuePair("tinytext",CSharpDataType.@string), + new KeyValuePair("longtext",CSharpDataType.@string), + + new KeyValuePair("tinyint",CSharpDataType.@byte), + new KeyValuePair("smallint",CSharpDataType.@short), + new KeyValuePair("bigint",CSharpDataType.@long), + new KeyValuePair("bit",CSharpDataType.@bool), + new KeyValuePair("real",CSharpDataType.@double), + new KeyValuePair("double",CSharpDataType.@double), + new KeyValuePair("float",CSharpDataType.@float), + new KeyValuePair("float",CSharpDataType.Single), + new KeyValuePair("decimal",CSharpDataType.@decimal), + new KeyValuePair("numeric",CSharpDataType.@decimal), + new KeyValuePair("year",CSharpDataType.@int), + + new KeyValuePair("datetime",CSharpDataType.DateTime), + new KeyValuePair("timestamp",CSharpDataType.DateTime), + new KeyValuePair("date",CSharpDataType.DateTime), + new KeyValuePair("time",CSharpDataType.DateTime), + + new KeyValuePair("blob",CSharpDataType.byteArray), + new KeyValuePair("longblob",CSharpDataType.byteArray), + new KeyValuePair("tinyblob",CSharpDataType.byteArray), + new KeyValuePair("varbinary",CSharpDataType.byteArray), + new KeyValuePair("binary",CSharpDataType.byteArray), + new KeyValuePair("multipoint",CSharpDataType.byteArray), + new KeyValuePair("geometry",CSharpDataType.byteArray), + new KeyValuePair("multilinestring",CSharpDataType.byteArray), + new KeyValuePair("polygon",CSharpDataType.byteArray), + new KeyValuePair("mediumblob",CSharpDataType.byteArray), + + new KeyValuePair("varchar",CSharpDataType.Guid), + }; + public override List StringThrow + { + get + { + return new List() { "int32", "datetime", "decimal", "double", "byte" }; + } + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbFirst/MySqlDbFirst.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbFirst/MySqlDbFirst.cs new file mode 100644 index 000000000..c3d893206 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbFirst/MySqlDbFirst.cs @@ -0,0 +1,11 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; + +namespace SqlSugar.MySqlConnector +{ + public class MySqlDbFirst : DbFirstProvider + { + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbMaintenance/MySqlDbMaintenance.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbMaintenance/MySqlDbMaintenance.cs new file mode 100644 index 000000000..6da274a6a --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/DbMaintenance/MySqlDbMaintenance.cs @@ -0,0 +1,464 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.RegularExpressions; + +namespace SqlSugar.MySqlConnector +{ + public class MySqlDbMaintenance : DbMaintenanceProvider + { + #region DML + protected override string GetDataBaseSql + { + get + { + return "SHOW DATABASES"; + } + } + protected override string GetColumnInfosByTableNameSql + { + get + { + string sql = @"SELECT + 0 as TableId, + TABLE_NAME as TableName, + column_name AS DbColumnName, + CASE WHEN left(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)-1)='' THEN COLUMN_TYPE ELSE left(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)-1) END AS DataType, + CAST(SUBSTRING(COLUMN_TYPE,LOCATE('(',COLUMN_TYPE)+1,LOCATE(')',COLUMN_TYPE)-LOCATE('(',COLUMN_TYPE)-1) AS signed) AS Length, + column_default AS `DefaultValue`, + column_comment AS `ColumnDescription`, + CASE WHEN COLUMN_KEY = 'PRI' + THEN true ELSE false END AS `IsPrimaryKey`, + CASE WHEN EXTRA='auto_increment' THEN true ELSE false END as IsIdentity, + CASE WHEN is_nullable = 'YES' + THEN true ELSE false END AS `IsNullable`, + numeric_scale as Scale, + numeric_scale as DecimalDigits + FROM + Information_schema.columns where TABLE_NAME='{0}' and TABLE_SCHEMA=(select database()) ORDER BY ordinal_position"; + return sql; + } + } + protected override string GetTableInfoListSql + { + get + { + return @"select TABLE_NAME as Name,TABLE_COMMENT as Description from information_schema.tables + where TABLE_SCHEMA=(select database()) AND TABLE_TYPE='BASE TABLE'"; + } + } + protected override string GetViewInfoListSql + { + get + { + return @"select TABLE_NAME as Name,TABLE_COMMENT as Description from information_schema.tables + where TABLE_SCHEMA=(select database()) AND TABLE_TYPE='VIEW' + "; + } + } + #endregion + + #region DDL + protected override string CreateDataBaseSql + { + get + { + return "CREATE DATABASE `{0}` CHARACTER SET utf8 COLLATE utf8_general_ci "; + } + } + protected override string AddPrimaryKeySql + { + get + { + return "ALTER TABLE {0} ADD PRIMARY KEY({2}) /*{1}*/"; + } + } + protected override string AddColumnToTableSql + { + get + { + return "ALTER TABLE {0} ADD {1} {2}{3} {4} {5} {6}"; + } + } + protected override string AlterColumnToTableSql + { + get + { + // return "ALTER TABLE {0} ALTER COLUMN {1} {2}{3} {4} {5} {6}"; + return "alter table {0} change column {1} {1} {2}{3} {4} {5} {6}"; + } + } + protected override string BackupDataBaseSql + { + get + { + return "mysqldump.exe {0} -uroot -p > {1} "; + } + } + protected override string CreateTableSql + { + get + { + return "CREATE TABLE {0}(\r\n{1} $PrimaryKey)"; + } + } + protected override string CreateTableColumn + { + get + { + return "{0} {1}{2} {3} {4} {5}"; + } + } + protected override string TruncateTableSql + { + get + { + return "TRUNCATE TABLE {0}"; + } + } + protected override string BackupTableSql + { + get + { + return "Create table {1} (Select * from {2} LIMIT 0,{0})"; + } + } + protected override string DropTableSql + { + get + { + return "DROP TABLE {0}"; + } + } + protected override string DropColumnToTableSql + { + get + { + return "ALTER TABLE {0} DROP COLUMN {1}"; + } + } + protected override string DropConstraintSql + { + get + { + return "ALTER TABLE {0} drop primary key;"; + } + } + protected override string RenameColumnSql + { + get + { + return "alter table {0} change column {1} {2}"; + } + } + #endregion + + #region Check + protected override string CheckSystemTablePermissionsSql + { + get + { + return "select 1 from Information_schema.columns limit 0,1"; + } + } + #endregion + + #region Scattered + protected override string CreateTableNull + { + get + { + return "DEFAULT NULL"; + } + } + protected override string CreateTableNotNull + { + get + { + return "NOT NULL"; + } + } + protected override string CreateTablePirmaryKey + { + get + { + return "PRIMARY KEY"; + } + } + protected override string CreateTableIdentity + { + get + { + return "AUTO_INCREMENT"; + } + } + + protected override string AddColumnRemarkSql + { + get + { + throw new NotSupportedException(); + } + } + + protected override string DeleteColumnRemarkSql + { + get + { + throw new NotSupportedException(); + } + } + + protected override string IsAnyColumnRemarkSql + { + get + { + throw new NotSupportedException(); + } + } + + protected override string AddTableRemarkSql + { + get + { + return "ALTER TABLE {0} COMMENT='{1}';"; + } + } + + protected override string DeleteTableRemarkSql + { + get + { + return "ALTER TABLE {0} COMMENT='';"; + } + } + + protected override string IsAnyTableRemarkSql + { + get + { + throw new NotSupportedException(); + } + } + + protected override string RenameTableSql { + get + { + return "alter table {0} rename {1}"; + } + } + + protected override string CreateIndexSql + { + get + { + return "CREATE {3} INDEX `Index_{0}_{2}` ON `{0}` ({1})"; + } + } + + protected override string AddDefaultValueSql + { + get + { + return "ALTER TABLE `{0}` ALTER COLUMN `{1}` SET DEFAULT '{2}'"; + } + } + protected override string IsAnyIndexSql + { + get + { + return "SELECT count(*) FROM information_schema.statistics WHERE index_name = '{0}'"; + } + } + #endregion + + #region Methods + /// + ///by current connection string + /// + /// + /// + public override bool CreateDatabase(string databaseName, string databaseDirectory = null) + { + if (databaseDirectory != null) + { + if (!FileHelper.IsExistDirectory(databaseDirectory)) + { + FileHelper.CreateDirectory(databaseDirectory); + } + } + var oldDatabaseName = this.Context.Ado.Connection.Database; + var connection = this.Context.CurrentConnectionConfig.ConnectionString; + Check.Exception(Regex.Split(connection,oldDatabaseName).Length > 2, "The user name and password cannot be the same as the database name "); + connection = connection.Replace(oldDatabaseName, "mysql"); + var newDb = new SqlSugarClient(new ConnectionConfig() + { + DbType = this.Context.CurrentConnectionConfig.DbType, + IsAutoCloseConnection = true, + ConnectionString = connection + }); + if (!GetDataBaseList(newDb).Any(it => it.Equals(databaseName, StringComparison.CurrentCultureIgnoreCase))) + { + newDb.Ado.ExecuteCommand(string.Format(CreateDataBaseSql, databaseName, databaseDirectory)); + } + return true; + } + public override bool AddTableRemark(string tableName, string description) + { + string sql = string.Format(this.AddTableRemarkSql, this.SqlBuilder.GetTranslationTableName(tableName), description); + this.Context.Ado.ExecuteCommand(sql); + return true; + } + public override bool CreateTable(string tableName, List columns, bool isCreatePrimaryKey = true) + { + if (columns.HasValue()) + { + foreach (var item in columns) + { + if (item.DbColumnName.Equals("GUID",StringComparison.CurrentCultureIgnoreCase)&&item.Length==0) + { + item.Length = 10; + } + } + } + string sql = GetCreateTableSql(tableName, columns); + string primaryKeyInfo = null; + if (columns.Any(it => it.IsPrimarykey)&&isCreatePrimaryKey) { + primaryKeyInfo =string.Format( ", Primary key({0})",string.Join(",",columns.Where(it=>it.IsPrimarykey).Select(it=>this.SqlBuilder.GetTranslationColumnName(it.DbColumnName)))); + + } + sql = sql.Replace("$PrimaryKey", primaryKeyInfo); + this.Context.Ado.ExecuteCommand(sql); + return true; + } + public override bool AddRemark(EntityInfo entity) + { + var db = this.Context; + db.DbMaintenance.AddTableRemark(entity.DbTableName, entity.TableDescription); + List columns = entity.Columns.Where(it => it.IsIgnore == false).ToList(); + foreach (var item in columns) + { + if (item.ColumnDescription != null) + { + var mySqlCodeFirst = this.Context.CodeFirst as MySqlCodeFirst; + string sql = GetUpdateColumnSql(entity.DbTableName, mySqlCodeFirst.GetEntityColumnToDbColumn(entity, entity.DbTableName, item))+" "+(item.IsIdentity? "AUTO_INCREMENT" : "")+" " + " COMMENT '" + item.ColumnDescription + "'"; + db.Ado.ExecuteCommand(sql); + } + } + return true; + } + protected override string GetCreateTableSql(string tableName, List columns) + { + List columnArray = new List(); + Check.Exception(columns.IsNullOrEmpty(), "No columns found "); + foreach (var item in columns) + { + string columnName = item.DbColumnName; + string dataSize = ""; + dataSize = GetSize(item); + string dataType = item.DataType; + string nullType = item.IsNullable ? this.CreateTableNull : CreateTableNotNull; + string primaryKey = null; + string identity = item.IsIdentity ? this.CreateTableIdentity : null; + string addItem = string.Format(this.CreateTableColumn, this.SqlBuilder.GetTranslationColumnName(columnName), dataType, dataSize, nullType, primaryKey, identity); + columnArray.Add(addItem); + } + string tableString = string.Format(this.CreateTableSql, this.SqlBuilder.GetTranslationTableName(tableName), string.Join(",\r\n", columnArray)); + return tableString; + } + + protected override string GetSize(DbColumnInfo item) + { + string dataSize = null; + var isMax = item.Length > 4000 || item.Length == -1; + if (isMax) + { + dataSize=""; + item.DataType = "longtext"; + } + else if (item.Length > 0 && item.DecimalDigits == 0) + { + dataSize = item.Length > 0 ? string.Format("({0})", item.Length) : null; + } + else if (item.Length == 0 && item.DecimalDigits > 0) + { + item.Length = 10; + dataSize = string.Format("({0},{1})", item.Length, item.DecimalDigits); + } + else if (item.Length > 0 && item.DecimalDigits > 0) + { + dataSize = item.Length > 0 ? string.Format("({0},{1})", item.Length, item.DecimalDigits) : null; + } + return dataSize; + } + + public override bool RenameColumn(string tableName, string oldColumnName, string newColumnName) + { + var columns=GetColumnInfosByTableName(tableName).Where(it=>it.DbColumnName.Equals(oldColumnName,StringComparison.CurrentCultureIgnoreCase)); + if (columns != null && columns.Any()) + { + var column = columns.First(); + var appendSql = " " + column.DataType; + if (column.Length > 0 && column.Scale == 0) + { + appendSql += string.Format("({0}) ", column.Length); + } + else if (column.Scale > 0 && column.Length > 0) + { + appendSql += string.Format("({0},{1}) ", column.Length, column.Scale); + } + else + { + appendSql += column.IsNullable ? " NULL " : " NOT NULL "; + } + tableName = this.SqlBuilder.GetTranslationTableName(tableName); + oldColumnName = this.SqlBuilder.GetTranslationColumnName(oldColumnName); + newColumnName = this.SqlBuilder.GetTranslationColumnName(newColumnName); + string sql = string.Format(this.RenameColumnSql, tableName, oldColumnName, newColumnName+appendSql); + this.Context.Ado.ExecuteCommand(sql); + return true; + } + else + { + return false; + } + } + public override bool AddDefaultValue(string tableName, string columnName, string defaultValue) + { + if (defaultValue == "''") + { + defaultValue = ""; + } + if (defaultValue.ToLower().IsIn("now()", "current_timestamp")|| defaultValue.ToLower().Contains("current_timestamp")) + { + string template = "ALTER table {0} CHANGE COLUMN {1} {1} {3} default {2}"; + var dbColumnInfo = this.Context.DbMaintenance.GetColumnInfosByTableName(tableName).First(it => it.DbColumnName.Equals(columnName, StringComparison.CurrentCultureIgnoreCase)); + string sql = string.Format(template, tableName, columnName, defaultValue, dbColumnInfo.DataType); + this.Context.Ado.ExecuteCommand(sql); + return true; + } + else if (defaultValue=="0"|| defaultValue == "1") + { + string sql = string.Format(AddDefaultValueSql.Replace("'",""), tableName, columnName, defaultValue); + this.Context.Ado.ExecuteCommand(sql); + return true; + } + else + { + return base.AddDefaultValue(tableName, columnName, defaultValue); + } + } + public override bool IsAnyConstraint(string constraintName) + { + throw new NotSupportedException("MySql IsAnyConstraint NotSupportedException"); + } + public override bool BackupDataBase(string databaseName, string fullFileName) + { + Check.ThrowNotSupportedException("MySql BackupDataBase NotSupported"); + return false; + } + + #endregion + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/MySqlProvider.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/MySqlProvider.cs new file mode 100644 index 000000000..761cf7cda --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/MySqlProvider.cs @@ -0,0 +1,140 @@ +using MySqlConnector; +using System; +using System.Collections.Generic; +using System.Data; +using System.Data.Common; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +namespace SqlSugar.MySqlConnector +{ + public class MySqlProvider : AdoProvider + { + public MySqlProvider() { } + public override IDbConnection Connection + { + get + { + if (base._DbConnection == null) + { + try + { + var mySqlConnectionString = base.Context.CurrentConnectionConfig.ConnectionString; + if (!mySqlConnectionString.ToLower().Contains("charset")) + { + mySqlConnectionString = mySqlConnectionString.Trim().TrimEnd(';') + ";charset=utf8;"; + } + base._DbConnection = new MySqlConnection(mySqlConnectionString); + } + catch (Exception ex) + { + Check.Exception(true, ex.Message); + } + } + return base._DbConnection; + } + set + { + base._DbConnection = value; + } + } + + public override void BeginTran(string transactionName) + { + base.BeginTran(); + } + /// + /// Only SqlServer + /// + /// + /// + public override void BeginTran(IsolationLevel iso, string transactionName) + { + base.BeginTran(iso); + } + public override IDataAdapter GetAdapter() + { + return new MySqlDataAdapter(); + } + public override DbCommand GetCommand(string sql, SugarParameter[] parameters) + { + MySqlCommand sqlCommand = new MySqlCommand(sql, (MySqlConnection)this.Connection); + sqlCommand.CommandType = this.CommandType; + sqlCommand.CommandTimeout = this.CommandTimeOut; + if (this.Transaction != null) + { + sqlCommand.Transaction = (MySqlTransaction)this.Transaction; + } + if (parameters.HasValue()) + { + IDataParameter[] ipars = ToIDbDataParameter(parameters); + sqlCommand.Parameters.AddRange((MySqlParameter[])ipars); + } + CheckConnection(); + return sqlCommand; + } + public override void SetCommandToAdapter(IDataAdapter dataAdapter, DbCommand command) + { + ((MySqlDataAdapter)dataAdapter).SelectCommand = (MySqlCommand)command; + } + /// + /// if mysql return MySqlParameter[] pars + /// if sqlerver return SqlParameter[] pars ... + /// + /// + /// + public override IDataParameter[] ToIDbDataParameter(params SugarParameter[] parameters) + { + if (parameters == null || parameters.Length == 0) return null; + MySqlParameter[] result = new MySqlParameter[parameters.Length]; + int index = 0; + var isVarchar =IsVarchar(); + foreach (var parameter in parameters) + { + if (parameter.Value == null) parameter.Value = DBNull.Value; + var sqlParameter = new MySqlParameter(); + sqlParameter.ParameterName = parameter.ParameterName; + sqlParameter.Size = parameter.Size; + sqlParameter.Value = parameter.Value; + sqlParameter.DbType = parameter.DbType; + if (parameter.Direction == 0) + { + parameter.Direction = ParameterDirection.Input; + } + sqlParameter.Direction = parameter.Direction; + //if (sqlParameter.Direction == 0) + //{ + // sqlParameter.Direction = ParameterDirection.Input; + //} + result[index] = sqlParameter; + if (sqlParameter.Direction.IsIn(ParameterDirection.Output, ParameterDirection.InputOutput, ParameterDirection.ReturnValue)) + { + if (this.OutputParameters == null) this.OutputParameters = new List(); + this.OutputParameters.RemoveAll(it => it.ParameterName == sqlParameter.ParameterName); + this.OutputParameters.Add(sqlParameter); + } + if (isVarchar && sqlParameter.DbType == System.Data.DbType.String) + { + sqlParameter.DbType = System.Data.DbType.AnsiString; + } + else if (parameter.DbType== System.Data.DbType.DateTimeOffset) + { + if(sqlParameter.Value != DBNull.Value) + sqlParameter.Value = UtilMethods.ConvertFromDateTimeOffset((DateTimeOffset)sqlParameter.Value); + sqlParameter.DbType = System.Data.DbType.DateTime; + } + ++index; + } + return result; + } + + private bool IsVarchar() + { + if (this.Context.CurrentConnectionConfig.MoreSettings != null && this.Context.CurrentConnectionConfig.MoreSettings.DisableNvarchar) + { + return true; + } + return false; + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/Queryable/MySqlQueryable.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/Queryable/MySqlQueryable.cs new file mode 100644 index 000000000..97779c89a --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/Queryable/MySqlQueryable.cs @@ -0,0 +1,60 @@ +namespace SqlSugar.MySqlConnector +{ + public class MySqlQueryable : QueryableProvider + { + public override ISugarQueryable With(string withString) + { + return this; + } + + public override ISugarQueryable PartitionBy(string groupFileds) + { + this.GroupBy(groupFileds); + return this; + } + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } + public class MySqlQueryable : QueryableProvider + { + + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBlukCopy.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBlukCopy.cs new file mode 100644 index 000000000..f7a4219bf --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBlukCopy.cs @@ -0,0 +1,202 @@ +using MySqlConnector; +using System; +using System.Collections.Generic; +using System.Data; +using System.IO; +using System.Linq; +using System.Reflection; +using System.Text; +using System.Threading.Tasks; +namespace SqlSugar.MySqlConnector +{ + public class MySqlBlukCopy + { + internal SqlSugarProvider Context { get; set; } + internal ISqlBuilder Builder { get; set; } + internal T[] Entitys { get; set; } + internal string Chara { get; set; } + private MySqlBlukCopy() + { + + } + public MySqlBlukCopy(SqlSugarProvider context, ISqlBuilder builder, T []entitys) + { + this.Context = context; + this.Builder = builder; + this.Entitys = entitys; + } + public bool ExecuteBulkCopy(string characterSet) + { + this.Chara = characterSet; + return ExecuteBulkCopy(); + } + + public bool ExecuteBulkCopy() + { + var IsBulkLoad = false; + if (Entitys == null || Entitys.Length <= 0) + return IsBulkLoad; + if (Entitys.First() == null && Entitys.Length ==1) + return IsBulkLoad; + DataTable dt = new DataTable(); + Type type = typeof(T); + var entity = this.Context.EntityMaintenance.GetEntityInfo(); + dt.TableName = this.Builder.GetTranslationColumnName(entity.DbTableName); + //if (this.Context.MappingTables != null && this.Context.MappingTables.Any(it => it.EntityName == it.EntityName)) + //{ + // dt.TableName = this.Builder.GetTranslationColumnName(this.Context.MappingTables.First(it => it.EntityName == it.EntityName).DbTableName); + //} + //创建属性的集合 + List pList = new List(); + //把所有的public属性加入到集合 并添加DataTable的列 + Array.ForEach(entity.Columns.ToArray(), p => { + if (!p.IsIgnore&& !p.IsOnlyIgnoreInsert) + { + pList.Add(p.PropertyInfo); dt.Columns.Add(p.DbColumnName); + } + }); + DataRow row = null; + foreach (T item in Entitys) + { + row = dt.NewRow(); + pList.ForEach(p => + { + var name = p.Name; + if (entity.Columns.Any(it => it.PropertyName == name)) + { + name = entity.Columns.First(it => it.PropertyName == name).DbColumnName; + } + row[name] = GetValue(p, item); + }); + dt.Rows.Add(row); + } + var dllPath =Path.Combine(AppDomain.CurrentDomain.BaseDirectory , "failFiles"); + DirectoryInfo dir = new DirectoryInfo(dllPath); + if (!dir.Exists) + { + dir.Create(); + } + var fileName =Path.Combine( dllPath , Guid.NewGuid().ToString() + ".csv"); + var dataTableToCsv = DataTableToCsvString(dt); + File.WriteAllText(fileName, dataTableToCsv, new UTF8Encoding(false)); + MySqlConnection conn = this.Context.Ado.Connection as MySqlConnection; + try + { + this.Context.Ado.Open(); + // IsolationLevel.Parse + MySqlBulkLoader bulk = new MySqlBulkLoader(conn) + { + CharacterSet = GetChara(), + FieldTerminator = ",", + FieldQuotationCharacter = '"', + EscapeCharacter = '"', + LineTerminator = Environment.NewLine, + FileName = fileName, + NumberOfLinesToSkip = 0, + TableName = dt.TableName, + Local = true, + }; + bulk.Columns.AddRange(dt.Columns.Cast().Select(colum => colum.ColumnName).Distinct().ToArray()); + IsBulkLoad = bulk.Load() > 0; + //执行成功才删除文件 + if (IsBulkLoad && File.Exists(fileName)) + { + File.Delete(fileName); + } + } + catch (MySqlException ex) + { + throw ex; + } + finally + { + CloseDb(); + } + return IsBulkLoad; ; + } + + public Task ExecuteBulkCopyAsync() + { + return Task.FromResult(ExecuteBulkCopy()); + } + + public Task ExecuteBulkCopyAsync(string characterSet) + { + this.Chara = characterSet; + return Task.FromResult(ExecuteBulkCopy()); + } + + #region Helper + private string GetChara() + { + if (this.Chara == null) + { + return "UTF8"; + } + else + { + return this.Chara; + } + } + + private void CloseDb() + { + if (this.Context.CurrentConnectionConfig.IsAutoCloseConnection && this.Context.Ado.Transaction == null) + { + this.Context.Ado.Connection.Close(); + } + } + + /// + ///DataTable to CSV + /// + /// datatable + /// CSV + public string DataTableToCsvString(DataTable table) + { + if (table.Rows.Count == 0) + return ""; + StringBuilder sb = new StringBuilder(); + DataColumn colum; + foreach (DataRow row in table.Rows) + { + for (int i = 0; i < table.Columns.Count; i++) + { + colum = table.Columns[i]; + if (i != 0) sb.Append(","); + if (colum.DataType == typeof(string) && (row[colum].ToString().Contains(",") || row[colum].ToString().Contains("\r") || row[colum].ToString().Contains("\""))) + { + sb.Append("\"" + row[colum].ToString().Replace("\"", "\"\"") + "\""); + } + else if (colum.DataType == typeof(bool)) + { + sb.Append(row[colum].ObjToBool() ? 1 : 0); + } + else if (colum.DataType == UtilConstants.DateType&& row[colum] != null && row[colum] != DBNull.Value) + { + sb.Append(row[colum].ObjToDate().ToString("yyyy-MM-dd HH:mm:ss.fff")); + } + else sb.Append(row[colum].ToString()); + } + sb.AppendLine(); + } + return sb.ToString(); + } + + + private static object GetValue(PropertyInfo p, T item) + { + var result= p.GetValue(item, null); + if (result != null && UtilMethods.GetUnderType(p.PropertyType) == UtilConstants.BoolType) + { + if (result.ObjToBool() == false) + { + result = null; + } + } + return result; + } + + #endregion + } +} \ No newline at end of file diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBuilder.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBuilder.cs new file mode 100644 index 000000000..a1fb2134a --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlBuilder.cs @@ -0,0 +1,26 @@ +using System; +using System.Linq; +using System.Text.RegularExpressions; + +namespace SqlSugar.MySqlConnector +{ + public class MySqlBuilder : SqlBuilderProvider + { + public override string SqlTranslationLeft { get { return "`"; } } + public override string SqlTranslationRight { get { return "`"; } } + public override string SqlDateNow + { + get + { + return "sysdate()"; + } + } + public override string FullSqlDateNow + { + get + { + return "select sysdate()"; + } + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlDeleteBuilder.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlDeleteBuilder.cs new file mode 100644 index 000000000..c82daf4d8 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlDeleteBuilder.cs @@ -0,0 +1,7 @@ +namespace SqlSugar.MySqlConnector +{ + public class MySqlDeleteBuilder : DeleteBuilder + { + + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlExpressionContext.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlExpressionContext.cs new file mode 100644 index 000000000..0ade08f20 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlExpressionContext.cs @@ -0,0 +1,154 @@ +using System; +using System.Linq; +namespace SqlSugar.MySqlConnector +{ + public class MySqlExpressionContext : ExpressionContext, ILambdaExpressions + { + public SqlSugarProvider Context { get; set; } + public MySqlExpressionContext() + { + base.DbMehtods = new MySqlMethod(); + } + public override string SqlTranslationLeft { get { return "`"; } } + public override string SqlTranslationRight { get { return "`"; } } + } + public class MySqlMethod : DefaultDbMethod, IDbMethods + { + public override string DateValue(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + if (parameter.MemberName != null && parameter.MemberName is DateTime) + { + return string.Format(" {0}('{1}') ", parameter2.MemberValue, parameter.MemberName); + } + else + { + return string.Format(" {0}({1}) ", parameter2.MemberValue, parameter.MemberName); + } + } + + public override string Contains(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + return string.Format(" ({0} like concat('%',{1},'%')) ", parameter.MemberName, parameter2.MemberName ); + } + + public override string StartsWith(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + return string.Format(" ({0} like concat({1},'%')) ", parameter.MemberName, parameter2.MemberName); + } + + public override string EndsWith(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + return string.Format(" ({0} like concat('%',{1}))", parameter.MemberName,parameter2.MemberName); + } + + public override string DateIsSameDay(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + return string.Format(" (TIMESTAMPDIFF(day,date({0}),date({1}))=0) ", parameter.MemberName, parameter2.MemberName); ; + } + + public override string DateIsSameByType(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + var parameter3 = model.Args[2]; + return string.Format(" (TIMESTAMPDIFF({2},{0},{1})=0) ", parameter.MemberName, parameter2.MemberName, parameter3.MemberValue); + } + + public override string DateAddByType(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + var parameter3 = model.Args[2]; + return string.Format(" (DATE_ADD({1} , INTERVAL {2} {0})) ", parameter3.MemberValue, parameter.MemberName, parameter2.MemberName); + } + + public override string DateAddDay(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter2 = model.Args[1]; + return string.Format(" (DATE_ADD({0}, INTERVAL {1} day)) ", parameter.MemberName, parameter2.MemberName); + } + + public override string ToInt32(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" CAST({0} AS SIGNED)", parameter.MemberName); + } + + public override string ToInt64(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" CAST({0} AS SIGNED)", parameter.MemberName); + } + + public override string ToString(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" CAST({0} AS CHAR)", parameter.MemberName); + } + + public override string ToGuid(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" CAST({0} AS CHAR)", parameter.MemberName); + } + + public override string ToDouble(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" CAST({0} AS DECIMAL(18,4))", parameter.MemberName); + } + + public override string ToBool(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" CAST({0} AS SIGNED)", parameter.MemberName); + } + + public override string ToDecimal(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" CAST({0} AS DECIMAL(18,4))", parameter.MemberName); + } + + public override string Length(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + return string.Format(" LENGTH({0})", parameter.MemberName); + } + public override string MergeString(params string[] strings) + { + return " concat("+string.Join(",", strings) + ") "; + } + public override string IsNull(MethodCallExpressionModel model) + { + var parameter = model.Args[0]; + var parameter1 = model.Args[1]; + return string.Format("IFNULL({0},{1})", parameter.MemberName, parameter1.MemberName); + } + public override string GetDate() + { + return "NOW()"; + } + + public override string GetRandom() + { + return "rand()"; + } + + public override string CharIndex(MethodCallExpressionModel model) + { + return string.Format("instr ({0},{1})", model.Args[0].MemberName, model.Args[1].MemberName); + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlFastBuilder.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlFastBuilder.cs new file mode 100644 index 000000000..44e52e316 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlFastBuilder.cs @@ -0,0 +1,74 @@ +using MySqlConnector; +using System; +using System.Collections.Generic; +using System.Data; +using System.Data.SqlClient; +using System.IO; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace SqlSugar.MySqlConnector +{ + + public class MySqlFastBuilder:FastBuilder,IFastBuilder + { + public override string UpdateSql { get; set; } = @"UPDATE {1} TM INNER JOIN {2} TE ON {3} SET {0} "; + public async Task ExecuteBulkCopyAsync(DataTable dt) + { + + var dllPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "failFiles"); + DirectoryInfo dir = new DirectoryInfo(dllPath); + if (!dir.Exists) + { + dir.Create(); + } + var fileName = Path.Combine(dllPath, Guid.NewGuid().ToString() + ".csv"); + var dataTableToCsv =new MySqlBlukCopy(this.Context.Context,null,null).DataTableToCsvString(dt); + File.WriteAllText(fileName, dataTableToCsv, new UTF8Encoding(false)); + MySqlConnection conn = this.Context.Ado.Connection as MySqlConnection; + int result = 0; + try + { + this.Context.Ado.Open(); + // IsolationLevel.Parse + MySqlBulkLoader bulk = new MySqlBulkLoader(conn) + { + CharacterSet = "UTF8", + FieldTerminator = ",", + FieldQuotationCharacter = '"', + EscapeCharacter = '"', + LineTerminator = Environment.NewLine, + FileName = fileName, + NumberOfLinesToSkip = 0, + TableName = dt.TableName, + Local = true, + }; + bulk.Columns.AddRange(dt.Columns.Cast().Select(colum =>new MySqlBuilder().GetTranslationColumnName(colum.ColumnName)).Distinct().ToArray()); + result= await bulk.LoadAsync(); + //执行成功才删除文件 + if (File.Exists(fileName)) + { + File.Delete(fileName); + } + } + catch (MySqlException ex) + { + throw ex; + } + finally + { + CloseDb(); + } + return result; + } + public override async Task CreateTempAsync(DataTable dt) + { + var queryable = this.Context.Queryable(); + var tableName = queryable.SqlBuilder.GetTranslationTableName(dt.TableName); + dt.TableName = "temp"+SnowFlakeSingle.instance.getID(); + var sql = queryable.AS(tableName).Where(it => false).ToSql().Key; + await this.Context.Ado.ExecuteCommandAsync($"Create TEMPORARY table {dt.TableName}({sql}) "); + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlInsertBuilder.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlInsertBuilder.cs new file mode 100644 index 000000000..482a21885 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlInsertBuilder.cs @@ -0,0 +1,136 @@ +using System; +using System.Linq; +using System.Text; + +namespace SqlSugar.MySqlConnector +{ + public class MySqlInsertBuilder : InsertBuilder + { + public override string SqlTemplate + { + get + { + if (IsReturnIdentity) + { + return @"INSERT INTO {0} + ({1}) + VALUES + ({2}) ;SELECT LAST_INSERT_ID();"; + } + else + { + return @"INSERT INTO {0} + ({1}) + VALUES + ({2}) ;"; + + } + } + } + public override object FormatValue(object value) + { + var n = "N"; + if (this.Context.CurrentConnectionConfig.MoreSettings != null && this.Context.CurrentConnectionConfig.MoreSettings.DisableNvarchar) + { + n = ""; + } + if (value == null) + { + return "NULL"; + } + else + { + var type = UtilMethods.GetUnderType(value.GetType()); + if (type == UtilConstants.DateType) + { + var date = value.ObjToDate(); + if (date < Convert.ToDateTime("1900-1-1")) + { + date = Convert.ToDateTime("1900-1-1"); + } + return "'" + date.ToString("yyyy-MM-dd HH:mm:ss.fff") + "'"; + } + else if (type == UtilConstants.ByteArrayType) + { + string bytesString = "0x" + BitConverter.ToString((byte[])value).Replace("-", ""); + return bytesString; + } + else if (type.IsEnum()) + { + if (this.Context.CurrentConnectionConfig.MoreSettings?.TableEnumIsString == true) + { + return value.ToSqlValue(); ; + } + else + { + return Convert.ToInt64(value); + } + } + else if (type == UtilConstants.BoolType) + { + return value.ObjToBool() ? "1" : "0"; + } + else if (type == UtilConstants.StringType || type == UtilConstants.ObjType) + { + return n+"'" + GetString(value).ToSqlFilter() + "'"; + } + else + { + return n+"'" + GetString(value) + "'"; + } + } + } + private string GetString(object value) + { + var result = value.ToString(); + if (result.HasValue() && result.Contains("\\")) + { + result = result.Replace("\\", "\\\\"); + } + return result; + } + + public override string ToSqlString() + { + if (IsNoInsertNull) + { + DbColumnInfoList = DbColumnInfoList.Where(it => it.Value != null).ToList(); + } + var groupList = DbColumnInfoList.GroupBy(it => it.TableId).ToList(); + var isSingle = groupList.Count() == 1; + string columnsString = string.Join(",", groupList.First().Select(it => Builder.GetTranslationColumnName(it.DbColumnName))); + if (isSingle) + { + string columnParametersString = string.Join(",", this.DbColumnInfoList.Select(it => Builder.SqlParameterKeyWord + it.DbColumnName)); + return string.Format(SqlTemplate, GetTableNameString, columnsString, columnParametersString); + } + else + { + StringBuilder batchInsetrSql = new StringBuilder(); + batchInsetrSql.Append("INSERT INTO " + GetTableNameString + " "); + batchInsetrSql.Append("("); + batchInsetrSql.Append(columnsString); + batchInsetrSql.Append(") VALUES"); + string insertColumns = ""; + foreach (var item in groupList) + { + batchInsetrSql.Append("("); + insertColumns = string.Join(",", item.Select(it => FormatValue(it.Value))); + batchInsetrSql.Append(insertColumns); + if (groupList.Last() == item) + { + batchInsetrSql.Append(") "); + } + else + { + batchInsetrSql.Append("), "); + } + } + + batchInsetrSql.AppendLine(";select @@IDENTITY"); + var result = batchInsetrSql.ToString(); + return result; + } + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlQueryBuilder.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlQueryBuilder.cs new file mode 100644 index 000000000..c8da0bb56 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlQueryBuilder.cs @@ -0,0 +1,138 @@ +using System.Linq; +using System.Text; +using System.Text.RegularExpressions; + +namespace SqlSugar.MySqlConnector +{ + public partial class MySqlQueryBuilder : QueryBuilder + { + #region Sql Template + public override string PageTempalte + { + get + { + /* + SELECT * FROM TABLE WHERE CONDITION ORDER BY ID DESC LIMIT 0,10 + */ + var template = "SELECT {0} FROM {1} {2} {3} {4} LIMIT {5},{6}"; + return template; + } + } + public override string DefaultOrderByTemplate + { + get + { + return "ORDER BY NOW() "; + } + } + + #endregion + + #region Common Methods + public override bool IsComplexModel(string sql) + { + return Regex.IsMatch(sql, @"AS \`\w+\.\w+\`")|| Regex.IsMatch(sql, @"AS \`\w+\.\w+\.\w+\`"); + } + public override string ToSqlString() + { + base.AppendFilter(); + string oldOrderValue = this.OrderByValue; + string result = null; + sql = new StringBuilder(); + sql.AppendFormat(SqlTemplate, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString); + if (IsCount) { return sql.ToString(); } + if (Skip != null && Take == null) + { + if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; + result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString, Skip.ObjToInt(), long.MaxValue); + } + else if (Skip == null && Take != null) + { + if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; + result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, 0, Take.ObjToInt()); + } + else if (Skip != null && Take != null) + { + if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; + result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, Skip.ObjToInt() > 0 ? Skip.ObjToInt() : 0, Take); + } + else + { + result = sql.ToString(); + } + this.OrderByValue = oldOrderValue; + result = GetSqlQuerySql(result); + return result; + } + private string ToCountSqlString() + { + //base.AppendFilter(); + string oldOrderValue = this.OrderByValue; + string result = null; + sql = new StringBuilder(); + sql.AppendFormat(SqlTemplate, "Count(*)", GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString); + if (IsCount) { return sql.ToString(); } + if (Skip != null && Take == null) + { + if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; + result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString, Skip.ObjToInt(), long.MaxValue); + } + else if (Skip == null && Take != null) + { + if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; + result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, 0, Take.ObjToInt()); + } + else if (Skip != null && Take != null) + { + if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0]; + result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, Skip.ObjToInt() > 0 ? Skip.ObjToInt() : 0, Take); + } + else + { + result = sql.ToString(); + } + this.OrderByValue = oldOrderValue; + return result; + } + public override string ToCountSql(string sql) + { + if (this.GroupByValue.HasValue()) + { + return base.ToCountSql(sql); + } + else + { + return ToCountSqlString(); + } + } + #endregion + + #region Get SQL Partial + public override string GetSelectValue + { + get + { + string result = string.Empty; + if (this.SelectValue == null || this.SelectValue is string) + { + result = GetSelectValueByString(); + } + else + { + result = GetSelectValueByExpression(); + } + if (this.SelectType == ResolveExpressType.SelectMultiple) + { + this.SelectCacheKey = this.SelectCacheKey + string.Join("-", this.JoinQueryInfos.Select(it => it.TableName)); + } + if (IsDistinct) + { + result = " DISTINCT " + result; + } + return result; + } + } + + #endregion + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlUpdateBuilder.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlUpdateBuilder.cs new file mode 100644 index 000000000..4c3054872 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/MySql/SqlBuilder/MySqlUpdateBuilder.cs @@ -0,0 +1,155 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.RegularExpressions; + +namespace SqlSugar.MySqlConnector +{ + public class MySqlUpdateBuilder : UpdateBuilder + { + public override string SqlTemplateBatch + { + get + { + return @"UPDATE {1} S {2} INNER JOIN ${{0}} SET {0} "; + } + } + public override string SqlTemplateJoin + { + get + { + return @" ( + {0} + + ) T ON {1} + "; + } + } + protected override string TomultipleSqlString(List> groupList) + { + Check.Exception(PrimaryKeys == null || PrimaryKeys.Count == 0, " Update List need Primary key"); + int pageSize = 200; + int pageIndex = 1; + int totalRecord = groupList.Count; + int pageCount = (totalRecord + pageSize - 1) / pageSize; + StringBuilder batchUpdateSql = new StringBuilder(); + while (pageCount >= pageIndex) + { + StringBuilder updateTable = new StringBuilder(); + string setValues = string.Join(",", groupList.First().Where(it => it.IsPrimarykey == false && (it.IsIdentity == false || (IsOffIdentity && it.IsIdentity))).Select(it => + { + if (SetValues.IsValuable()) + { + var setValue = SetValues.Where(sv => sv.Key == Builder.GetTranslationColumnName(it.DbColumnName)); + if (setValue != null && setValue.Any()) + { + return setValue.First().Value; + } + } + var result = string.Format("S.{0}=T.{0}", Builder.GetTranslationColumnName(it.DbColumnName)); + return result; + })); + batchUpdateSql.AppendFormat(SqlTemplateBatch.ToString(), setValues, GetTableNameStringNoWith, TableWithString); + int i = 0; + foreach (var columns in groupList.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList()) + { + var isFirst = i == 0; + if (!isFirst) + { + updateTable.Append(SqlTemplateBatchUnion); + } + updateTable.Append("\r\n SELECT " + string.Join(",", columns.Select(it => string.Format(SqlTemplateBatchSelect, FormatValue(it.Value),this.Builder.GetTranslationColumnName(it.DbColumnName))))); + ++i; + } + pageIndex++; + updateTable.Append("\r\n"); + string whereString = null; + if (this.WhereValues.HasValue()) + { + foreach (var item in WhereValues) + { + var isFirst = whereString == null; + whereString += (isFirst ? null : " AND "); + whereString += Regex.Replace(item, " \\" + this.Builder.SqlTranslationLeft, "S." + this.Builder.SqlTranslationLeft); + } + } + if (PrimaryKeys.HasValue()) + { + foreach (var item in PrimaryKeys) + { + var isFirst = whereString == null; + whereString += (isFirst ? null : " AND "); + whereString += string.Format("S.{0}=T.{0}", Builder.GetTranslationColumnName(item)); + } + } + var format= string.Format(SqlTemplateJoin, updateTable, whereString); + batchUpdateSql.Replace("${0}",format); + batchUpdateSql.Append(";"); + } + return batchUpdateSql.ToString(); + } + public override object FormatValue(object value) + { + var n = "N"; + if (this.Context.CurrentConnectionConfig.MoreSettings != null&&this.Context.CurrentConnectionConfig.MoreSettings.DisableNvarchar) + { + n = ""; + } + if (value == null) + { + return "NULL"; + } + else + { + var type = UtilMethods.GetUnderType(value.GetType()); + if (type == UtilConstants.DateType) + { + var date = value.ObjToDate(); + if (date < Convert.ToDateTime("1900-1-1")) + { + date = Convert.ToDateTime("1900-1-1"); + } + return "'" + date.ToString("yyyy-MM-dd HH:mm:ss.fff") + "'"; + } + else if (type == UtilConstants.ByteArrayType) + { + string bytesString = "0x" + BitConverter.ToString((byte[])value).Replace("-", ""); + return bytesString; + } + else if (type.IsEnum()) + { + if (this.Context.CurrentConnectionConfig.MoreSettings?.TableEnumIsString == true) + { + return value.ToSqlValue(); + } + else + { + return Convert.ToInt64(value); + } + } + else if (type == UtilConstants.BoolType) + { + return value.ObjToBool() ? "1" : "0"; + } + else if (type == UtilConstants.StringType || type == UtilConstants.ObjType) + { + return n+"'" + GetString(value).ToSqlFilter() + "'"; + } + else + { + return n+"'" + GetString(value) + "'"; + } + } + } + private string GetString(object value) + { + var result = value.ToString(); + if (result.HasValue() && result.Contains("\\")) + { + result = result.Replace("\\", "\\\\"); + } + return result; + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/Properties/AssemblyInfo.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/Properties/AssemblyInfo.cs new file mode 100644 index 000000000..21c65787a --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// 有关程序集的一般信息由以下 +// 控制。更改这些特性值可修改 +// 与程序集关联的信息。 +[assembly: AssemblyTitle("SqlSugar.MySqlConnector")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("SqlSugar.MySqlConnector")] +[assembly: AssemblyCopyright("Copyright © 2022")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// 将 ComVisible 设置为 false 会使此程序集中的类型 +//对 COM 组件不可见。如果需要从 COM 访问此程序集中的类型 +//请将此类型的 ComVisible 特性设置为 true。 +[assembly: ComVisible(false)] + +// 如果此项目向 COM 公开,则下列 GUID 用于类型库的 ID +[assembly: Guid("d131ee06-bad4-4b80-b7de-d6f539087644")] + +// 程序集的版本信息由下列四个值组成: +// +// 主版本 +// 次版本 +// 生成号 +// 修订号 +// +//可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值 +//通过使用 "*",如下所示: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/SqlSugar.MySqlConnector.csproj b/Src/Asp.Net/SqlSugar.MySqlConnector/SqlSugar.MySqlConnector.csproj new file mode 100644 index 000000000..ca47f822d --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/SqlSugar.MySqlConnector.csproj @@ -0,0 +1,93 @@ + + + + + Debug + AnyCPU + {D131EE06-BAD4-4B80-B7DE-D6F539087644} + Library + Properties + SqlSugar.MySqlConnector + SqlSugar.MySqlConnector + v4.6 + 512 + true + + + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + ..\packages\MySqlConnector.1.2.0\lib\net45\MySqlConnector.dll + + + + ..\packages\System.Buffers.4.4.0\lib\netstandard1.1\System.Buffers.dll + + + + ..\packages\System.Memory.4.5.0\lib\netstandard1.1\System.Memory.dll + + + ..\packages\System.Runtime.CompilerServices.Unsafe.4.5.0\lib\netstandard1.0\System.Runtime.CompilerServices.Unsafe.dll + + + ..\packages\System.Threading.Tasks.Extensions.4.3.0\lib\portable-net45+win8+wp8+wpa81\System.Threading.Tasks.Extensions.dll + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + {489bb790-226c-4fad-8d1e-51d72a7ff8e5} + SqlSugar + + + + + \ No newline at end of file diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ErrorMessage.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ErrorMessage.cs new file mode 100644 index 000000000..fad294a3f --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ErrorMessage.cs @@ -0,0 +1,64 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +namespace SqlSugar.MySqlConnector +{ + internal static partial class ErrorMessage + { + internal static LanguageType SugarLanguageType { get; set; } = LanguageType.Default; + internal static string ObjNotExist + { + get + { + return GetThrowMessage("{0} does not exist.", + "{0}不存在。"); + } + } + internal static string EntityMappingError + { + get + { + return GetThrowMessage("Entity mapping error.{0}", + "实体与表映射出错。{0}"); + } + } + + public static string NotSupportedDictionary + { + get + { + return GetThrowMessage("This type of Dictionary is not supported for the time being. You can try Dictionary, or contact the author!!", + "暂时不支持该类型的Dictionary 你可以试试 Dictionary或者联系作者!!"); + } + } + + public static string NotSupportedArray + { + get + { + return GetThrowMessage("This type of Array is not supported for the time being. You can try object[] or contact the author!!", + "暂时不支持该类型的Array 你可以试试 object[] 或者联系作者!!"); + } + } + + internal static string GetThrowMessage(string enMessage, string cnMessage, params string[] args) + { + if (SugarLanguageType == LanguageType.Default) + { + List formatArgs = new List() { enMessage, cnMessage }; + formatArgs.AddRange(args); + return string.Format(@"中文提示 : {1} +English Message : {0}", formatArgs.ToArray()); + } + else if (SugarLanguageType == LanguageType.English) + { + return enMessage; + } + else + { + return cnMessage; + } + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/FileHelper.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/FileHelper.cs new file mode 100644 index 000000000..40aa0a74a --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/FileHelper.cs @@ -0,0 +1,70 @@ +using System; +using System.Collections.Generic; +using System.IO; +using System.Linq; +using System.Text; + +namespace SqlSugar.MySqlConnector +{ + internal class FileHelper + { + public static void CreateFile(string filePath, string text, Encoding encoding) + { + try + { + if (IsExistFile(filePath)) + { + DeleteFile(filePath); + } + if (!IsExistFile(filePath)) + { + string directoryPath = GetDirectoryFromFilePath(filePath); + CreateDirectory(directoryPath); + + //Create File + FileInfo file = new FileInfo(filePath); + using (FileStream stream = file.Create()) + { + using (StreamWriter writer = new StreamWriter(stream, encoding)) + { + writer.Write(text); + writer.Flush(); + } + } + } + } + catch(Exception ex) + { + throw ex; + } + } + public static bool IsExistDirectory(string directoryPath) + { + return Directory.Exists(directoryPath); + } + public static void CreateDirectory(string directoryPath) + { + if (!IsExistDirectory(directoryPath)) + { + Directory.CreateDirectory(directoryPath); + } + } + public static void DeleteFile(string filePath) + { + if (IsExistFile(filePath)) + { + File.Delete(filePath); + } + } + public static string GetDirectoryFromFilePath(string filePath) + { + FileInfo file = new FileInfo(filePath); + DirectoryInfo directory = file.Directory; + return directory.FullName; + } + public static bool IsExistFile(string filePath) + { + return File.Exists(filePath); + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilConstants.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilConstants.cs new file mode 100644 index 000000000..f24373722 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilConstants.cs @@ -0,0 +1,73 @@ +using System; +using System.Collections.Generic; +using System.Dynamic; +using System.Linq; +using System.Text; +namespace SqlSugar.MySqlConnector +{ + internal static class UtilConstants + { + public const string Dot = "."; + public const char DotChar = '.'; + internal const string Space = " "; + internal const char SpaceChar =' '; + internal const string AssemblyName = "SqlSugar"; + internal const string ReplaceKey = "{662E689B-17A1-4D06-9D27-F29EAB8BC3D6}"; + internal const string ReplaceCommaKey = "{112A689B-17A1-4A06-9D27-A39EAB8BC3D5}"; + + internal static Type IntType = typeof(int); + internal static Type LongType = typeof(long); + internal static Type GuidType = typeof(Guid); + internal static Type BoolType = typeof(bool); + internal static Type BoolTypeNull = typeof(bool?); + internal static Type ByteType = typeof(Byte); + internal static Type ObjType = typeof(object); + internal static Type DobType = typeof(double); + internal static Type FloatType = typeof(float); + internal static Type ShortType = typeof(short); + internal static Type DecType = typeof(decimal); + internal static Type StringType = typeof(string); + internal static Type DateType = typeof(DateTime); + internal static Type DateTimeOffsetType = typeof(DateTimeOffset); + internal static Type TimeSpanType = typeof(TimeSpan); + internal static Type ByteArrayType = typeof(byte[]); + internal static Type ModelType= typeof(ModelContext); + internal static Type DynamicType = typeof(ExpandoObject); + internal static Type Dicii = typeof(KeyValuePair); + internal static Type DicIS = typeof(KeyValuePair); + internal static Type DicSi = typeof(KeyValuePair); + internal static Type DicSS = typeof(KeyValuePair); + internal static Type DicOO = typeof(KeyValuePair); + internal static Type DicSo = typeof(KeyValuePair); + internal static Type DicArraySS = typeof(Dictionary); + internal static Type DicArraySO = typeof(Dictionary); + + public static Type SugarType = typeof(SqlSugarProvider); + + + internal static Type[] NumericalTypes = new Type[] + { + typeof(int), + typeof(uint), + typeof(byte), + typeof(sbyte), + typeof(long), + typeof(ulong), + typeof(short), + typeof(ushort), + }; + + + internal static string[] DateTypeStringList = new string[] + { + "Year", + "Month", + "Day", + "Hour", + "Second" , + "Minute", + "Millisecond", + "Date" + }; + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilExtensions.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilExtensions.cs new file mode 100644 index 000000000..645eccc9c --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilExtensions.cs @@ -0,0 +1,123 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +namespace SqlSugar.MySqlConnector +{ + /// + ///Common Extensions for external users + /// + public static class UtilExtensions + { + public static int ObjToInt(this object thisValue) + { + int reval = 0; + if (thisValue == null) return 0; + if (thisValue is Enum) + { + return (int)thisValue; + } + if (thisValue != null && thisValue != DBNull.Value && int.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return reval; + } + + public static int ObjToInt(this object thisValue, int errorValue) + { + int reval = 0; + if (thisValue is Enum) + { + return (int)thisValue; + } + if (thisValue != null && thisValue != DBNull.Value && int.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return errorValue; + } + + public static double ObjToMoney(this object thisValue) + { + double reval = 0; + if (thisValue != null && thisValue != DBNull.Value && double.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return 0; + } + + public static double ObjToMoney(this object thisValue, double errorValue) + { + double reval = 0; + if (thisValue != null && thisValue != DBNull.Value && double.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return errorValue; + } + + public static string ObjToString(this object thisValue) + { + if (thisValue != null) return thisValue.ToString().Trim(); + return ""; + } + + public static string ObjToString(this object thisValue, string errorValue) + { + if (thisValue != null) return thisValue.ToString().Trim(); + return errorValue; + } + + public static Decimal ObjToDecimal(this object thisValue) + { + Decimal reval = 0; + if (thisValue != null && thisValue != DBNull.Value && decimal.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return 0; + } + + public static Decimal ObjToDecimal(this object thisValue, decimal errorValue) + { + Decimal reval = 0; + if (thisValue != null && thisValue != DBNull.Value && decimal.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return errorValue; + } + + public static DateTime ObjToDate(this object thisValue) + { + DateTime reval = DateTime.MinValue; + if (thisValue != null && thisValue != DBNull.Value && DateTime.TryParse(thisValue.ToString(), out reval)) + { + reval = Convert.ToDateTime(thisValue); + } + return reval; + } + + public static DateTime ObjToDate(this object thisValue, DateTime errorValue) + { + DateTime reval = DateTime.MinValue; + if (thisValue != null && thisValue != DBNull.Value && DateTime.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return errorValue; + } + + public static bool ObjToBool(this object thisValue) + { + bool reval = false; + if (thisValue != null && thisValue != DBNull.Value && bool.TryParse(thisValue.ToString(), out reval)) + { + return reval; + } + return reval; + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilMethods.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilMethods.cs new file mode 100644 index 000000000..1ed5547d9 --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/UtilMethods.cs @@ -0,0 +1,493 @@ +using System; +using System.Collections.Generic; +using System.ComponentModel; +using System.Data; +using System.Diagnostics; +using System.Globalization; +using System.Linq; +using System.Linq.Expressions; +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Security.Cryptography; +using System.Text; +using System.Text.RegularExpressions; + +namespace SqlSugar.MySqlConnector +{ + public class UtilMethods + { + + internal static DateTime ConvertFromDateTimeOffset(DateTimeOffset dateTime) + { + if (dateTime.Offset.Equals(TimeSpan.Zero)) + return dateTime.UtcDateTime; + else if (dateTime.Offset.Equals(TimeZoneInfo.Local.GetUtcOffset(dateTime.DateTime))) + return DateTime.SpecifyKind(dateTime.DateTime, DateTimeKind.Local); + else + return dateTime.DateTime; + } + + internal static object To(object value, Type destinationType) + { + return To(value, destinationType, CultureInfo.InvariantCulture); + } + + internal static object To(object value, Type destinationType, CultureInfo culture) + { + if (value != null) + { + destinationType = UtilMethods.GetUnderType(destinationType); + var sourceType = value.GetType(); + + var destinationConverter = TypeDescriptor.GetConverter(destinationType); + if (destinationConverter != null && destinationConverter.CanConvertFrom(value.GetType())) + return destinationConverter.ConvertFrom(null, culture, value); + + var sourceConverter = TypeDescriptor.GetConverter(sourceType); + if (sourceConverter != null && sourceConverter.CanConvertTo(destinationType)) + return sourceConverter.ConvertTo(null, culture, value, destinationType); + + if (destinationType.IsEnum && value is int) + return Enum.ToObject(destinationType, (int)value); + + if (!destinationType.IsInstanceOfType(value)) + return Convert.ChangeType(value, destinationType, culture); + } + return value; + } + public static bool IsAnyAsyncMethod(StackFrame[] methods) + { + bool isAsync = false; + foreach (var item in methods) + { + if (UtilMethods.IsAsyncMethod(item.GetMethod())) + { + isAsync = true; + break; + } + } + return isAsync; + } + + public static bool IsAsyncMethod(MethodBase method) + { + if (method == null) + { + return false; + } + if (method.DeclaringType != null) + { + if (method.DeclaringType.GetInterfaces().Contains(typeof(IAsyncStateMachine))) + { + return true; + } + } + var name = method.Name; + if (name.Contains("OutputAsyncCausalityEvents")) + { + return true; + } + if (name.Contains("OutputWaitEtwEvents")) + { + return true; + } + if (name.Contains("ExecuteAsync")) + { + return true; + } + Type attType = typeof(AsyncStateMachineAttribute); + var attrib = (AsyncStateMachineAttribute)method.GetCustomAttribute(attType); + return (attrib != null); + } + + public static StackTraceInfo GetStackTrace() + { + + StackTrace st = new StackTrace(true); + StackTraceInfo info = new StackTraceInfo(); + info.MyStackTraceList = new List(); + info.SugarStackTraceList = new List(); + for (int i = 0; i < st.FrameCount; i++) + { + var frame = st.GetFrame(i); + if (frame.GetMethod().Module.Name.ToLower() != "sqlsugar.dll" && frame.GetMethod().Name.First() != '<') + { + info.MyStackTraceList.Add(new StackTraceInfoItem() + { + FileName = frame.GetFileName(), + MethodName = frame.GetMethod().Name, + Line = frame.GetFileLineNumber() + }); + } + else + { + info.SugarStackTraceList.Add(new StackTraceInfoItem() + { + FileName = frame.GetFileName(), + MethodName = frame.GetMethod().Name, + Line = frame.GetFileLineNumber() + }); + } + } + return info; + } + + internal static T To(object value) + { + return (T)To(value, typeof(T)); + } + internal static Type GetUnderType(Type oldType) + { + Type type = Nullable.GetUnderlyingType(oldType); + return type == null ? oldType : type; + } + public static string ReplaceSqlParameter(string itemSql, SugarParameter itemParameter, string newName) + { + itemSql = Regex.Replace(itemSql, string.Format(@"{0} ", "\\" + itemParameter.ParameterName), newName + " ", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"{0}\)", "\\" + itemParameter.ParameterName), newName + ")", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"{0}\,", "\\" + itemParameter.ParameterName), newName + ",", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"{0}$", "\\" + itemParameter.ParameterName), newName, RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"\+{0}\+", "\\" + itemParameter.ParameterName), "+" + newName + "+", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"\+{0} ", "\\" + itemParameter.ParameterName), "+" + newName + " ", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@" {0}\+", "\\" + itemParameter.ParameterName), " " + newName + "+", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"\|\|{0}\|\|", "\\" + itemParameter.ParameterName), "||" + newName + "||", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"\={0}\+", "\\" + itemParameter.ParameterName), "=" + newName + "+", RegexOptions.IgnoreCase); + itemSql = Regex.Replace(itemSql, string.Format(@"{0}\|\|", "\\" + itemParameter.ParameterName), newName + "||", RegexOptions.IgnoreCase); + return itemSql; + } + internal static Type GetRootBaseType(Type entityType) + { + var baseType = entityType.BaseType; + while (baseType != null && baseType.BaseType != UtilConstants.ObjType) + { + baseType = baseType.BaseType; + } + return baseType; + } + + + internal static Type GetUnderType(PropertyInfo propertyInfo, ref bool isNullable) + { + Type unType = Nullable.GetUnderlyingType(propertyInfo.PropertyType); + isNullable = unType != null; + unType = unType ?? propertyInfo.PropertyType; + return unType; + } + + internal static Type GetUnderType(PropertyInfo propertyInfo) + { + Type unType = Nullable.GetUnderlyingType(propertyInfo.PropertyType); + unType = unType ?? propertyInfo.PropertyType; + return unType; + } + + internal static bool IsNullable(PropertyInfo propertyInfo) + { + Type unType = Nullable.GetUnderlyingType(propertyInfo.PropertyType); + return unType != null; + } + + internal static bool IsNullable(Type type) + { + Type unType = Nullable.GetUnderlyingType(type); + return unType != null; + } + //internal static T IsNullReturnNew(T returnObj) where T : new() + //{ + // if (returnObj.IsNullOrEmpty()) + // { + // returnObj = new T(); + // } + // return returnObj; + //} + public static object ChangeType2(object value, Type type) + { + if (value == null && type.IsGenericType) return Activator.CreateInstance(type); + if (value == null) return null; + if (type == value.GetType()) return value; + if (type.IsEnum) + { + if (value is string) + return Enum.Parse(type, value as string); + else + return Enum.ToObject(type, value); + } + if (!type.IsInterface && type.IsGenericType) + { + Type innerType = type.GetGenericArguments()[0]; + object innerValue = ChangeType(value, innerType); + return Activator.CreateInstance(type, new object[] { innerValue }); + } + if (value is string && type == typeof(Guid)) return new Guid(value as string); + if (value is string && type == typeof(Version)) return new Version(value as string); + if (!(value is IConvertible)) return value; + return Convert.ChangeType(value, type); + } + + internal static T ChangeType(T obj, Type type) + { + return (T)Convert.ChangeType(obj, type); + } + + internal static T ChangeType(T obj) + { + return (T)Convert.ChangeType(obj, typeof(T)); + } + + internal static DateTimeOffset GetDateTimeOffsetByDateTime(DateTime date) + { + date = DateTime.SpecifyKind(date, DateTimeKind.Utc); + DateTimeOffset utcTime2 = date; + return utcTime2; + } + + //internal static void RepairReplicationParameters(ref string appendSql, SugarParameter[] parameters, int addIndex, string append = null) + //{ + // if (appendSql.HasValue() && parameters.HasValue()) + // { + // foreach (var parameter in parameters.OrderByDescending(it => it.ParameterName.Length)) + // { + // //Compatible with.NET CORE parameters case + // var name = parameter.ParameterName; + // string newName = name + append + addIndex; + // appendSql = ReplaceSqlParameter(appendSql, parameter, newName); + // parameter.ParameterName = newName; + // } + // } + //} + + internal static string GetPackTable(string sql, string shortName) + { + return string.Format(" ({0}) {1} ", sql, shortName); + } + + public static Func GetTypeConvert(object value) + { + if (value is int || value is uint || value is int? || value is uint?) + { + return x => Convert.ToInt32(x); + } + else if (value is short || value is ushort || value is short? || value is ushort?) + { + return x => Convert.ToInt16(x); + } + else if (value is long || value is long? || value is ulong? || value is long?) + { + return x => Convert.ToInt64(x); + } + else if (value is DateTime|| value is DateTime?) + { + return x => Convert.ToDateTime(x); + } + else if (value is bool||value is bool?) + { + return x => Convert.ToBoolean(x); + } + return null; + } + + internal static string GetTypeName(object value) + { + if (value == null) + { + return null; + } + else + { + return value.GetType().Name; + } + } + + internal static string GetParenthesesValue(string dbTypeName) + { + if (Regex.IsMatch(dbTypeName, @"\(.+\)")) + { + dbTypeName = Regex.Replace(dbTypeName, @"\(.+\)", ""); + } + dbTypeName = dbTypeName.Trim(); + return dbTypeName; + } + + internal static T GetOldValue(T value, Action action) + { + action(); + return value; + } + + internal static object DefaultForType(Type targetType) + { + return targetType.IsValueType ? Activator.CreateInstance(targetType) : null; + } + + internal static Int64 GetLong(byte[] bytes) + { + return Convert.ToInt64(string.Join("", bytes).PadRight(20, '0')); + } + public static object GetPropertyValue(T t, string PropertyName) + { + return t.GetType().GetProperty(PropertyName).GetValue(t, null); + } + internal static string GetMD5(string myString) + { + MD5 md5 = new MD5CryptoServiceProvider(); + byte[] fromData = System.Text.Encoding.Unicode.GetBytes(myString); + byte[] targetData = md5.ComputeHash(fromData); + string byte2String = null; + + for (int i = 0; i < targetData.Length; i++) + { + byte2String += targetData[i].ToString("x"); + } + + return byte2String; + } + + //public static string EncodeBase64(string code) + //{ + // if (code.IsNullOrEmpty()) return code; + // string encode = ""; + // byte[] bytes = Encoding.GetEncoding("utf-8").GetBytes(code); + // try + // { + // encode = Convert.ToBase64String(bytes); + // } + // catch + // { + // encode = code; + // } + // return encode; + //} + public static string ConvertNumbersToString(string value) + { + string[] splitInt = value.Split(new char[] { '9' }, StringSplitOptions.RemoveEmptyEntries); + + var splitChars = splitInt.Select(s => Convert.ToChar( + Convert.ToInt32(s, 8) + ).ToString()); + + return string.Join("", splitChars); + } + public static string ConvertStringToNumbers(string value) + { + StringBuilder sb = new StringBuilder(); + + foreach (char c in value) + { + int cAscil = (int)c; + sb.Append(Convert.ToString(c, 8) + "9"); + } + + return sb.ToString(); + } + + //public static string DecodeBase64(string code) + //{ + // try + // { + // if (code.IsNullOrEmpty()) return code; + // string decode = ""; + // byte[] bytes = Convert.FromBase64String(code); + // try + // { + // decode = Encoding.GetEncoding("utf-8").GetString(bytes); + // } + // catch + // { + // decode = code; + // } + // return decode; + // } + // catch + // { + // return code; + // } + //} + + public static void DataInoveByExpresson(Type[] datas, MethodCallExpression callExpresion) + { + var methodInfo = callExpresion.Method; + foreach (var item in datas) + { + if (callExpresion.Arguments.Count == 0) + { + methodInfo.Invoke(item, null); + } + else + { + List methodParameters = new List(); + foreach (var callItem in callExpresion.Arguments) + { + var parameter = callItem.GetType().GetProperties().FirstOrDefault(it => it.Name == "Value"); + if (parameter == null) + { + var value = LambdaExpression.Lambda(callItem).Compile().DynamicInvoke(); + methodParameters.Add(value); + } + else + { + var value = parameter.GetValue(callItem, null); + methodParameters.Add(value); + } + } + methodInfo.Invoke(item, methodParameters.ToArray()); + } + } + } + + public static Dictionary EnumToDictionary() + { + Dictionary dic = new Dictionary(); + if (!typeof(T).IsEnum) + { + return dic; + } + string desc = string.Empty; + foreach (var item in Enum.GetValues(typeof(T))) + { + var key = item.ToString().ToLower(); + if (!dic.ContainsKey(key)) + dic.Add(key, (T)item); + } + return dic; + } + //public static object ConvertDataByTypeName(string ctypename,string value) + //{ + // var item = new ConditionalModel() { + // CSharpTypeName = ctypename, + // FieldValue = value + // }; + // if (item.CSharpTypeName.EqualCase(UtilConstants.DecType.Name)) + // { + // return Convert.ToDecimal(item.FieldValue); + // } + // else if (item.CSharpTypeName.EqualCase(UtilConstants.DobType.Name)) + // { + // return Convert.ToDouble(item.FieldValue); + // } + // else if (item.CSharpTypeName.EqualCase(UtilConstants.DateType.Name)) + // { + // return Convert.ToDateTime(item.FieldValue); + // } + // else if (item.CSharpTypeName.EqualCase(UtilConstants.IntType.Name)) + // { + // return Convert.ToInt32(item.FieldValue); + // } + // else if (item.CSharpTypeName.EqualCase(UtilConstants.LongType.Name)) + // { + // return Convert.ToInt64(item.FieldValue); + // } + // else if (item.CSharpTypeName.EqualCase(UtilConstants.ShortType.Name)) + // { + // return Convert.ToInt16(item.FieldValue); + // } + // else if (item.CSharpTypeName.EqualCase(UtilConstants.DateTimeOffsetType.Name)) + // { + // return UtilMethods.GetDateTimeOffsetByDateTime(Convert.ToDateTime(item.FieldValue)); + // } + // else + // { + // return item.FieldValue; + // } + //} + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ValidateExtensions.cs b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ValidateExtensions.cs new file mode 100644 index 000000000..77bf8c0ca --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/Tools/ValidateExtensions.cs @@ -0,0 +1,172 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Text.RegularExpressions; +namespace SqlSugar.MySqlConnector +{ + internal static class ValidateExtensions + { + public static bool IsInRange(this int thisValue, int begin, int end) + { + return thisValue >= begin && thisValue <= end; + } + + public static bool IsInRange(this DateTime thisValue, DateTime begin, DateTime end) + { + return thisValue >= begin && thisValue <= end; + } + + public static bool IsIn(this T thisValue, params T[] values) + { + return values.Contains(thisValue); + } + + public static bool IsContainsIn(this string thisValue, params string[] inValues) + { + return inValues.Any(it => thisValue.Contains(it)); + } + + public static bool IsNullOrEmpty(this object thisValue) + { + if (thisValue == null || thisValue == DBNull.Value) return true; + return thisValue.ToString() == ""; + } + + public static bool IsNullOrEmpty(this Guid? thisValue) + { + if (thisValue == null) return true; + return thisValue == Guid.Empty; + } + + public static bool IsNullOrEmpty(this Guid thisValue) + { + if (thisValue == null) return true; + return thisValue == Guid.Empty; + } + + public static bool IsNullOrEmpty(this IEnumerable thisValue) + { + if (thisValue == null || thisValue.Count() == 0) return true; + return false; + } + + public static bool HasValue(this object thisValue) + { + if (thisValue == null || thisValue == DBNull.Value) return false; + return thisValue.ToString() != ""; + } + + public static bool HasValue(this IEnumerable thisValue) + { + if (thisValue == null || thisValue.Count() == 0) return false; + return true; + } + + public static bool IsValuable(this IEnumerable> thisValue) + { + if (thisValue == null || thisValue.Count() == 0) return false; + return true; + } + + public static bool IsZero(this object thisValue) + { + return (thisValue == null || thisValue.ToString() == "0"); + } + + public static bool IsInt(this object thisValue) + { + if (thisValue == null) return false; + return Regex.IsMatch(thisValue.ToString(), @"^\d+$"); + } + + /// + public static bool IsNoInt(this object thisValue) + { + if (thisValue == null) return true; + return !Regex.IsMatch(thisValue.ToString(), @"^\d+$"); + } + + public static bool IsMoney(this object thisValue) + { + if (thisValue == null) return false; + double outValue = 0; + return double.TryParse(thisValue.ToString(), out outValue); + } + public static bool IsGuid(this object thisValue) + { + if (thisValue == null) return false; + Guid outValue = Guid.Empty; + return Guid.TryParse(thisValue.ToString(), out outValue); + } + + public static bool IsDate(this object thisValue) + { + if (thisValue == null) return false; + DateTime outValue = DateTime.MinValue; + return DateTime.TryParse(thisValue.ToString(), out outValue); + } + + public static bool IsEamil(this object thisValue) + { + if (thisValue == null) return false; + return Regex.IsMatch(thisValue.ToString(), @"^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"); + } + + public static bool IsMobile(this object thisValue) + { + if (thisValue == null) return false; + return Regex.IsMatch(thisValue.ToString(), @"^\d{11}$"); + } + + public static bool IsTelephone(this object thisValue) + { + if (thisValue == null) return false; + return System.Text.RegularExpressions.Regex.IsMatch(thisValue.ToString(), @"^(\(\d{3,4}\)|\d{3,4}-|\s)?\d{8}$"); + + } + + public static bool IsIDcard(this object thisValue) + { + if (thisValue == null) return false; + return System.Text.RegularExpressions.Regex.IsMatch(thisValue.ToString(), @"^(\d{15}$|^\d{18}$|^\d{17}(\d|X|x))$"); + } + + public static bool IsFax(this object thisValue) + { + if (thisValue == null) return false; + return System.Text.RegularExpressions.Regex.IsMatch(thisValue.ToString(), @"^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$"); + } + + public static bool IsMatch(this object thisValue, string pattern) + { + if (thisValue == null) return false; + Regex reg = new Regex(pattern); + return reg.IsMatch(thisValue.ToString()); + } + public static bool IsAnonymousType(this Type type) + { + string typeName = type.Name; + return typeName.Contains("<>") && typeName.Contains("__") && typeName.Contains("AnonymousType"); + } + public static bool IsCollectionsList(this string thisValue) + { + return (thisValue + "").StartsWith("System.Collections.Generic.List")|| (thisValue + "").StartsWith("System.Collections.Generic.IEnumerable"); + } + public static bool IsStringArray(this string thisValue) + { + return (thisValue + "").IsMatch(@"System\.[a-z,A-Z,0-9]+?\[\]"); + } + public static bool IsEnumerable(this string thisValue) + { + return (thisValue + "").StartsWith("System.Linq.Enumerable"); + } + + public static Type StringType = typeof (string); + + public static bool IsClass(this Type thisValue) + { + return thisValue != StringType && thisValue.IsEntity()&&thisValue!=UtilConstants.ByteArrayType; + } + } +} diff --git a/Src/Asp.Net/SqlSugar.MySqlConnector/packages.config b/Src/Asp.Net/SqlSugar.MySqlConnector/packages.config new file mode 100644 index 000000000..63969e29a --- /dev/null +++ b/Src/Asp.Net/SqlSugar.MySqlConnector/packages.config @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/Src/Asp.Net/SqlSugar.sln b/Src/Asp.Net/SqlSugar.sln index 7e18c93bf..a5a45a090 100644 --- a/Src/Asp.Net/SqlSugar.sln +++ b/Src/Asp.Net/SqlSugar.sln @@ -1,7 +1,7 @@  Microsoft Visual Studio Solution File, Format Version 12.00 -# Visual Studio 15 -VisualStudioVersion = 15.0.26730.10 +# Visual Studio Version 16 +VisualStudioVersion = 16.0.31624.102 MinimumVisualStudioVersion = 10.0.40219.1 Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SqlSugar", "SqlSugar\SqlSugar.csproj", "{489BB790-226C-4FAD-8D1E-51D72A7FF8E5}" EndProject @@ -29,6 +29,12 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PgSqlTest", "PgSqlTest\PgSq EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "DmTest", "DmTest\DmTest.csproj", "{68A45CBA-AD64-429C-9AF4-FE78658B73D5}" EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SqlSugar.Access", "SqlSugar.Access\SqlSugar.Access.csproj", "{0A27F276-D442-4E0A-B810-32D6074F0155}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SqlSugar.MySqlConnector", "SqlSugar.MySqlConnector\SqlSugar.MySqlConnector.csproj", "{D131EE06-BAD4-4B80-B7DE-D6F539087644}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MySqlConnectorTest", "MySqlConnectorTest\MySqlConnectorTest.csproj", "{7F705C44-F878-4706-AB9B-8D35030A8222}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Any CPU = Debug|Any CPU @@ -83,6 +89,18 @@ Global {68A45CBA-AD64-429C-9AF4-FE78658B73D5}.Debug|Any CPU.Build.0 = Debug|Any CPU {68A45CBA-AD64-429C-9AF4-FE78658B73D5}.Release|Any CPU.ActiveCfg = Release|Any CPU {68A45CBA-AD64-429C-9AF4-FE78658B73D5}.Release|Any CPU.Build.0 = Release|Any CPU + {0A27F276-D442-4E0A-B810-32D6074F0155}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {0A27F276-D442-4E0A-B810-32D6074F0155}.Debug|Any CPU.Build.0 = Debug|Any CPU + {0A27F276-D442-4E0A-B810-32D6074F0155}.Release|Any CPU.ActiveCfg = Release|Any CPU + {0A27F276-D442-4E0A-B810-32D6074F0155}.Release|Any CPU.Build.0 = Release|Any CPU + {D131EE06-BAD4-4B80-B7DE-D6F539087644}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {D131EE06-BAD4-4B80-B7DE-D6F539087644}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D131EE06-BAD4-4B80-B7DE-D6F539087644}.Release|Any CPU.ActiveCfg = Release|Any CPU + {D131EE06-BAD4-4B80-B7DE-D6F539087644}.Release|Any CPU.Build.0 = Release|Any CPU + {7F705C44-F878-4706-AB9B-8D35030A8222}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {7F705C44-F878-4706-AB9B-8D35030A8222}.Debug|Any CPU.Build.0 = Debug|Any CPU + {7F705C44-F878-4706-AB9B-8D35030A8222}.Release|Any CPU.ActiveCfg = Release|Any CPU + {7F705C44-F878-4706-AB9B-8D35030A8222}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/Src/Asp.Net/SqlSugar/Abstract/SugarProvider/SqlSugarAccessory.cs b/Src/Asp.Net/SqlSugar/Abstract/SugarProvider/SqlSugarAccessory.cs index 9fec865af..f96cd04f7 100644 --- a/Src/Asp.Net/SqlSugar/Abstract/SugarProvider/SqlSugarAccessory.cs +++ b/Src/Asp.Net/SqlSugar/Abstract/SugarProvider/SqlSugarAccessory.cs @@ -382,8 +382,13 @@ namespace SqlSugar DependencyManagement.TryOscar(); break; case DbType.MySqlConnector: + InstanceFactory.CustomTypeName = "SqlSugar.MySqlConnector"; + break; case DbType.Access: + InstanceFactory.CustomTypeName = "SqlSugar.Access"; + break; case DbType.Custom: + InstanceFactory.CustomTypeName = "Custom"; break; default: throw new Exception("ConnectionConfig.DbType is null"); diff --git a/Src/Asp.Net/SqlSugar/Infrastructure/InstanceFactory.cs b/Src/Asp.Net/SqlSugar/Infrastructure/InstanceFactory.cs index 335519812..75ef9dca9 100644 --- a/Src/Asp.Net/SqlSugar/Infrastructure/InstanceFactory.cs +++ b/Src/Asp.Net/SqlSugar/Infrastructure/InstanceFactory.cs @@ -11,6 +11,7 @@ namespace SqlSugar { static Assembly assembly = Assembly.GetExecutingAssembly(); static Dictionary typeCache = new Dictionary(); + public static string CustomTypeName = ""; public static bool NoCache = false; public static void RemoveCache() @@ -302,7 +303,22 @@ namespace SqlSugar private static string GetClassName(string type, string name) { - return UtilConstants.AssemblyName + "." + type + name; + if (type == "MySqlConnector") + { + return "SqlSugar.MySqlConnector.MySql" + name; + } + else if (type == "Access") + { + return "SqlSugar.MySqlConnector.Access" + name; + } + else if (type == "Custom") + { + return "SqlSugar.MySqlConnector.MySql" + name; + } + else + { + return UtilConstants.AssemblyName + "." + CustomTypeName + name; + } } #region CreateInstance @@ -403,8 +419,16 @@ namespace SqlSugar } private static Restult NoCacheGetCacheInstance(string className, Type[] types) { - - Type type = Type.GetType(className + "`" + types.Length, true).MakeGenericType(types); + + Type type = null; + if (string.IsNullOrEmpty(CustomTypeName)) + { + type = Type.GetType(className + "`" + types.Length, true).MakeGenericType(types); + } + else + { + type = GetCustomTypeByClass(className + "`" + types.Length).MakeGenericType(types); + } var result = (Restult)Activator.CreateInstance(type, true); return result; } @@ -452,10 +476,24 @@ namespace SqlSugar } private static T NoCacheGetCacheInstance(string className) { - Type type = assembly.GetType(className); + Type type = null; + if (string.IsNullOrEmpty(CustomTypeName)) + { + type=assembly.GetType(className); + } + else + { + type = GetCustomTypeByClass(className); + } var result = (T)Activator.CreateInstance(type, true); return result; } + + private static Type GetCustomTypeByClass(string className) + { + Type type = Assembly.LoadFrom(CustomTypeName+".dll").GetType(className); + return type; + } #endregion } }