mirror of
https://github.com/nsnail/FreeSql.git
synced 2025-07-29 11:56:19 +08:00
48 lines
2.6 KiB
C#
48 lines
2.6 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Data;
|
|
using System.Linq.Expressions;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace FreeSql
|
|
{
|
|
public interface ISelect<T1, T2, T3> : ISelect0<ISelect<T1, T2, T3>, T1> where T1 : class where T2 : class where T3 : class
|
|
{
|
|
|
|
bool Any(Expression<Func<T1, T2, T3, bool>> exp);
|
|
Task<bool> AnyAsync(Expression<Func<T1, T2, T3, bool>> exp);
|
|
|
|
DataTable ToDataTable<TReturn>(Expression<Func<T1, T2, T3, TReturn>> select);
|
|
Task<DataTable> ToDataTableAsync<TReturn>(Expression<Func<T1, T2, T3, TReturn>> select);
|
|
|
|
List<TReturn> ToList<TReturn>(Expression<Func<T1, T2, T3, TReturn>> select);
|
|
Task<List<TReturn>> ToListAsync<TReturn>(Expression<Func<T1, T2, T3, TReturn>> select);
|
|
List<TDto> ToList<TDto>();
|
|
Task<List<TDto>> ToListAsync<TDto>();
|
|
string ToSql<TReturn>(Expression<Func<T1, T2, T3, TReturn>> select);
|
|
|
|
TReturn ToAggregate<TReturn>(Expression<Func<ISelectGroupingAggregate<T1>, ISelectGroupingAggregate<T2>, ISelectGroupingAggregate<T3>, TReturn>> select);
|
|
Task<TReturn> ToAggregateAsync<TReturn>(Expression<Func<ISelectGroupingAggregate<T1>, ISelectGroupingAggregate<T2>, ISelectGroupingAggregate<T3>, TReturn>> select);
|
|
|
|
TMember Sum<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
Task<TMember> SumAsync<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
TMember Min<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
Task<TMember> MinAsync<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
TMember Max<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
Task<TMember> MaxAsync<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
TMember Avg<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
Task<TMember> AvgAsync<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
|
|
ISelect<T1, T2, T3> LeftJoin(Expression<Func<T1, T2, T3, bool>> exp);
|
|
ISelect<T1, T2, T3> InnerJoin(Expression<Func<T1, T2, T3, bool>> exp);
|
|
ISelect<T1, T2, T3> RightJoin(Expression<Func<T1, T2, T3, bool>> exp);
|
|
|
|
ISelect<T1, T2, T3> Where(Expression<Func<T1, T2, T3, bool>> exp);
|
|
ISelect<T1, T2, T3> WhereIf(bool condition, Expression<Func<T1, T2, T3, bool>> exp);
|
|
|
|
ISelectGrouping<TKey, (T1, T2, T3)> GroupBy<TKey>(Expression<Func<T1, T2, T3, TKey>> exp);
|
|
|
|
ISelect<T1, T2, T3> OrderBy<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
ISelect<T1, T2, T3> OrderByDescending<TMember>(Expression<Func<T1, T2, T3, TMember>> column);
|
|
}
|
|
} |