diff --git a/FreeSql.Tests/FreeSql.Tests/Issues/1208.cs b/FreeSql.Tests/FreeSql.Tests/Issues/1208.cs index 63ec1220..22f81bce 100644 --- a/FreeSql.Tests/FreeSql.Tests/Issues/1208.cs +++ b/FreeSql.Tests/FreeSql.Tests/Issues/1208.cs @@ -112,6 +112,24 @@ WHERE (exists(SELECT 1 limit 0,1)) AND (x.""Id"" = 100) limit 0,1)) ORDER BY a.""Id"" DESC", sql); + + using (userRepository.DataFilter.Disable("TenantQuery")) + { + sql = userRepository.Select + .Where(i => i.DoorDevices.Any(x => x.Id == deviceId)) + .OrderByDescending(true, a => a.Id) + .ToSql(); + Assert.Equal(@"SELECT a.""Id"", a.""TenantId"" +FROM ""issues1208_User"" a +WHERE (exists(SELECT 1 + FROM ""issues1208_DoorDevice"" x + WHERE (exists(SELECT 1 + FROM ""issues1208_DoorDeviceUser"" Mx_Ma + WHERE (Mx_Ma.""DoorDeviceId"" = x.""Id"") AND (Mx_Ma.""UserId"" = a.""Id"") + limit 0,1)) AND (x.""Id"" = 100) + limit 0,1)) +ORDER BY a.""Id"" DESC", sql); + } } } diff --git a/FreeSql/FreeSql.xml b/FreeSql/FreeSql.xml index 33f2441b..b703f8db 100644 --- a/FreeSql/FreeSql.xml +++ b/FreeSql/FreeSql.xml @@ -3331,177 +3331,6 @@ - - - 测试数据库是否连接正确,本方法执行如下命令: - MySql/SqlServer/PostgreSQL/达梦/人大金仓/神通: SELECT 1 - Oracle: SELECT 1 FROM dual - - 命令超时设置(秒) - - true: 成功, false: 失败 - - - - 查询,若使用读写分离,查询【从库】条件cmdText.StartsWith("SELECT "),否则查询【主库】 - - - - - - - - - - 查询,ExecuteReaderAsync(dr => {}, "select * from user where age > @age", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - - 查询 - - - - - - - - - 查询,ExecuteArrayAsync("select * from user where age > @age", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - - 查询 - - - - - - - - - 查询,ExecuteDataSetAsync("select * from user where age > @age; select 2", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - - 查询 - - - - - - - - - 查询,ExecuteDataTableAsync("select * from user where age > @age", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - - 在【主库】执行 - - - - - - - - - 在【主库】执行,ExecuteNonQueryAsync("delete from user where age > @age", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - - 在【主库】执行 - - - - - - - - - 在【主库】执行,ExecuteScalarAsync("select 1 from user where age > @age", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - - 执行SQL返回对象集合,QueryAsync<User>("select * from user where age > @age", new SqlParameter { ParameterName = "age", Value = 25 }) - - - - - - - - - - - 执行SQL返回对象集合,QueryAsync<User>("select * from user where age > @age", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - - - 执行SQL返回对象集合,Query<User>("select * from user where age > @age; select * from address", new SqlParameter { ParameterName = "age", Value = 25 }) - - - - - - - - - - - - 执行SQL返回对象集合,Query<User, Address>("select * from user where age > @age; select * from address", new { age = 25 }) - 提示:parms 参数还可以传 Dictionary<string, object> - - - - - - - - 可自定义解析表达式 @@ -4525,12 +4354,6 @@ 超时 - - - 获取资源 - - - 使用完毕后,归还资源 @@ -4606,12 +4429,6 @@ 资源对象 - - - 从对象池获取对象成功的时候触发,通过该方法统计或初始化对象 - - 资源对象 - 归还对象给对象池的时候触发