Cl.Core.Db
1.2.2
See the version list below for details.
dotnet add package Cl.Core.Db --version 1.2.2
NuGet\Install-Package Cl.Core.Db -Version 1.2.2
<PackageReference Include="Cl.Core.Db" Version="1.2.2" />
paket add Cl.Core.Db --version 1.2.2
#r "nuget: Cl.Core.Db, 1.2.2"
// Install Cl.Core.Db as a Cake Addin #addin nuget:?package=Cl.Core.Db&version=1.2.2 // Install Cl.Core.Db as a Cake Tool #tool nuget:?package=Cl.Core.Db&version=1.2.2
Acerca de Cl.Core.Db
Permite contruir y ejecutar scripts de base de datos a través de un contexto EntityFramework y retornar un ResultSet mapeado a su objeto de interés.
¿Qué resuelve?
Optimiza los tiempos de creación de transacciones CRUD, permitiéndole al desarrrollar invocar los métodos que esta librería ofrece y asi evitarse tener que estar mapeado las propiedades de un objeto. Esto nos permite solo tener que crear los objetos de base de datos que van a recibir estas propiedades.
Resumen de versión
Características (Features)
- Soporte para paginacion de consultas a base de datos de aplicación
Correcciones (Fixes)
- Agregados ICore e IServices interfaces para inyectar los servicio de bases de datos
Rutinas
GetDataTable:System.Data.DataTable
- System.Data.Common.DbConnection _connection: Contexto de la conexión de la base de datos.
- System.String _query: Query que va a ser ejecutado.
Usado para devolver una tabla según el query suministrado.
GetDataSet:System.Data.DataSet
- System.String _stringConnection: Datos de la conexión para poder crear. una nueva instancia de la conexión
- System.String _query: Query que va a ser ejecutado.
Usado para devolver el resultado de multiples tablas que puede retornar un query.
GetDBObjectName:System.String
- System.String _dbObjectKey: Alias del nombre del objeto de base de datos.
- T _context: Modelo del contexto de la base de datos.
- System.Bool _shouldReleaseContext(false): Bandera para indicar si este método debe liberar la conexión tras finalizar sus procesos.
Usado para obtener el objeto de base de datos para formar parte del query que se va a ejecutar.
Execute:Cl.Core.Structures.Classes.Context<System.Collections.Generic.List<T>>
T:new()
U:System.Data.Entity.DbContext, new()
- System.String _dbObjectToken: Alias de objeto de base de datos(Usualmente una vista sql).
Retorna el ResultSet de una vista sql.
Ejemplo:
// Retorna todos los usuarios de la vista con alias vGetUsers
var users = _services.Execute<User, AppContext>("vGetUsers").Response.Data;
Execute:CL.STRUCTURES.CLASSES.Context<System.Collections.Generic.List<T>>
T:new(): Objeto que va a ser mapeado a un query.
U:System.Data.Entity.DbContext, new(): Model del contexto de la base de datos.
- System.String _dbObjectToken: Alias de objeto de base de datos.
- V _index: Llave del objeto a filtrar, debe ser una primitiva de datos.
Permite filtrar un ResultSet mediante una llave(DocEntry, Id, etc.)
Ejemplo:
// Retorna todos los usuarios con el Id 5, pero le aplicamos un first or default para obtener solo uno.
var user = _services.Execute<User, AppContext, System.Int16>("spGetUserById", 5).Response.Data.FirstOrDefault();
Execute:Cl.Core.Structures.Classes.Context<System.Collections.Generic.List<T>>
T:new(): Objeto que va a ser mapeado a un query.
U:System.Data.Entity.DbContext, new(): Model del contexto de la base de datos.
V:Cl.Core.Structures.Interfaces.ICLMaster: Interface validadora al incluir/excluir propieades del Objeto T
- System.String _dbObjectToken: Alias de objeto de base de datos.
- T _object: Objeto que va a ser mapeado a un query
- System.String[] _toIgnore: Lista de propieades del objeto que van ser ignoradas/incluidas
Crear un query según las propiedades del objeto U y el genérico V, el cual puede ser dos interfaces. Cl.Core.Structures.Interfaces.ICLInclude, para indicar que las propidades de la lista _toIgnore van a ser omitidas en el query y Cl.Core.Structures.Interfaces.ICLExclude, para indicar que solo quiero tomar esas propidades.
Ejemplo:
// Obtiene todos los usuarios, pero excluyendo la propiedad Id al momento de crear el query.
var usersa = _services.Execute<User, AppContext, Cl.Core.Structures.Interfaces.ICLExclude>("spGetUsers", user, new System.String[] { "Id" });
Execute:Cl.Core.Structures.Classes.Context<System.Collections.Generic.List<U>>
T:new(): Objeto que va a ser mapeado a un query.
U:new(): Objeto aal que va a ser mapeado el ResultSet.
V:System.Data.Entity.DbContext, new(): Contexto de la base de datos.
W:Cl.Core.Structures.Interfaces.ICLMaster: Interface validadora al incluir/excluir propieades del Objeto T
- System.String _dbObjectToken: Alias del objeto de base de datos que va a formar parte del query.
- T _object: Objeto que va a ser mapedo a un query
- System.String[] _toIgnore(null): Lista de propieades a incluir/ignorar.
Crear un query según las propiedades del objeto T y el genérico V, el cual puede ser dos interfaces. CL.STRUCTURES.INTERFACES.ICLInclude, para indicar que las propidades de la lista _toIgnore van a ser omitidas en el query y CL.STRUCTURES.INTERFACES.ICLExclude, para indicar que solo quiero tomar esas propidades, pero con la facilidad de devolver un objeto de tipo U.
// Retorna todos los documentos según el objeto search que puede tener propiedades como rango de fechas
var documents = _services.Execute<Search, Document, AppContext, Cl.Core.Structures.Interfaces.ICLInclude>("spGetDocuments", search);
Paginación de consultas
Para realizar la paginacion de consultas debera agregar el siguiente ActionFilter al endpoint
Cl.Core.Common.ActionFilters.ApplicationDatabase.EnablePagination
esto hara que los valores de paginacion enviados se envien como parametros a los procedimientos almacenados. Ademas tiene que agregar los siguientes parametros en el siguiente orden:@Take INT
,@Skip INT
,@Count INT OUTPUT
, como en el siguiente ejemplo:CREATE PROCEDURE dbo.MyProcedure @Take INT, @Skip INT, @Count INT OUTPUT, -- ...Other parameters AS BEGIN SET @Count = (SELECT COUNT(*) FROM dbo.MyTable)--your query to get the total records of the query without pagination SELECT [* | column1, column2, ...] FROM dbo.MyTable ORDER BY [column1, ...] [DESC | ASC] OFFSET @Skip ROWS FETCH NEXT @Take ROWS ONLY; END;
Configuration keys
Hay ciertas keys de configuración que se deben agregar para el correcto funcionamiento
- spGetDBResource (Obligatoria): Esta key de configuración lo que hace es otorgar el nombre del procedimiento almacenado que va a obtener los nombres de los otros objetos de base de datos. Ejm: "< add key="spGetDBResource" value="CLVS_D_MLT_SLT_DBRESOURCE" />" Parametros que debe tener el procedimiento almacenado que se indica en el valor de la key:
- Name: Codigo del DBResource
- CompanyKey: Id de la compañía, este parametro solamente se debe agregar al procedimiento si la key de configuración IsMulticompany esta con el valor true. Para obtener el valor de este parametro se debe agregar el id de la compañía en los HttpContext.Current.Items con el siguiente identificador Cl.Core.Structures.Enums.HttpContextItems.CompanyKey
- IsMulticompany (Obligatoria): Esta key de configuración se utiliza para saber si la aplicacion va a manejar multicompañía, acepta los siguientes valores "true" o "false", si se agrega con "true" debe agregar un parametro extra al procedimiento almacenado que se indica en el "spGetDBResource"
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- Cl.Core.Common (>= 1.6.7)
- Cl.Core.Structures (>= 1.5.0)
- Microsoft.Data.SqlClient (>= 5.1.1)
- Microsoft.EntityFrameworkCore (>= 7.0.5)
- Microsoft.EntityFrameworkCore.Relational (>= 7.0.5)
- System.Data.Odbc (>= 7.0.0)
- System.Data.SqlClient (>= 4.8.5)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on Cl.Core.Db:
Package | Downloads |
---|---|
Cl.Core.Auth
Servicios para recuperacion y cambio de contraseñas |
|
Cl.Core.Addons
Funciones relacionadas con componente de walkthrough |
|
Cl.Core.Udfs
Funcionalidades relacionadas con udfs dinámicos |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.2.3-alpha | 87 | 12/20/2024 |
1.2.2 | 618 | 8/8/2024 |
1.2.2-alpha | 128 | 7/31/2024 |
1.2.1-alpha | 297 | 6/22/2024 |
1.2.0 | 212 | 5/18/2024 |
1.1.1-alpha | 107 | 4/26/2024 |
1.1.0-alpha | 112 | 4/22/2024 |
1.0.3.2 | 311 | 2/16/2024 |
1.0.3.1 | 140 | 2/14/2024 |
1.0.3 | 337 | 11/28/2023 |
1.0.2 | 240 | 9/29/2023 |
1.0.2-alpha | 133 | 8/17/2023 |
1.0.1-alpha | 132 | 8/17/2023 |
1.0.0.2 | 230 | 7/4/2023 |
1.0.0.2-alpha | 127 | 8/16/2023 |
1.0.0.1 | 169 | 7/4/2023 |
1.0.0 | 168 | 7/4/2023 |