示例#1
0
        /// <summary>
        /// Elimina el grupo y las personas en una sola transacción. Si en algún momento del proceso falla, se hace rollback de todo
        /// </summary>
        /// <param name="oGrupo"></param>
        /// <param name="personas"></param>
        /// <returns></returns>
        public void DeleteGrupoFull(Grupo oGrupo)
        {
            SqlConnection oConn = new SqlConnection(ConfigurationManager.ConnectionStrings["CONEXION"].ConnectionString);

            oConn.Open();
            SqlTransaction oTran = oConn.BeginTransaction();

            try
            {
                // Elimina el Grupo
                using (GrupoDataAccess oGrupoDataAccess = new GrupoDataAccess())
                {
                    oGrupo = oGrupoDataAccess.Delete(oConn, oTran, oGrupo);
                }

                // Elimina a las personas del grupo
                using (GrupoPersonaBusiness oGrupoPersonaBusiness = new GrupoPersonaBusiness())
                {
                    oGrupoPersonaBusiness.DeleteGrupoPersona(oConn, oTran, (int)oGrupo.IdGrupo);
                }

                oTran.Commit();
            }
            catch (Exception e)
            {
                oTran.Rollback();
                throw new Exception(e.Message);
            }
            finally
            {
                oConn.Close();
                oTran.Dispose();
            }
        }
示例#2
0
        public List <GrupoConsulta> GetListByFilter(GrupoFilter oGrupoFilter)
        {
            // Busco los grupos
            using (GrupoDataAccess oGrupoDataAccess = new GrupoDataAccess())
            {
                List <GrupoConsulta> oGrupos = null;
                DataSet ds = oGrupoDataAccess.GetListByFilter(oGrupoFilter);

                if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
                {
                    oGrupos = GrupoConsulta.GetFromDS(ds);

                    // Busco las personas de cada grupo
                    foreach (GrupoConsulta oGrupoConsulta in oGrupos)
                    {
                        using (GrupoPersonaBusiness oGrupoPersonaBusiness = new GrupoPersonaBusiness())
                        {
                            List <GrupoPersona> oGrupoPersona = oGrupoPersonaBusiness.GetListByFilter(new GrupoPersona()
                            {
                                IdGrupo = oGrupoConsulta.IdGrupo
                            });
                            if (oGrupoPersona != null)
                            {
                                oGrupoConsulta.Personas = oGrupoPersona.Select(x => (int)x.IdPersona).ToList <int>();
                            }
                        }
                    }

                    return(oGrupos);
                }
            }
            return(null);
        }
示例#3
0
        /// <summary>
        /// Inserto el grupo y las personas en una sola transacción. Si en algún momento del proceso falla, se hace rollback de todo
        /// </summary>
        /// <param name="oGrupo"></param>
        /// <param name="personas"></param>
        /// <returns></returns>
        public Grupo InsertGrupoFull(Grupo oGrupo, List <int> personas)
        {
            // Busco si existe la compania - Si no existe, creo Excepcion
            using (CompaniaBusiness oCompaniaBusiness = new CompaniaBusiness())
            {
                if (oCompaniaBusiness.GetCompaniaById(new Compania()
                {
                    IdCompania = oGrupo.IdCompania
                }) == null)
                {
                    throw new Exception(string.Format("La compañia con id {0} no existe", oGrupo.IdCompania));
                }
            }

            SqlConnection oConn = new SqlConnection(ConfigurationManager.ConnectionStrings["CONEXION"].ConnectionString);

            oConn.Open();
            SqlTransaction oTran = oConn.BeginTransaction();

            try
            {
                // Inserto el Grupo
                using (GrupoDataAccess oGrupoDataAccess = new GrupoDataAccess())
                {
                    oGrupo = oGrupoDataAccess.Insert(oConn, oTran, oGrupo);
                }

                // Obtengo la lista de objetos de GrupoPersonas
                List <GrupoPersona> oListGrupoPersona = this.GetGrupoPersonas(personas, oGrupo.IdGrupo, oGrupo.UsuarioAlta);

                // Inserto a las personas del grupo
                using (GrupoPersonaBusiness oGrupoPersonaBusiness = new GrupoPersonaBusiness())
                {
                    oGrupoPersonaBusiness.InsertGrupoPersona(oConn, oTran, oListGrupoPersona, (int)oGrupo.IdGrupo);
                }

                oTran.Commit();
            }
            catch (Exception e)
            {
                oTran.Rollback();
                throw new Exception(e.Message);
            }
            finally
            {
                oConn.Close();
                oTran.Dispose();
            }

            return(this.GetGrupoById(oGrupo));
        }
示例#4
0
        /// <summary>
        /// Actualiza el grupo y las personas en una sola transacción. Si en algún momento del proceso falla, se hace rollback de todo
        /// </summary>
        /// <param name="oGrupo"></param>
        /// <param name="personas"></param>
        /// <returns></returns>
        public Grupo UpdateGrupoFull(Grupo oGrupo, List <int> personas)
        {
            SqlConnection oConn = new SqlConnection(ConfigurationManager.ConnectionStrings["CONEXION"].ConnectionString);

            oConn.Open();
            SqlTransaction oTran = oConn.BeginTransaction();

            try
            {
                // Actualizo el Grupo
                using (GrupoDataAccess oGrupoDataAccess = new GrupoDataAccess())
                {
                    oGrupo = oGrupoDataAccess.Update(oConn, oTran, oGrupo);
                }

                // Obtengo la lista de objetos de GrupoPersonas
                List <GrupoPersona> oListGrupoPersona = this.GetGrupoPersonas(personas, oGrupo.IdGrupo, oGrupo.UsuarioUltModif);

                // Inserto a las personas del grupo
                using (GrupoPersonaBusiness oGrupoPersonaBusiness = new GrupoPersonaBusiness())
                {
                    oGrupoPersonaBusiness.UpdateGrupoPersona(oConn, oTran, oListGrupoPersona, (int)oGrupo.IdGrupo);
                }

                oTran.Commit();
            }
            catch (Exception e)
            {
                oTran.Rollback();
                throw new Exception(e.Message);
            }
            finally
            {
                oConn.Close();
                oTran.Dispose();
            }

            return(this.GetGrupoById(oGrupo));
        }