blob: 9c6d9a8ed09c23135e23dbe00b8ad74f502d41a9 [file] [log] [blame]
/*
* 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.Collections.Generic;
using System.Diagnostics.CodeAnalysis;
using System.Threading.Tasks;
/// <summary>
/// Query result set.
/// <para />
/// Implements <see cref="IAsyncEnumerable{T}"/>: use <c>await foreach (var row in resultSet)</c> to consume,
/// or call <see cref="ToListAsync"/> to get all rows as a list.
/// <para />
/// Can not be enumerated more than once. The implementation is lazy and retrieves data pages on demand
/// (while iterating with <see cref="IAsyncEnumerable{T}"/> or when <see cref="ToListAsync"/> is called).
/// Page size is defined in <see cref="SqlStatement.PageSize"/>.
/// </summary>
/// <typeparam name="T">Row type.</typeparam>
public interface IResultSet<T> : IAsyncEnumerable<T>, IAsyncDisposable, IDisposable
{
/// <summary>
/// Gets result set metadata when <see cref="HasRowSet"/> is <c>true</c>, otherwise <c>null</c>.
/// </summary>
IResultSetMetadata? Metadata { get; }
/// <summary>
/// Gets a value indicating whether this result set contains a collection of rows.
/// </summary>
[MemberNotNullWhen(true, nameof(Metadata))]
bool HasRowSet { get; }
/// <summary>
/// Gets the number of rows affected by the DML statement execution (such as "INSERT", "UPDATE", etc.),
/// or 0 if the statement returns nothing (such as "ALTER TABLE", etc), or -1 if not applicable.
/// </summary>
long AffectedRows { get; }
/// <summary>
/// Gets a value indicating whether a conditional query (such as "CREATE TABLE IF NOT EXISTS") was applied successfully.
/// </summary>
bool WasApplied { get; }
/// <summary>
/// Gets all result set rows as list.
/// <para />
/// Can not be called multiple times - the underlying server-side result set is closed as soon
/// as the last page of data is retrieved, and client-side buffer is also released to reduce memory usage.
/// </summary>
/// <returns>All result set rows as list.</returns>
ValueTask<List<T>> ToListAsync();
/// <summary>
/// Gets all result set rows as dictionary.
/// <para />
/// Can not be called multiple times - the underlying server-side result set is closed as soon
/// as the last page of data is retrieved, and client-side buffer is also released to reduce memory usage.
/// </summary>
/// <param name="keySelector">Key selector.</param>
/// <param name="valSelector">Value selector.</param>
/// <param name="comparer">Optional comparer.</param>
/// <typeparam name="TK">Dictionary key type.</typeparam>
/// <typeparam name="TV">Dictionary value type.</typeparam>
/// <returns>All result set rows as list.</returns>
ValueTask<Dictionary<TK, TV>> ToDictionaryAsync<TK, TV>(
Func<T, TK> keySelector,
Func<T, TV> valSelector,
IEqualityComparer<TK>? comparer = null)
where TK : notnull;
/// <summary>
/// Collects all result set rows into a container of the specified type.
/// </summary>
/// <param name="constructor">Container constructor, accepts estimated capacity.
/// Actual result set size may exceed specified capacity.</param>
/// <param name="accumulator">Accumulator, adds rows to the container.</param>
/// <typeparam name="TResult">Resulting container type.</typeparam>
/// <returns>resulting container.</returns>
ValueTask<TResult> CollectAsync<TResult>(Func<int, TResult> constructor, Action<TResult, T> accumulator);
}
}