/// <summary>
        /// Obtém a Alimentacao pelo seu Código de Alimentacao
        /// </summary>
        /// <param name="codigoAlimentacao"></param>
        /// <returns></returns>
        public Alimentacao Obter(int CodigoAlimentacao)
        {
            SqlCommand comando = new SqlCommand("select * from Alimentacao where CodigoAlimentacao = @CodigoAlimentacao", base.Conectar());
            SqlParameter parametroCodigoAlimentacao = new SqlParameter("@CodigoAlimentacao", CodigoAlimentacao);
            parametroCodigoAlimentacao.DbType = System.Data.DbType.Int32;
            comando.Parameters.Add(parametroCodigoAlimentacao);

            SqlDataReader leitorDados = comando.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
            Alimentacao objAlimentacao = null;

            if (leitorDados.Read())
            {
                objAlimentacao = new Alimentacao();

                objAlimentacao.CodigoAlimentacao = CodigoAlimentacao;
                objAlimentacao.DiaSemana = leitorDados["DiaSemana"].ToString();
                objAlimentacao.Periodo = leitorDados["Periodo"].ToString();
                objAlimentacao.Horario = Convert.ToString(leitorDados["Horario"]);
                objAlimentacao.Diretiva = leitorDados["Diretiva"].ToString();

                //Pega os alimentos contidos na alimentação
                AlimentacaoAlimentoDados objAlimentacaoAlimentoDados = new AlimentacaoAlimentoDados();
                objAlimentacao.AlimentacaoAlimentoLista = objAlimentacaoAlimentoDados.ListarPorCodAlimentacao(objAlimentacao.CodigoAlimentacao.Value);
            }

            leitorDados.Close();
            leitorDados.Dispose();

            return objAlimentacao;
        }
        /// <summary>
        /// Retorna o nome do dia caso o dia informado possui alimentação
        /// </summary>
        /// <param name="diaSemana"></param>
        /// <returns></returns>
        public List<Alimentacao> ListarPorDia(string diaSemana)
        {
            SqlCommand comando = new SqlCommand("select * from Alimentacao where DiaSemana = @diaSemana order by Horario", base.Conectar());

            SqlParameter parametroDiaSemana = new SqlParameter("@diaSemana", diaSemana);
            parametroDiaSemana.DbType = System.Data.DbType.String;
            comando.Parameters.Add(parametroDiaSemana);

            SqlDataReader leitorDados = comando.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
            List<Alimentacao> objAlimentacaoLista = new List<Alimentacao>();
            Alimentacao objAlimentacao = null;

            while (leitorDados.Read())
            {
                objAlimentacao = new Alimentacao();

                objAlimentacao.CodigoAlimentacao = Convert.ToInt32(leitorDados["CodigoAlimentacao"]); 
                objAlimentacao.DiaSemana = leitorDados["DiaSemana"].ToString();
                objAlimentacao.Periodo = leitorDados["Periodo"].ToString();
                objAlimentacao.Horario = Convert.ToString(leitorDados["Horario"]);
                objAlimentacao.Diretiva = leitorDados["Diretiva"].ToString();

                //Pega os alimentos contidos na alimentação
                AlimentacaoAlimentoDados objAlimentacaoAlimentoDados = new AlimentacaoAlimentoDados();
                objAlimentacao.AlimentacaoAlimentoLista = objAlimentacaoAlimentoDados.ListarPorCodAlimentacao(objAlimentacao.CodigoAlimentacao.Value);

                objAlimentacaoLista.Add(objAlimentacao);
            }

            leitorDados.Close();
            leitorDados.Dispose();

            return objAlimentacaoLista;

        }
        /// <summary>
        /// Exclui uma Alimentacao pelo seu código
        /// </summary>
        public bool Excluir(int codigoAlimentacao)
        {
            AlimentacaoAlimentoDados objAlimentacaoAlimentoDados = new AlimentacaoAlimentoDados();
            bool execucao;

            //Exclui todas os Alimentos que uma Alimentação possui
            objAlimentacaoAlimentoDados.Excluir(codigoAlimentacao);

            //Exclui a Alimentação
            SqlCommand comando = new SqlCommand("delete from Alimentacao where CodigoAlimentacao = @CodigoAlimentacao", base.Conectar());

            SqlParameter parametroCodigoAlimentacao = new SqlParameter("@CodigoAlimentacao", codigoAlimentacao);
            parametroCodigoAlimentacao.DbType = System.Data.DbType.Int32;
            comando.Parameters.Add(parametroCodigoAlimentacao);

            execucao = Convert.ToBoolean(comando.ExecuteNonQuery());

            return execucao;
        }
        /// <summary>
        /// Este método salva a Alimentacao.
        /// </summary>
        /// <param name="objAlimentacao"></param>
        /// <returns></returns>
        public Alimentacao Salvar(Alimentacao objAlimentacao)
        {
            SqlCommand comando = new SqlCommand();
            comando.Connection = base.Conectar();

            if (!objAlimentacao.CodigoAlimentacao.HasValue)
            {
                comando.CommandText =
                    @"INSERT INTO Alimentacao (DiaSemana, Periodo, Horario, Diretiva)
                    VALUES (@diaSemana, @periodo, @horario, @diretiva)";
            }
            else
            {
                comando.CommandText =
                    @"UPDATE Alimentacao SET DiaSemana = @diaSemana,
                        Periodo = @periodo, Horario = @horario, Diretiva = @diretiva
                        WHERE (CodigoAlimentacao = @CodigoAlimentacao)";
            }

            comando.CommandType = System.Data.CommandType.Text;
            if (objAlimentacao.CodigoAlimentacao.HasValue)
            {
                SqlParameter parametroCodigo = new SqlParameter("@CodigoAlimentacao", objAlimentacao.CodigoAlimentacao.Value);
                parametroCodigo.DbType = System.Data.DbType.Int32;
                comando.Parameters.Add(parametroCodigo);
            }

            SqlParameter parametroDiaSemana = new SqlParameter("@diaSemana", objAlimentacao.DiaSemana);
            parametroDiaSemana.DbType = System.Data.DbType.String;

            SqlParameter parametroPeriodo = new SqlParameter("@periodo", objAlimentacao.Periodo);
            parametroPeriodo.DbType = System.Data.DbType.String;

            SqlParameter parametroHorario = new SqlParameter("@horario", objAlimentacao.Horario);
            parametroHorario.DbType = System.Data.DbType.String;

            SqlParameter parametroDiretiva = new SqlParameter("@diretiva", objAlimentacao.Diretiva);
            parametroDiretiva.DbType = System.Data.DbType.String;

            comando.Parameters.Add(parametroDiaSemana);
            comando.Parameters.Add(parametroPeriodo);
            comando.Parameters.Add(parametroHorario);
            comando.Parameters.Add(parametroDiretiva);

            comando.ExecuteNonQuery();

            //Pega o código gerado no banco de Alimentação
            //List<AlimentacaoAlimento> alimentacaoAlimentoLista = objAlimentacao.AlimentacaoAlimentoLista;

            if (!objAlimentacao.CodigoAlimentacao.HasValue)
            {
                Alimentacao AlimentacaoClone = ObterUltima();
                objAlimentacao.CodigoAlimentacao = AlimentacaoClone.CodigoAlimentacao;
            }

            //Salva os alimentos da Alimentação
            foreach (AlimentacaoAlimento item in objAlimentacao.AlimentacaoAlimentoLista)
            {
                item.CodigoAlimentacao = objAlimentacao.CodigoAlimentacao;
            }

            AlimentacaoAlimentoDados objAlimentacaoAlimentoDados = new AlimentacaoAlimentoDados();
            objAlimentacaoAlimentoDados.Salvar(objAlimentacao.AlimentacaoAlimentoLista);

            return objAlimentacao;

        }
        /// <summary>
        /// Obtém a última Alimentacao Inserida
        /// </summary>
        /// <param name="codigoAlimentacao"></param>
        /// <returns></returns>
        public Alimentacao ObterUltima()
        {
            SqlCommand comando = new SqlCommand(@"SELECT TOP (1) * FROM Alimentacao ORDER BY CodigoAlimentacao DESC", base.Conectar());

            SqlDataReader leitorDados = comando.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
            Alimentacao objAlimentacao = null;

            if (leitorDados.Read())
            {
                objAlimentacao = new Alimentacao();
                
                objAlimentacao.CodigoAlimentacao = Convert.ToInt32(leitorDados["CodigoAlimentacao"]);
                objAlimentacao.DiaSemana = leitorDados["DiaSemana"].ToString();
                objAlimentacao.Periodo = leitorDados["Periodo"].ToString();
                objAlimentacao.Horario = Convert.ToString(leitorDados["Horario"]);
                objAlimentacao.Diretiva = leitorDados["Diretiva"].ToString();

                AlimentacaoAlimentoDados objAlimentacaoAlimentoDados = new AlimentacaoAlimentoDados();
                objAlimentacao.AlimentacaoAlimentoLista = objAlimentacaoAlimentoDados.ListarPorCodAlimentacao(objAlimentacao.CodigoAlimentacao.Value);
            }

            leitorDados.Close();
            leitorDados.Dispose();

            return objAlimentacao;
        }