- 移除 FreeSql.Repository 扩展方法 FromRepository;

- 调整 ISelect.AsTable 规则,每一次使用将增加 UNION ALL 查询;
- 优化 AsTable UseSyncStructureToLower/ToUpper 设置,兼容 AsTable((t,o) => "(select * from tb)"); #89
This commit is contained in:
28810
2019-09-10 09:26:08 +08:00
parent 7fcb2ed601
commit fa61d8a3d1
16 changed files with 168 additions and 253 deletions

View File

@ -225,16 +225,6 @@
<param name="asTable">分表规则,参数:旧表名;返回:新表名 https://github.com/2881099/FreeSql/wiki/Repository</param>
<returns></returns>
</member>
<member name="M:FreeSqlRepositoryExtenssions.FromRepository``2(FreeSql.ISelect{``0},FreeSql.BaseRepository{``1})">
<summary>
合并两个仓储的设置(过滤+分表),以便查询
</summary>
<typeparam name="TEntity"></typeparam>
<typeparam name="T2"></typeparam>
<param name="that"></param>
<param name="repos"></param>
<returns></returns>
</member>
<member name="M:FreeSqlRepositoryExtenssions.CreateUnitOfWork(IFreeSql)">
<summary>
创建基于仓储功能的工作单元,务必使用 using 包含使用

View File

@ -44,20 +44,20 @@ public static class FreeSqlRepositoryExtenssions
return new GuidRepository<TEntity>(that, filter, asTable);
}
/// <summary>
/// 合并两个仓储的设置(过滤+分表),以便查询
/// </summary>
/// <typeparam name="TEntity"></typeparam>
/// <typeparam name="T2"></typeparam>
/// <param name="that"></param>
/// <param name="repos"></param>
/// <returns></returns>
public static ISelect<TEntity> FromRepository<TEntity, T2>(this ISelect<TEntity> that, BaseRepository<T2> repos) where TEntity : class where T2 : class
{
var filters = (repos.DataFilter as DataFilter<T2>)._filters.Where(a => a.Value.IsEnabled == true);
foreach (var filter in filters) that.Where<T2>(filter.Value.Expression);
return that.AsTable(repos.AsTableSelectInternal);
}
///// <summary>
///// 合并两个仓储的设置(过滤+分表),以便查询
///// </summary>
///// <typeparam name="TEntity"></typeparam>
///// <typeparam name="T2"></typeparam>
///// <param name="that"></param>
///// <param name="repos"></param>
///// <returns></returns>
//public static ISelect<TEntity> FromRepository<TEntity, T2>(this ISelect<TEntity> that, BaseRepository<T2> repos) where TEntity : class where T2 : class
//{
// var filters = (repos.DataFilter as DataFilter<T2>)._filters.Where(a => a.Value.IsEnabled == true);
// foreach (var filter in filters) that.Where<T2>(filter.Value.Expression);
// return that.AsTable(repos.AsTableSelectInternal);
//}
/// <summary>
/// 创建基于仓储功能的工作单元,务必使用 using 包含使用