Exferia/Exferia_KairosPro/Exferia_KairosPRO/2_Datos/KRSS_PausasFotos_Datos.cs

453 lines
19 KiB
C#

using Exferia_KairosPRO._1_Modelos.Herencia.Capas;
using System;
using System.Collections.Generic;
using System.Linq;
using Exferia_Aplicacion.General;
using Exferia_KairosPRO_EF;
using static Exferia_Aplicacion.General.Enumerados;
using System.Data.SqlClient;
using System.Data;
namespace Exferia_KairosPRO._2_Datos
{
public class KRSS_PausasFotos_Datos : ABS_Datos
{
#region Listado
public override List<dynamic> Obtener_Listado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
throw new NotImplementedException();
}
public override dynamic Obtener_RegistroListado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
{
throw new NotImplementedException();
}
protected override void ConsultaRellenar_Listado(KairosProEntities _dbcontext, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{ }
#endregion
#region Listado Secundario
public override List<dynamic> Obtener_Listado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
return null;
}
public override dynamic Obtener_RegistroListado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
{
return null;
}
protected override void ConsultaRellenar_Listado_Secundario(KairosProEntities _dbcontext, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
}
#endregion
#region F3
public override dynamic Obtener_F3(string _str_filtro, string _str_CampoBusqueda, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
throw new NotImplementedException();
}
public override dynamic Obtener_F3_PorId(long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
throw new NotImplementedException();
}
protected override void ConsultaRellenar_F3(KairosProEntities _dbcontext, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
}
#endregion
#region Obtener
private dynamic g_dnm_Modelo_Obtener = null;
public override dynamic Obtener(long _lng_id)
{
KairosProEntities obj_KairosProEntities = null;
try
{
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
string str_SQL =
" SELECT " +
nameof(KRSS_PausasFotos) + "." + nameof(KRSS_PausasFotos.id) + "," +
nameof(KRSS_PausasFotos) + "." + nameof(KRSS_PausasFotos.idPausa) + "," +
nameof(KRSS_PausasFotos) + "." + nameof(KRSS_PausasFotos.foto) +
" FROM " + nameof(KRSS_PausasFotos) +
" WHERE " +
nameof(KRSS_PausasFotos) + "." + nameof(KRSS_PausasFotos.idPausa) + "=@id ";
//Parametros
object[] arr_Parametros = new object[]
{
new SqlParameter("@id", _lng_id)
};
//Rellenar el Modelo
g_dnm_Modelo_Obtener = obj_KairosProEntities.Database.SqlQuery<KRSS_PausasFotos>(str_SQL, arr_Parametros).FirstOrDefault();
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_PausasFotos_Datos) + "/" + nameof(Obtener), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return g_dnm_Modelo_Obtener;
}
public override dynamic Obtener_Registro_PorCampo(string _str_CampoBusqueda, string _str_Filtro)
{
throw new NotImplementedException();
}
#endregion
#region MODELOS
#region Modelo Simple
private KRSS_PausasFotos g_mdl_KRSS_PausasFotos = null;
public KRSS_PausasFotos Obtener_Modelo_Por_Id(long _lng_id)
{
try
{
string str_SQL = Obtener_Consulta_Modelo() +
//WHERE
" WHERE " +
nameof(KRSS_PausasFotos) + "." + nameof(KRSS_PausasFotos.id) + "=@id ";
//Parametros
object[] arr_Parametros = new object[]
{
new SqlParameter("@id", _lng_id)
};
//Ejecutar y rellenar el modelo
Ejecutar_Consulta_Modelo(str_SQL,
arr_Parametros);
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_PausasFotos_Datos) + "/" + nameof(Obtener_Modelo_Por_Id), true);
}
return g_mdl_KRSS_PausasFotos;
}
private void Ejecutar_Consulta_Modelo(string _str_SQL,
object[] _arr_Parametros)
{
KairosProEntities obj_KairosProEntities = null;
try
{
//Conexion
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
//Rellenar el Modelo
g_mdl_KRSS_PausasFotos = obj_KairosProEntities.Database.SqlQuery<KRSS_PausasFotos>(_str_SQL, _arr_Parametros).FirstOrDefault();
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_PausasFotos_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
}
#endregion
#region Modelo Listado
private List<KRSS_PausasFotos> g_lst_KRSS_PausasFotos = null;
public List<KRSS_PausasFotos> Obtener_ModeloListado_Por_Pausa(long _lng_idPausa)
{
try
{
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
//Consulta
string str_SQL = Obtener_Consulta_Modelo() +
//WHERE
" WHERE " +
nameof(KRSS_PausasFotos) + "." + nameof(KRSS_PausasFotos.idPausa) + "=@idPausa ";
//Parametros
lst_Parametros.Add(new SqlParameter("@idPausa", _lng_idPausa));
object[] arr_Parametros = lst_Parametros.ToArray();
//Ejecutar y rellenar el listado
Ejecutar_Consulta_Modelo_Listado(str_SQL,
arr_Parametros);
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_PausasFotos_Datos) + "/" + nameof(Obtener_ModeloListado_Por_Pausa), true);
}
return g_lst_KRSS_PausasFotos;
}
#region Ejecutar Consulta
private void Ejecutar_Consulta_Modelo_Listado(string _str_SQL,
object[] _arr_Parametros)
{
KairosProEntities obj_KairosProEntities = null;
try
{
//Conexion
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
//Rellenar el modelo
g_lst_KRSS_PausasFotos = obj_KairosProEntities.Database.SqlQuery<KRSS_PausasFotos>(_str_SQL, _arr_Parametros).ToList();
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_PausasFotos_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo_Listado), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
}
#endregion
#endregion
private string Obtener_Consulta_Modelo()
{
return
" SELECT " +
nameof(KRSS_PausasFotos.id) + " , " +
nameof(KRSS_PausasFotos.idPausa) + " , " +
nameof(KRSS_PausasFotos.foto) +
" FROM " + nameof(KRSS_PausasFotos);
}
#endregion
#region Grabar
public override INTERNO_ValorDevuelto_Modelo Grabar(object _mdl_obj)
{
KairosProEntities obj_KairosProEntities = null;
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
try
{
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
KRSS_PausasFotos mdl_KRSS_PausasFotos_AGrabar = (KRSS_PausasFotos)_mdl_obj;
KRSS_PausasFotos mdl_KRSS_PausasFotos_DatosViejos = new KRSS_PausasFotos();
KRSS_PausasFotos mdl_KRSS_PausasFotos_Final = Obtener_Modelo_Por_Id(mdl_KRSS_PausasFotos_AGrabar.id);
if (mdl_KRSS_PausasFotos_Final != null)
{
//Tipo de Accion que se va a realizar
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_MODIFICAR;
//Datos viejos para la trazabilidar
Funciones.CopiarPropiedadesObjetos(mdl_KRSS_PausasFotos_Final, mdl_KRSS_PausasFotos_DatosViejos, false, false);
//Cargar los Datos del modelo
Funciones.CopiarPropiedadesObjetos(mdl_KRSS_PausasFotos_AGrabar, mdl_KRSS_PausasFotos_Final, false, false);
#region Update
string str_SQL_Update = " UPDATE " + nameof(KRSS_PausasFotos) +
" SET " +
nameof(KRSS_PausasFotos.idPausa) + "=@idPausa," +
nameof(KRSS_PausasFotos.foto) + "=@foto" +
" WHERE " +
nameof(KRSS_PausasFotos.id) + "=@id";
//Foto
SqlParameter obj_SqlParameter_Foto = new SqlParameter("@foto", SqlDbType.Binary);
if (mdl_KRSS_PausasFotos_Final.foto != null)
{ obj_SqlParameter_Foto.Value = mdl_KRSS_PausasFotos_Final.foto; }
else
{ obj_SqlParameter_Foto.Value = DBNull.Value; }
//Parametros
object[] arr_Parametros_Update = new object[]
{
new SqlParameter("@idPausa", mdl_KRSS_PausasFotos_Final.idPausa),
obj_SqlParameter_Foto,
new SqlParameter("@id", mdl_KRSS_PausasFotos_Final.id),
};
#endregion
//Update
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
//Id de la tabla
mdl_INTERNO_ValorDevuelto_Modelo.Id = mdl_KRSS_PausasFotos_Final.id;
}
else
{
mdl_KRSS_PausasFotos_Final = new KRSS_PausasFotos();
//Tipo de Accion que se va a realizar
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_INSERTAR;
//Cargar los Datos del modelo
Funciones.CopiarPropiedadesObjetos(mdl_KRSS_PausasFotos_AGrabar, mdl_KRSS_PausasFotos_Final, false, false);
#region INSERT
string str_SQL_Insert = " INSERT INTO " + nameof(KRSS_PausasFotos) +
" (" +
nameof(KRSS_PausasFotos.idPausa) + "," +
nameof(KRSS_PausasFotos.foto) +
" ) " +
" OUTPUT INSERTED." + nameof(KRSS_PausasFotos.id) +
" VALUES " +
" ( " +
"@idPausa," +
"@foto" +
" ) ";
//Foto
SqlParameter obj_SqlParameter_Foto = new SqlParameter("@foto", SqlDbType.Binary);
if (mdl_KRSS_PausasFotos_Final.foto != null)
{ obj_SqlParameter_Foto.Value = mdl_KRSS_PausasFotos_Final.foto; }
else
{ obj_SqlParameter_Foto.Value = DBNull.Value; }
//Parametros
object[] arr_Parametros_Insert = new object[]
{
new SqlParameter("@idPausa", mdl_KRSS_PausasFotos_Final.idPausa),
obj_SqlParameter_Foto
};
#endregion
//Id de la tabla
mdl_INTERNO_ValorDevuelto_Modelo.Id = obj_KairosProEntities.Database.SqlQuery<long>(str_SQL_Insert, arr_Parametros_Insert).Single();
}
//Grabar un registro de trazabilidad con los datos de la transaccion realizada
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRSS_PausasFotos), mdl_KRSS_PausasFotos_DatosViejos, mdl_KRSS_PausasFotos_Final, mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion, obj_KairosProEntities);
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_PausasFotos_Datos) + "/" + nameof(Grabar), true);
}
finally
{
//Finalizar transaccion
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return mdl_INTERNO_ValorDevuelto_Modelo;
}
#endregion
#region Borrar
public override INTERNO_ValorDevuelto_Modelo Borrar(long _lng_id)
{
KairosProEntities obj_KairosProEntities = null;
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_ELIMINAR;
try
{
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
// Ver si existe ######################################################################
KRSS_PausasFotos mdl_KRSS_PausasFotos = Obtener_Modelo_Por_Id(_lng_id);
//######################################################################################
if (mdl_KRSS_PausasFotos != null)
{
#region Delete
string str_SQL_Delete = " DELETE FROM " + nameof(KRSS_PausasFotos) +
" WHERE " +
nameof(KRSS_PausasFotos.id) + "=@id ";
//Parametros
object[] arr_Parametros_Delete = new object[]
{
new SqlParameter("@id", _lng_id)
};
#endregion
//Delete
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Delete, arr_Parametros_Delete);
// Grabar un registro de trazabilidad con los datos de la transaccion realizada.
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRSS_PausasFotos), null, mdl_KRSS_PausasFotos, G_ENUM_TIPOACCION.INT_ELIMINAR, obj_KairosProEntities);
}
// Devolver también el Objeto
mdl_INTERNO_ValorDevuelto_Modelo.Id = _lng_id;
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_PausasFotos_Datos) + "/" + nameof(Borrar), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return mdl_INTERNO_ValorDevuelto_Modelo;
}
public override INTERNO_ValorDevuelto_Modelo Borrar(object _mdl_obj)
{
throw new NotImplementedException();
}
public override INTERNO_ValorDevuelto_Modelo Borrar(long _lng_id, long _lng_idAuxiliar)
{
throw new NotImplementedException();
}
#endregion
}
}