modules/platforms/dotnet/Apache.Ignite/Sql/IgniteQueryableExtensions.Sum.cs (212 lines of code) (raw):

/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ namespace Apache.Ignite.Sql; using System; using System.Diagnostics.CodeAnalysis; using System.Linq; using System.Linq.Expressions; using System.Reflection; using System.Threading.Tasks; using Internal.Common; using Table; /// <summary> /// LINQ extensions for Apache Ignite SQL engine. /// <para /> /// Use <see cref="IRecordView{T}.AsQueryable"/> and <see cref="IKeyValueView{TK,TV}.AsQueryable"/> to query Ignite with LINQ, then /// materialize the query results by calling <see cref="ToResultSetAsync{T}"/>. /// </summary> public static partial class IgniteQueryableExtensions { /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<int> SumAsync(this IQueryable<int> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<int>, int>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<int>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<int> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, int>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, int>>, int>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<int>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<int?> SumAsync(this IQueryable<int?> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<int?>, int?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<int?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<int?> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, int?>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, int?>>, int?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<int?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<long> SumAsync(this IQueryable<long> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<long>, long>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<long>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<long> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, long>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, long>>, long>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<long>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<long?> SumAsync(this IQueryable<long?> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<long?>, long?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<long?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<long?> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, long?>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, long?>>, long?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<long?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<float> SumAsync(this IQueryable<float> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<float>, float>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<float>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<float> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, float>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, float>>, float>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<float>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<float?> SumAsync(this IQueryable<float?> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<float?>, float?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<float?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<float?> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, float?>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, float?>>, float?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<float?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<double> SumAsync(this IQueryable<double> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<double>, double>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<double>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<double> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, double>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, double>>, double>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<double>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<double?> SumAsync(this IQueryable<double?> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<double?>, double?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<double?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<double?> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, double?>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, double?>>, double?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<double?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<decimal> SumAsync(this IQueryable<decimal> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<decimal>, decimal>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<decimal>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<decimal> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, decimal>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, decimal>>, decimal>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<decimal>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <param name="queryable">Query.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<decimal?> SumAsync(this IQueryable<decimal?> queryable) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<decimal?>, decimal?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<decimal?>(expression).ConfigureAwait(false); } /// <summary> /// Returns the sum of a sequence of values. /// </summary> /// <typeparam name="TSource">Element type.</typeparam> /// <param name="queryable">Query.</param> /// <param name="selector">A projection function to apply to each element.</param> /// <returns>A <see cref="Task"/> representing the asynchronous operation. /// The task result contains the sum of a sequence of values. /// </returns> [DynamicDependency("Sum", typeof(Queryable))] public static async Task<decimal?> SumAsync<TSource>( this IQueryable<TSource> queryable, Expression<Func<TSource, decimal?>> selector) { IgniteArgumentCheck.NotNull(queryable, nameof(queryable)); var method = new Func<IQueryable<TSource>, Expression<Func<TSource, decimal?>>, decimal?>(Queryable.Sum).GetMethodInfo(); var expression = Expression.Call(null, method, queryable.Expression, Expression.Quote(selector)); var provider = queryable.ToQueryableInternal().Provider; return await provider.ExecuteSingleAsync<decimal?>(expression).ConfigureAwait(false); } }