static void Main(string[] args) { #region 初始化 IFreeSql var fsql = new FreeSql.FreeSqlBuilder() .UseAutoSyncStructure(true) .UseNoneCommandParameter(true) .UseConnectionString(FreeSql.DataType.Sqlite, "data source=test1.db;max pool size=5") //.UseSlave("data source=test1.db", "data source=test2.db", "data source=test3.db", "data source=test4.db") //.UseSlaveWeight(10, 1, 1, 5) //.UseConnectionString(FreeSql.DataType.Firebird, @"database=localhost:D:\fbdata\EXAMPLES.fdb;user=sysdba;password=123456;max pool size=5") //.UseConnectionString(FreeSql.DataType.MySql, "Data Source=127.0.0.1;Port=3306;User ID=root;Password=root;Initial Catalog=cccddd;Charset=utf8;SslMode=none;Max pool size=2") //.UseConnectionString(FreeSql.DataType.SqlServer, "Data Source=.;Integrated Security=True;Initial Catalog=freesqlTest;Pooling=true;Max Pool Size=3;TrustServerCertificate=true") //.UseConnectionString(FreeSql.DataType.PostgreSQL, "Host=192.168.164.10;Port=5432;Username=postgres;Password=123456;Database=tedb;Pooling=true;Maximum Pool Size=2") //.UseNameConvert(FreeSql.Internal.NameConvertType.ToLower) //.UseConnectionString(FreeSql.DataType.Oracle, "user id=user1;password=123456;data source=//127.0.0.1:1521/XE;Pooling=true;Max Pool Size=2") //.UseNameConvert(FreeSql.Internal.NameConvertType.ToUpper) //.UseConnectionString(FreeSql.DataType.OdbcMySql, "Driver={MySQL ODBC 8.0 Unicode Driver};Server=127.0.0.1;Persist Security Info=False;Trusted_Connection=Yes;UID=root;PWD=root;DATABASE=cccddd_odbc;Charset=utf8;SslMode=none;Max pool size=2") //.UseConnectionString(FreeSql.DataType.OdbcSqlServer, "Driver={SQL Server};Server=.;Persist Security Info=False;Trusted_Connection=Yes;Integrated Security=True;DATABASE=freesqlTest_odbc;Pooling=true;Max pool size=3") //.UseConnectionString(FreeSql.DataType.OdbcPostgreSQL, "Driver={PostgreSQL Unicode(x64)};Server=192.168.164.10;Port=5432;UID=postgres;PWD=123456;Database=tedb_odbc;Pooling=true;Maximum Pool Size=2") //.UseNameConvert(FreeSql.Internal.NameConvertType.ToLower) //.UseConnectionString(FreeSql.DataType.OdbcOracle, "Driver={Oracle in XE};Server=//127.0.0.1:1521/XE;Persist Security Info=False;Trusted_Connection=Yes;UID=odbc1;PWD=123456") //.UseNameConvert(FreeSql.Internal.NameConvertType.ToUpper) //.UseConnectionString(FreeSql.DataType.OdbcDameng, "Driver={DM8 ODBC DRIVER};Server=127.0.0.1:5236;Persist Security Info=False;Trusted_Connection=Yes;UID=USER1;PWD=123456789") .UseMonitorCommand(null, (umcmd, log) => Console.WriteLine(umcmd.Connection.ConnectionString + ":" + umcmd.CommandText + "\r\n")) .UseLazyLoading(true) .UseGenerateCommandParameterWithLambda(true) .Build(); BaseEntity.Initialization(fsql, () => _asyncUow.Value); #endregion if (fsql.Ado.DataType == DataType.PostgreSQL) { fsql.CodeFirst.IsNoneCommandParameter = false; fsql.Aop.AuditDataReader += (_, e) => { var dbtype = e.DataReader.GetDataTypeName(e.Index); var m = Regex.Match(dbtype, @"numeric\((\d+)\)", RegexOptions.IgnoreCase); if (m.Success && int.Parse(m.Groups[1].Value) > 19) { e.Value = e.DataReader.GetFieldValue <BigInteger>(e.Index); //否则会报溢出错误 } }; var num = BigInteger.Parse("57896044618658097711785492504343953926634992332820282019728792003956564819968"); fsql.Delete <tuint256tb_01>().Where("1=1").ExecuteAffrows(); if (1 != fsql.Insert(new tuint256tb_01()).ExecuteAffrows()) { throw new Exception("not equal"); } var find = fsql.Select <tuint256tb_01>().ToList(); if (find.Count != 1) { throw new Exception("not single"); } if ("0" != find[0].Number.ToString()) { throw new Exception("not equal"); } var item = new tuint256tb_01 { Number = num }; if (1 != fsql.Insert(item).ExecuteAffrows()) { throw new Exception("not equal"); } find = fsql.Select <tuint256tb_01>().Where(a => a.Id == item.Id).ToList(); if (find.Count != 1) { throw new Exception("not single"); } if (item.Number != find[0].Number) { throw new Exception("not equal"); } num = num - 1; item.Number = num; if (1 != fsql.Update <tuint256tb_01>().SetSource(item).ExecuteAffrows()) { throw new Exception("not equal"); } find = fsql.Select <tuint256tb_01>().Where(a => a.Id == item.Id).ToList(); if (find.Count != 1) { throw new Exception("not single"); } if ("57896044618658097711785492504343953926634992332820282019728792003956564819967" != find[0].Number.ToString()) { throw new Exception("not equal"); } num = BigInteger.Parse("57896044618658097711785492504343953926634992332820282019728792003956564819968"); fsql.Delete <tuint256tb_01>().Where("1=1").ExecuteAffrows(); if (1 != fsql.Insert(new tuint256tb_01()).NoneParameter().ExecuteAffrows()) { throw new Exception("not equal"); } find = fsql.Select <tuint256tb_01>().ToList(); if (find.Count != 1) { throw new Exception("not single"); } if ("0" != find[0].Number.ToString()) { throw new Exception("not equal"); } item = new tuint256tb_01 { Number = num }; if (1 != fsql.Insert(item).NoneParameter().ExecuteAffrows()) { throw new Exception("not equal"); } find = fsql.Select <tuint256tb_01>().Where(a => a.Id == item.Id).ToList(); if (find.Count != 1) { throw new Exception("not single"); } if (item.Number != find[0].Number) { throw new Exception("not equal"); } num = num - 1; item.Number = num; if (1 != fsql.Update <tuint256tb_01>().NoneParameter().SetSource(item).ExecuteAffrows()) { throw new Exception("not equal"); } find = fsql.Select <tuint256tb_01>().Where(a => a.Id == item.Id).ToList(); if (find.Count != 1) { throw new Exception("not single"); } if ("57896044618658097711785492504343953926634992332820282019728792003956564819967" != find[0].Number.ToString()) { throw new Exception("not equal"); } } fsql.Aop.CommandBefore += (_, e) => { if (CommandTimeoutCascade._asyncLocalTimeout.Value > 0) { e.Command.CommandTimeout = CommandTimeoutCascade._asyncLocalTimeout.Value; } }; using (new CommandTimeoutCascade(1000)) { fsql.Select <Order>().ToList(); fsql.Select <Order>().ToList(); fsql.Select <Order>().ToList(); } var sql1 = fsql.Select <User1, UserGroup>() .RawJoin("FULL JOIN UserGroup b ON b.id = a.GroupId") .Where((a, b) => a.IsDeleted == false) .ToSql((a, b) => new { user = a, group = b }); sql1 = sql1.Replace("INNER JOIN ", "FULL JOIN "); var tinc01 = fsql.Select <UserGroup>().IncludeMany(a => a.User1s.Where(b => b.GroupId == a.Id)).ToList(); var tsub01 = fsql.Select <UserGroup>() .ToList(a => new { users1 = fsql.Select <User1>().Where(b => b.GroupId == a.Id).ToList(), users2 = fsql.Select <User1>().Where(b => b.GroupId == a.Id).ToList(b => new { userid = b.Id, username = b.Username, users11 = fsql.Select <User1>().Where(c => c.GroupId == a.Id).ToList(), users22 = fsql.Select <User1>().Where(c => c.GroupId == a.Id).ToList(c => new { userid = c.Id, username = c.Username, }), groups11 = fsql.Select <UserGroup>().Where(c => c.Id == b.GroupId).ToList(), groups22 = fsql.Select <UserGroup>().Where(c => c.Id == b.GroupId).ToList(c => new { c.Id, c.GroupName, username = b.Username, }) }), users3 = fsql.Select <User1>().Limit(10).ToList(), users4 = fsql.Select <User1>().Limit(10).ToList(b => new { userid = b.Id, username = b.Username }) //users3 = fsql.Ado.Query<User1>("select * from user1 where groupid = @id", new { id = a.Id }) }); var typs = fsql.Select <User1>(); var typs2 = typeof(ISelect <User1>).GetInterfaces().SelectMany(a => a.GetMethods().Where(b => b.Name == "ToListAsync")).ToArray(); var tsub02 = fsql.Select <UserGroup>() .ToListAsync(a => new { users1 = fsql.Select <User1>().Where(b => b.GroupId == a.Id).ToList(), users2 = fsql.Select <User1>().Where(b => b.GroupId == a.Id).ToList(b => new { userid = b.Id, username = b.Username, users11 = fsql.Select <User1>().Where(c => c.GroupId == a.Id).ToList(), users22 = fsql.Select <User1>().Where(c => c.GroupId == a.Id).ToList(c => new { userid = c.Id, username = c.Username, }), groups11 = fsql.Select <UserGroup>().Where(c => c.Id == b.GroupId).ToList(), groups22 = fsql.Select <UserGroup>().Where(c => c.Id == b.GroupId).ToList(c => new { c.Id, c.GroupName, username = b.Username, }) }), users3 = fsql.Select <User1>().Limit(10).ToList(), users4 = fsql.Select <User1>().Limit(10).ToList(b => new { userid = b.Id, username = b.Username }) //users3 = fsql.Ado.Query<User1>("select * from user1 where groupid = @id", new { id = a.Id }) }).Result; fsql.UseJsonMap(); //var txt1 = fsql.Ado.Query<(string, string)>("select '꧁꫞꯭丑小鸭꫞꧂', '123123中国人' from dual"); fsql.Insert(new Order { ShippingAddress = "'꧁꫞꯭丑小鸭꫞꧂'" }).ExecuteAffrows(); fsql.Insert(new Order { ShippingAddress = "'123123中国人'" }).ExecuteAffrows(); var lst1 = fsql.Select <Order>().ToList(); var lst2 = fsql.Select <Order>().ToListIgnore(a => new { a.ShippingAddress }); fsql.Delete <TopicMapTypeToListDto>().Where("1=1").ExecuteAffrows(); fsql.Insert(new[] { new TopicMapTypeToListDto { Clicks = 100, Title = "testMapTypeTitle1", CouponIds = new List <int> { 1, 2, 3, 4 } }, new TopicMapTypeToListDto { Clicks = 101, Title = "testMapTypeTitle2", CouponIds = new List <int> { 1, 2, 3, 1 } }, new TopicMapTypeToListDto { Clicks = 102, Title = "testMapTypeTitle3", CouponIds = new List <int> { 1 } }, new TopicMapTypeToListDto { Clicks = 103, Title = "testMapTypeTitle4", CouponIds = new List <int>() }, new TopicMapTypeToListDto { Clicks = 103, Title = "testMapTypeTitle5", }, }).ExecuteAffrows(); var dtomaplist2 = fsql.Select <TopicMapTypeToListDto>().ToList <TopicMapTypeToListDtoMap>(); var dtomaplist22 = fsql.Select <TopicMapTypeToListDto>().ToList <TopicMapTypeToListDtoMap2>(); var dtomaplist0 = fsql.Select <TopicMapTypeToListDto>().ToList(); var dtomaplist1 = fsql.Select <TopicMapTypeToListDto>().ToList(a => new TopicMapTypeToListDtoMap { CouponIds = a.CouponIds }); int LocalConcurrentDictionaryIsTypeKey(Type dictType, int level = 1) { if (dictType.IsGenericType == false) { return(0); } if (dictType.GetGenericTypeDefinition() != typeof(ConcurrentDictionary <,>)) { return(0); } var typeargs = dictType.GetGenericArguments(); if (typeargs[0] == typeof(Type) || typeargs[0] == typeof(ColumnInfo) || typeargs[0] == typeof(TableInfo)) { return(level); } if (level > 2) { return(0); } return(LocalConcurrentDictionaryIsTypeKey(typeargs[1], level + 1)); } var fds = typeof(FreeSql.Internal.Utils).GetFields(BindingFlags.Static | BindingFlags.NonPublic | BindingFlags.Public) .Where(a => LocalConcurrentDictionaryIsTypeKey(a.FieldType) > 0).ToArray(); var ttypes1 = typeof(IFreeSql).Assembly.GetTypes().Select(a => new { Type = a, ConcurrentDictionarys = a.GetFields(BindingFlags.Static | BindingFlags.NonPublic | BindingFlags.Public) .Where(b => LocalConcurrentDictionaryIsTypeKey(b.FieldType) > 0).ToArray() }).Where(a => a.ConcurrentDictionarys.Length > 0).ToArray(); var ttypes2 = typeof(IBaseRepository).Assembly.GetTypes().Select(a => new { Type = a, ConcurrentDictionarys = a.GetFields(BindingFlags.Static | BindingFlags.NonPublic | BindingFlags.Public) .Where(b => LocalConcurrentDictionaryIsTypeKey(b.FieldType) > 0).ToArray() }).Where(a => a.ConcurrentDictionarys.Length > 0).ToArray(); #region pgsql poco // fsql.Aop.ParseExpression += (_, e) => // { // //解析 POCO Jsonb a.Customer.Name // if (e.Expression is MemberExpression memExp) // { // var parentMemExps = new Stack<MemberExpression>(); // parentMemExps.Push(memExp); // while (true) // { // switch (memExp.Expression.NodeType) // { // case ExpressionType.MemberAccess: // memExp = memExp.Expression as MemberExpression; // if (memExp == null) return; // parentMemExps.Push(memExp); // break; // case ExpressionType.Parameter: // var tb = fsql.CodeFirst.GetTableByEntity(memExp.Expression.Type); // if (tb == null) return; // if (tb.ColumnsByCs.TryGetValue(parentMemExps.Pop().Member.Name, out var trycol) == false) return; // if (new[] { typeof(JToken), typeof(JObject), typeof(JArray) }.Contains(trycol.Attribute.MapType.NullableTypeOrThis()) == false) return; // var tmpcol = tb.ColumnsByPosition.OrderBy(a => a.Attribute.Name.Length).First(); // var result = e.FreeParse(Expression.MakeMemberAccess(memExp.Expression, tb.Properties[tmpcol.CsName])); // result = result.Replace(tmpcol.Attribute.Name, trycol.Attribute.Name); // while (parentMemExps.Any()) // { // memExp = parentMemExps.Pop(); // result = $"{result}->>'{memExp.Member.Name}'"; // } // e.Result = result; // return; // } // } // } // }; // var methodJsonConvertDeserializeObject = typeof(JsonConvert).GetMethod("DeserializeObject", new[] { typeof(string), typeof(Type) }); // var methodJsonConvertSerializeObject = typeof(JsonConvert).GetMethod("SerializeObject", new[] { typeof(object), typeof(JsonSerializerSettings) }); // var jsonConvertSettings = JsonConvert.DefaultSettings?.Invoke() ?? new JsonSerializerSettings(); // FreeSql.Internal.Utils.dicExecuteArrayRowReadClassOrTuple[typeof(Customer)] = true; // FreeSql.Internal.Utils.GetDataReaderValueBlockExpressionObjectToStringIfThenElse.Add((LabelTarget returnTarget, Expression valueExp, Expression elseExp, Type type) => // { // return Expression.IfThenElse( // Expression.TypeIs(valueExp, typeof(Customer)), // Expression.Return(returnTarget, Expression.Call(methodJsonConvertSerializeObject, Expression.Convert(valueExp, typeof(object)), Expression.Constant(jsonConvertSettings)), typeof(object)), // elseExp); // }); // FreeSql.Internal.Utils.GetDataReaderValueBlockExpressionSwitchTypeFullName.Add((LabelTarget returnTarget, Expression valueExp, Type type) => // { // if (type == typeof(Customer)) return Expression.Return(returnTarget, Expression.TypeAs(Expression.Call(methodJsonConvertDeserializeObject, Expression.Convert(valueExp, typeof(string)), Expression.Constant(type)), type)); // return null; // }); // var seid = fsql.Insert(new SomeEntity // { // Customer = JsonConvert.DeserializeObject<Customer>(@"{ // ""Age"": 25, // ""Name"": ""Joe"", // ""Orders"": [ // { ""OrderPrice"": 9, ""ShippingAddress"": ""Some address 1"" }, // { ""OrderPrice"": 23, ""ShippingAddress"": ""Some address 2"" } // ] //}") // }).ExecuteIdentity(); // var selist = fsql.Select<SomeEntity>().ToList(); // var joes = fsql.Select<SomeEntity>() // .Where(e => e.Customer.Name == "Joe") // .ToSql(); #endregion var testitems = new[] { new AsTableLog { msg = "msg01", createtime = DateTime.Parse("2022-1-1 13:00:11") }, new AsTableLog { msg = "msg02", createtime = DateTime.Parse("2022-1-2 14:00:12") }, new AsTableLog { msg = "msg03", createtime = DateTime.Parse("2022-2-2 15:00:13") }, new AsTableLog { msg = "msg04", createtime = DateTime.Parse("2022-2-8 15:00:13") }, new AsTableLog { msg = "msg05", createtime = DateTime.Parse("2022-3-8 15:00:13") }, new AsTableLog { msg = "msg06", createtime = DateTime.Parse("2022-4-8 15:00:13") }, new AsTableLog { msg = "msg07", createtime = DateTime.Parse("2022-6-8 15:00:13") }, new AsTableLog { msg = "msg07", createtime = DateTime.Parse("2022-7-1") } }; var sqlatb = fsql.Insert(testitems).NoneParameter(); var sqlat = sqlatb.ToSql(); var sqlatr = sqlatb.ExecuteAffrows(); var sqlatc1 = fsql.Delete <AsTableLog>().Where(a => a.id == Guid.NewGuid() && a.createtime == DateTime.Parse("2022-3-8 15:00:13")); var sqlatca1 = sqlatc1.ToSql(); var sqlatcr1 = sqlatc1.ExecuteAffrows(); var sqlatc2 = fsql.Delete <AsTableLog>().Where(a => a.id == Guid.NewGuid() && a.createtime == DateTime.Parse("2021-3-8 15:00:13")); var sqlatca2 = sqlatc2.ToSql(); var sqlatcr2 = sqlatc2.ExecuteAffrows(); var sqlatc = fsql.Delete <AsTableLog>().Where(a => a.id == Guid.NewGuid() && a.createtime.Between(DateTime.Parse("2022-3-1"), DateTime.Parse("2022-5-1"))); var sqlatca = sqlatc.ToSql(); var sqlatcr = sqlatc.ExecuteAffrows(); var sqlatd1 = fsql.Update <AsTableLog>().SetSource(testitems[0]); var sqlatd101 = sqlatd1.ToSql(); var sqlatd102 = sqlatd1.ExecuteAffrows(); var sqlatd2 = fsql.Update <AsTableLog>().SetSource(testitems[5]); var sqlatd201 = sqlatd2.ToSql(); var sqlatd202 = sqlatd2.ExecuteAffrows(); var sqlatd3 = fsql.Update <AsTableLog>().SetSource(testitems); var sqlatd301 = sqlatd3.ToSql(); var sqlatd302 = sqlatd3.ExecuteAffrows(); var sqlatd4 = fsql.Update <AsTableLog>(Guid.NewGuid()).Set(a => a.msg == "newmsg"); var sqlatd401 = sqlatd4.ToSql(); var sqlatd402 = sqlatd4.ExecuteAffrows(); var sqlatd5 = fsql.Update <AsTableLog>(Guid.NewGuid()).Set(a => a.msg == "newmsg").Where(a => a.createtime.Between(DateTime.Parse("2022-3-1"), DateTime.Parse("2022-5-1"))); var sqlatd501 = sqlatd5.ToSql(); var sqlatd502 = sqlatd5.ExecuteAffrows(); var sqlatd6 = fsql.Update <AsTableLog>(Guid.NewGuid()).Set(a => a.msg == "newmsg").Where(a => a.createtime > DateTime.Parse("2022-3-1") && a.createtime < DateTime.Parse("2022-5-1")); var sqlatd601 = sqlatd6.ToSql(); var sqlatd602 = sqlatd6.ExecuteAffrows(); var sqlatd7 = fsql.Update <AsTableLog>(Guid.NewGuid()).Set(a => a.msg == "newmsg").Where(a => a.createtime > DateTime.Parse("2022-3-1")); var sqlatd701 = sqlatd7.ToSql(); var sqlatd702 = sqlatd7.ExecuteAffrows(); var sqlatd8 = fsql.Update <AsTableLog>(Guid.NewGuid()).Set(a => a.msg == "newmsg").Where(a => a.createtime < DateTime.Parse("2022-5-1")); var sqlatd801 = sqlatd8.ToSql(); var sqlatd802 = sqlatd8.ExecuteAffrows(); var sqlatd12 = fsql.InsertOrUpdate <AsTableLog>().SetSource(testitems[0]); var sqlatd1201 = sqlatd12.ToSql(); var sqlatd1202 = sqlatd12.ExecuteAffrows(); var sqlatd22 = fsql.InsertOrUpdate <AsTableLog>().SetSource(testitems[5]); var sqlatd2201 = sqlatd22.ToSql(); var sqlatd2202 = sqlatd22.ExecuteAffrows(); var sqlatd32 = fsql.InsertOrUpdate <AsTableLog>().SetSource(testitems); var sqlatd3201 = sqlatd32.ToSql(); var sqlatd3202 = sqlatd32.ExecuteAffrows(); var sqls1 = fsql.Select <AsTableLog>(); var sqls101 = sqls1.ToSql(); var sqls102 = sqls1.ToList(); var sqls2 = fsql.Select <AsTableLog>().Where(a => a.createtime.Between(DateTime.Parse("2022-3-1"), DateTime.Parse("2022-5-1"))); var sqls201 = sqls2.ToSql(); var sqls202 = sqls2.ToList(); var sqls3 = fsql.Select <AsTableLog>().Where(a => a.createtime > DateTime.Parse("2022-3-1") && a.createtime < DateTime.Parse("2022-5-1")); var sqls301 = sqls3.ToSql(); var sqls302 = sqls3.ToList(); var sqls4 = fsql.Select <AsTableLog>().Where(a => a.createtime > DateTime.Parse("2022-3-1")); var sqls401 = sqls4.ToSql(); var sqls402 = sqls4.ToList(); var sqls5 = fsql.Select <AsTableLog>().Where(a => a.createtime < DateTime.Parse("2022-5-1")); var sqls501 = sqls5.ToSql(); var sqls502 = sqls5.ToList(); var sqls6 = fsql.Select <AsTableLog>().Where(a => a.createtime < DateTime.Parse("2022-5-1")).Limit(10).OrderBy(a => a.createtime); var sqls601 = sqls6.ToSql(); var sqls602 = sqls6.ToList(); fsql.Aop.AuditValue += new EventHandler <FreeSql.Aop.AuditValueEventArgs>((_, e) => { }); Dictionary <string, object> dic = new Dictionary <string, object>(); dic.Add("id", 1); dic.Add("name", "xxxx"); var diclist = new List <Dictionary <string, object> >(); diclist.Add(dic); diclist.Add(new Dictionary <string, object> { ["id"] = 2, ["name"] = "yyyy" }); var sqss = fsql.InsertDict(dic).AsTable("table1").ToSql(); var sqss2 = fsql.InsertDict(diclist).AsTable("table1").ToSql(); sqss = fsql.InsertDict(dic).AsTable("table1").NoneParameter(false).ToSql(); sqss2 = fsql.InsertDict(diclist).AsTable("table1").NoneParameter(false).ToSql(); var sqlupd1 = fsql.UpdateDict(dic).AsTable("table1").WherePrimary("id").ToSql(); var sqlupd2 = fsql.UpdateDict(diclist).AsTable("table1").WherePrimary("id").ToSql(); var sqlupd11 = fsql.UpdateDict(dic).AsTable("table1").WherePrimary("id").NoneParameter(false).ToSql(); var sqlupd22 = fsql.UpdateDict(diclist).AsTable("table1").WherePrimary("id").NoneParameter(false).ToSql(); var sqldel1 = fsql.DeleteDict(dic).AsTable("table1").ToSql(); var sqldel2 = fsql.DeleteDict(diclist).AsTable("table1").ToSql(); diclist[1]["title"] = "newtitle"; var sqldel3 = fsql.DeleteDict(diclist).AsTable("table1").ToSql(); diclist.Clear(); diclist.Add(new Dictionary <string, object> { ["id"] = 1 }); diclist.Add(new Dictionary <string, object> { ["id"] = 2 }); var sqldel4 = fsql.DeleteDict(diclist).AsTable("table1").ToSql(); for (var a = 0; a < 10000; a++) { fsql.Select <User1>().First(); } for (var a = 0; a < 1000; a++) { fsql.Transaction(() => { var tran = fsql.Ado.TransactionCurrentThread; tran.Rollback(); }); } fsql.UseJsonMap(); var bid1 = 10; var list1 = fsql.Select <A>() .Where(a => a.BId == bid1); var aid1 = 11; var select2 = fsql.Select <B>(); (select2 as Select0Provider)._params = (list1 as Select0Provider)._params; var list2 = select2 .Where(a => list1.ToList(B => B.BId).Contains(a.Id)) .Where(a => a.Id == aid1) .ToSql(); //fsql.Aop.CommandBefore += (s, e) => //{ // e.States["xxx"] = 111; //}; //fsql.Aop.CommandAfter += (s, e) => //{ // var xxx = e.States["xxx"]; //}; //fsql.Aop.TraceBefore += (s, e) => //{ // e.States["xxx"] = 222; //}; //fsql.Aop.TraceAfter += (s, e) => //{ // var xxx = e.States["xxx"]; //}; //fsql.Aop.SyncStructureBefore += (s, e) => //{ // e.States["xxx"] = 333; //}; //fsql.Aop.SyncStructureAfter += (s, e) => //{ // var xxx = e.States["xxx"]; //}; //fsql.Aop.CurdBefore += (s, e) => //{ // e.States["xxx"] = 444; //}; //fsql.Aop.CurdAfter += (s, e) => //{ // var xxx = e.States["xxx"]; //}; fsql.Insert(new tttorder("xx1", 1, 10)).ExecuteAffrows(); fsql.Insert(new tttorder("xx2", 2, 20)).ExecuteAffrows(); var tttorders = fsql.Select <tttorder>().Limit(2).ToList(); var tsql1 = fsql.Select <Sys_reg_user>() .Include(a => a.Owner) .Where(a => a.UnionId == "xxx") .ToSql(); var tsql2 = fsql.Select <Sys_owner>() .Where(a => a.RegUser.UnionId == "xxx2") .ToSql(); var names = (fsql.Select <object>() as Select0Provider)._commonUtils.SplitTableName("`Backups.ProductStockBak`"); var dbparams = fsql.Ado.GetDbParamtersByObject(new { id = 1, name = "xxx" }); var sql = fsql.CodeFirst.GetComparisonDDLStatements(typeof(EMSServerModel.Model.User), "testxsx001"); var test01 = EMSServerModel.Model.User.Select.IncludeMany(a => a.Roles).ToList(); var test02 = EMSServerModel.Model.UserRole.Select.ToList(); var test01tb = EMSServerModel.Model.User.Orm.CodeFirst.GetTableByEntity(typeof(EMSServerModel.Model.User)); var us = User1.Select.Limit(10).ToList(); new Products { title = "product-1" }.Save(); new Products { title = "product-2" }.Save(); new Products { title = "product-3" }.Save(); new Products { title = "product-4" }.Save(); new Products { title = "product-5" }.Save(); var wdy1 = JsonConvert.DeserializeObject <DynamicFilterInfo>(@" { ""Logic"" : ""And"", ""Filters"" : [ { ""Logic"" : ""Or"", ""Filters"" : [ { ""Field"" : ""title"", ""Operator"" : ""contains"", ""Value"" : """", }, { ""Field"" : ""title"", ""Operator"" : ""contains"", ""Value"" : ""product-2222"", } ] }, { ""Field"" : ""title"", ""Operator"" : ""eq"", ""Value"" : ""product-2"" }, { ""Field"" : ""title"", ""Operator"" : ""eq"", ""Value"" : ""product-3"" }, { ""Field"" : ""title"", ""Operator"" : ""eq"", ""Value"" : ""product-4"" }, { ""Field"" : ""testint"", ""Operator"" : ""Range"", ""Value"" : [100,200] }, { ""Field"" : ""testint"", ""Operator"" : ""Range"", ""Value"" : [""101"",""202""] }, { ""Field"" : ""testint"", ""Operator"" : ""contains"", ""Value"" : ""123"" }, ] } "); var config = new JsonSerializerOptions() { PropertyNamingPolicy = null, AllowTrailingCommas = true, IgnoreNullValues = true, Encoder = JavaScriptEncoder.UnsafeRelaxedJsonEscaping, Converters = { new JsonStringEnumConverter() } }; var wdy2 = System.Text.Json.JsonSerializer.Deserialize <DynamicFilterInfo>(@" { ""Logic"" : 1, ""Filters"" : [ { ""Field"" : ""title"", ""Operator"" : 8, ""Value"" : ""product-1"", ""Filters"" : [ { ""Field"" : ""title"", ""Operator"" : 0, ""Value"" : ""product-1111"" } ] }, { ""Field"" : ""title"", ""Operator"" : 8, ""Value"" : ""product-2"" }, { ""Field"" : ""title"", ""Operator"" : 8, ""Value"" : ""product-3"" }, { ""Field"" : ""title"", ""Operator"" : 8, ""Value"" : ""product-4"" }, { ""Field"" : ""testint"", ""Operator"" : 8, ""Value"" : 11 }, { ""Field"" : ""testint"", ""Operator"" : 8, ""Value"" : ""12"" }, { ""Field"" : ""testint"", ""Operator"" : ""Range"", ""Value"" : [100,200] }, { ""Field"" : ""testint"", ""Operator"" : ""Range"", ""Value"" : [""101"",""202""] } ] } ", config); Products.Select.WhereDynamicFilter(wdy1).ToList(); Products.Select.WhereDynamicFilter(wdy2).ToList(); var items1 = Products.Select.Limit(10).OrderByDescending(a => a.CreateTime).ToList(); var items2 = fsql.Select <Products>().Limit(10).OrderByDescending(a => a.CreateTime).ToList(); BaseEntity.Orm.UseJsonMap(); BaseEntity.Orm.UseJsonMap(); BaseEntity.Orm.CodeFirst.ConfigEntity <S_SysConfig <TestConfig> >(a => { a.Property(b => b.Config2).JsonMap(); }); new S_SysConfig <TestConfig> { Name = "testkey11", Config = new TestConfig { clicks = 11, title = "testtitle11" }, Config2 = new TestConfig { clicks = 11, title = "testtitle11" } }.Save(); new S_SysConfig <TestConfig> { Name = "testkey22", Config = new TestConfig { clicks = 22, title = "testtitle22" }, Config2 = new TestConfig { clicks = 11, title = "testtitle11" } }.Save(); new S_SysConfig <TestConfig> { Name = "testkey33", Config = new TestConfig { clicks = 33, title = "testtitle33" }, Config2 = new TestConfig { clicks = 11, title = "testtitle11" } }.Save(); var testconfigs11 = S_SysConfig <TestConfig> .Select.ToList(); var testconfigs11tb = S_SysConfig <TestConfig> .Select.ToDataTable(); var testconfigs111 = S_SysConfig <TestConfig> .Select.ToList(a => a.Name); var testconfigs112 = S_SysConfig <TestConfig> .Select.ToList(a => a.Config); var testconfigs1122 = S_SysConfig <TestConfig> .Select.ToList(a => new { a.Name, a.Config }); var testconfigs113 = S_SysConfig <TestConfig> .Select.ToList(a => a.Config2); var testconfigs1133 = S_SysConfig <TestConfig> .Select.ToList(a => new { a.Name, a.Config2 }); var repo = BaseEntity.Orm.Select <TestConfig>().Limit(10).ToList(); //void ConfigEntityProperty(object sender, FreeSql.Aop.ConfigEntityPropertyEventArgs e) //{ // if (e.Property.PropertyType == typeof(byte[])) // { // var orm = sender as IFreeSql; // switch (orm.Ado.DataType) // { // case DataType.SqlServer: // e.ModifyResult.DbType = "image"; // break; // case DataType.MySql: // e.ModifyResult.DbType = "longblob"; // break; // } // } //} //fsql.Aop.ConfigEntityProperty += ConfigEntityProperty; Task.Run(async() => { using (var uow = BaseEntity.Orm.CreateUnitOfWork()) { _asyncUow.Value = uow; try { var id = (await new User1().SaveAsync()).Id; } finally { _asyncUow.Value = null; } uow.Commit(); } var ug1 = new UserGroup(); ug1.GroupName = "分组一"; await ug1.InsertAsync(); var ug2 = new UserGroup(); ug2.GroupName = "分组二"; await ug2.InsertAsync(); var u1 = new User1(); u1.GroupId = ug1.Id; await u1.SaveAsync(); await u1.DeleteAsync(); await u1.RestoreAsync(); u1.Nickname = "x1"; await u1.UpdateAsync(); var u11 = await User1.FindAsync(u1.Id); u11.Description = "备注"; await u11.SaveAsync(); await u11.DeleteAsync(); var slslsl = Newtonsoft.Json.JsonConvert.SerializeObject(u1); var u11null = User1.Find(u1.Id); var u11s = User1.Where(a => a.Group.Id == ug1.Id).Limit(10).ToList(); var u11s2 = User1.Select.LeftJoin <UserGroup>((a, b) => a.GroupId == b.Id).Limit(10).ToList(); var ug1s = UserGroup.Select .IncludeMany(a => a.User1s) .Limit(10).ToList(); var ug1s2 = UserGroup.Select.Where(a => a.User1s.AsSelect().Any(b => b.Nickname == "x1")).Limit(10).ToList(); var r1 = new Role(); r1.Id = "管理员"; await r1.SaveAsync(); var r2 = new Role(); r2.Id = "超级会员"; await r2.SaveAsync(); var ru1 = new RoleUser1(); ru1.User1Id = u1.Id; ru1.RoleId = r1.Id; await ru1.SaveAsync(); ru1.RoleId = r2.Id; await ru1.SaveAsync(); var u1roles = await User1.Select.IncludeMany(a => a.Roles).ToListAsync(); var u1roles2 = await User1.Select.Where(a => a.Roles.AsSelect().Any(b => b.Id == "xx")).ToListAsync(); }).Wait(); Console.WriteLine("按任意键结束。。。"); Console.ReadKey(); }