453 lines
19 KiB
C#
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_FichajesFotos_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_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<KRSS_FichajesFotos>(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<KRSS_FichajesFotos>(_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<KRSS_FichajesFotos> g_lst_KRSS_FichajesFotos = null;
|
|
|
|
public List<KRSS_FichajesFotos> Obtener_ModeloListado_Por_Fichaje(long _lng_idFichaje)
|
|
{
|
|
try
|
|
{
|
|
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
|
|
|
|
//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<KRSS_FichajesFotos>(_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<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_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
|
|
|
|
}
|
|
}
|