first commit

This commit is contained in:
2026-01-10 23:14:51 -06:00
commit 389715b4b4
503 changed files with 98244 additions and 0 deletions

View File

@@ -0,0 +1,36 @@
using System.Data;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Storage;
using Npgsql;
namespace Rs_system.Data;
public static class PostgresScalarExecutor
{
public static async Task<T> ExecuteAsync<T>(
DbContext context,
string sql,
Action<NpgsqlParameterCollection>? parameters = null
)
{
var conn = (NpgsqlConnection)context.Database.GetDbConnection();
if (conn.State != ConnectionState.Open)
await conn.OpenAsync();
await using var cmd = new NpgsqlCommand(sql, conn);
var currentTx = context.Database.CurrentTransaction;
if (currentTx != null)
cmd.Transaction = (NpgsqlTransaction)currentTx.GetDbTransaction();
parameters?.Invoke(cmd.Parameters);
var result = await cmd.ExecuteScalarAsync();
if (result == null || result == DBNull.Value)
throw new InvalidOperationException("La consulta escalar no devolvió ningún valor.");
return (T)Convert.ChangeType(result, typeof(T));
}
}