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_FichajesFotos_Datos : ABS_Datos { #region Listado public override List Obtener_Listado(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { throw new NotImplementedException(); } public override dynamic Obtener_RegistroListado(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo, long _lng_id, List _lst_id) { throw new NotImplementedException(); } protected override void ConsultaRellenar_Listado(KairosProEntities _dbcontext, List _lst_CamposConRelacionABuscar, long _lng_id, List _lst_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { } #endregion #region Listado Secundario public override List Obtener_Listado_Secundario(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { return null; } public override dynamic Obtener_RegistroListado_Secundario(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo, long _lng_id, List _lst_id) { return null; } protected override void ConsultaRellenar_Listado_Secundario(KairosProEntities _dbcontext, List _lst_CamposConRelacionABuscar, long _lng_id, List _lst_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { } #endregion #region F3 public override dynamic Obtener_F3(string _str_filtro, string _str_CampoBusqueda, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { throw new NotImplementedException(); } public override dynamic Obtener_F3_PorId(long _lng_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { throw new NotImplementedException(); } protected override void ConsultaRellenar_F3(KairosProEntities _dbcontext, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _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_FichajesFotos) + "." + nameof(KRSS_FichajesFotos.id) + "," + nameof(KRSS_FichajesFotos) + "." + nameof(KRSS_FichajesFotos.idFichaje) + "," + nameof(KRSS_FichajesFotos) + "." + nameof(KRSS_FichajesFotos.foto) + " FROM " + nameof(KRSS_FichajesFotos) + " WHERE " + nameof(KRSS_FichajesFotos) + "." + nameof(KRSS_FichajesFotos.idFichaje) + "=@id "; //Parametros object[] arr_Parametros = new object[] { new SqlParameter("@id", _lng_id) }; //Rellenar el Modelo g_dnm_Modelo_Obtener = obj_KairosProEntities.Database.SqlQuery(str_SQL, arr_Parametros).FirstOrDefault(); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRSS_FichajesFotos_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_FichajesFotos g_mdl_KRSS_FichajesFotos = null; public KRSS_FichajesFotos Obtener_Modelo_Por_Id(long _lng_id) { try { string str_SQL = Obtener_Consulta_Modelo() + //WHERE " WHERE " + nameof(KRSS_FichajesFotos) + "." + nameof(KRSS_FichajesFotos.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_FichajesFotos_Datos) + "/" + nameof(Obtener_Modelo_Por_Id), true); } return g_mdl_KRSS_FichajesFotos; } 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_FichajesFotos = obj_KairosProEntities.Database.SqlQuery(_str_SQL, _arr_Parametros).FirstOrDefault(); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRSS_FichajesFotos_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } } #endregion #region Modelo Listado private List g_lst_KRSS_FichajesFotos = null; public List Obtener_ModeloListado_Por_Fichaje(long _lng_idFichaje) { try { List lst_Parametros = new List(); //Consulta string str_SQL = Obtener_Consulta_Modelo() + //WHERE " WHERE " + nameof(KRSS_FichajesFotos) + "." + nameof(KRSS_FichajesFotos.idFichaje) + "=@idFichaje "; //Parametros lst_Parametros.Add(new SqlParameter("@idFichaje", _lng_idFichaje)); 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_FichajesFotos_Datos) + "/" + nameof(Obtener_ModeloListado_Por_Fichaje), true); } return g_lst_KRSS_FichajesFotos; } #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_FichajesFotos = obj_KairosProEntities.Database.SqlQuery(_str_SQL, _arr_Parametros).ToList(); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRSS_FichajesFotos_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_FichajesFotos.id) + " , " + nameof(KRSS_FichajesFotos.idFichaje) + " , " + nameof(KRSS_FichajesFotos.foto) + " FROM " + nameof(KRSS_FichajesFotos); } #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_FichajesFotos mdl_KRSS_FichajesFotos_AGrabar = (KRSS_FichajesFotos)_mdl_obj; KRSS_FichajesFotos mdl_KRSS_FichajesFotos_DatosViejos = new KRSS_FichajesFotos(); KRSS_FichajesFotos mdl_KRSS_FichajesFotos_Final = Obtener_Modelo_Por_Id(mdl_KRSS_FichajesFotos_AGrabar.id); if (mdl_KRSS_FichajesFotos_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_FichajesFotos_Final, mdl_KRSS_FichajesFotos_DatosViejos, false, false); //Cargar los Datos del modelo Funciones.CopiarPropiedadesObjetos(mdl_KRSS_FichajesFotos_AGrabar, mdl_KRSS_FichajesFotos_Final, false, false); #region Update string str_SQL_Update = " UPDATE " + nameof(KRSS_FichajesFotos) + " SET " + nameof(KRSS_FichajesFotos.idFichaje) + "=@idFichaje," + nameof(KRSS_FichajesFotos.foto) + "=@foto" + " WHERE " + nameof(KRSS_FichajesFotos.id) + "=@id"; //Foto SqlParameter obj_SqlParameter_Foto = new SqlParameter("@foto", SqlDbType.Binary); if (mdl_KRSS_FichajesFotos_Final.foto != null) { obj_SqlParameter_Foto.Value = mdl_KRSS_FichajesFotos_Final.foto; } else { obj_SqlParameter_Foto.Value = DBNull.Value; } //Parametros object[] arr_Parametros_Update = new object[] { new SqlParameter("@idFichaje", mdl_KRSS_FichajesFotos_Final.idFichaje), obj_SqlParameter_Foto, new SqlParameter("@id", mdl_KRSS_FichajesFotos_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_FichajesFotos_Final.id; } else { mdl_KRSS_FichajesFotos_Final = new KRSS_FichajesFotos(); //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_FichajesFotos_AGrabar, mdl_KRSS_FichajesFotos_Final, false, false); #region INSERT string str_SQL_Insert = " INSERT INTO " + nameof(KRSS_FichajesFotos) + " (" + nameof(KRSS_FichajesFotos.idFichaje) + "," + nameof(KRSS_FichajesFotos.foto) + " ) " + " OUTPUT INSERTED." + nameof(KRSS_FichajesFotos.id) + " VALUES " + " ( " + "@idFichaje," + "@foto" + " ) "; //Foto SqlParameter obj_SqlParameter_Foto = new SqlParameter("@foto", SqlDbType.Binary); if (mdl_KRSS_FichajesFotos_Final.foto != null) { obj_SqlParameter_Foto.Value = mdl_KRSS_FichajesFotos_Final.foto; } else { obj_SqlParameter_Foto.Value = DBNull.Value; } //Parametros object[] arr_Parametros_Insert = new object[] { new SqlParameter("@idFichaje", mdl_KRSS_FichajesFotos_Final.idFichaje), obj_SqlParameter_Foto }; #endregion //Id de la tabla mdl_INTERNO_ValorDevuelto_Modelo.Id = obj_KairosProEntities.Database.SqlQuery(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_FichajesFotos), mdl_KRSS_FichajesFotos_DatosViejos, mdl_KRSS_FichajesFotos_Final, mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion, obj_KairosProEntities); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRSS_FichajesFotos_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_FichajesFotos mdl_KRSS_FichajesFotos = Obtener_Modelo_Por_Id(_lng_id); //###################################################################################### if (mdl_KRSS_FichajesFotos != null) { #region Delete string str_SQL_Delete = " DELETE FROM " + nameof(KRSS_FichajesFotos) + " WHERE " + nameof(KRSS_FichajesFotos.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_FichajesFotos), null, mdl_KRSS_FichajesFotos, 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_FichajesFotos_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 } }