Facebook Pixel
Acessando Dados com Entity Framework no .NET Core

Acessando Dados com Entity Framework no .NET Core

Este artigo é parte da série:

Em primeiro lugar, tenha em mente que o .NET Core não traz a biblioteca Entity Framework instalada por padrão. Então, primeiro passo é instalá-la a partir do NuGet.

Instale o pacote “Microsoft.EntityFrameworkCore.Tools” e, como estamos trabalhando com SQL Server, instale também “Microsoft.EntityFrameworkCore.SqlServer”. Supostamente, seria necesário instalar o pacote “Microsoft.EntityFrameworkCore” também, mas isso não é necessário porque ele já instala junto com o “Microsoft.EntityFrameworkCore.SqlServer”.

Caso você tenha chegado nesta página agora, saiba que este exercício é uma continuação, então para entender o que está acontecendo, volte para o exercício anterior:

No SQL Server, crie um banco de dados. A tabela que iremos trabalhar será criada automaticamente pelo Entity Framework. Para fins deste exercício, o banco de dados vai se chamar “Treino01”. Se você está vindo do exercício anterior “Acessando Dados com ADO.NET no .NET Core”, o banco de dados já estará criado.

Para manipular o banco de dados, o EF (Entity Framework) precisa de uma classe baseada em DbContext. Vamos adicioná-la na pasta “Models” com o nome “UFdbContext.cs”. Neste primeiro momento, iremos apenas criar o objeto “UFLista” do tipo DbSet manipulando objetos da classe UF.

    public class UFdbContext : DbContext
    {
        public DbSet<UF> UFs { get; set; }
    }

E para que o DbContext UFs encontre o banco de dados, vamos informar a string de conexão sobrescrevendo o método OnConfiguring da DbContext:

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
    base.OnConfiguring(optionsBuilder);
    optionsBuilder.UseSqlServer(String de Conexão);
}

No final, a classe “UFdbContext” fica assim:

using Microsoft.EntityFrameworkCore;

namespace Treino_REST_02.Models
{
    public class UFdbContext : DbContext
    {
        public DbSet<UF> UFs { get; set; }

        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            base.OnConfiguring(optionsBuilder);
            var cnStr = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build().GetSection("ConnectionStrings")["cnMain"];
            optionsBuilder.UseSqlServer(cnStr);
        }
    }
}

Para esta etapa do projeto, vamos criar um novo controller, chamado “EFMetodoController” na pasta “Controllers”. Atente-se ao detalhe que é uma “API Controlller” e não “MVC Controller” conforme vem no padrão.

Agora vamos copiar para “EFMetodoController” toda a estrutura que fizemos em “DadosController” e substituir todas as designações “Dados” para “EF” para evitar conflito na hora de compilar o programa.

Segue o código já com os métodos implementados:

using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using Treino_REST_02.Models;

namespace Treino_REST_02.Controllers
{
    /// <summary>
    /// Exemplo de operações CRUD com Entity Framework
    /// </summary>
    [Route("api/[controller]")]
    [ApiController]
    public class EFMetodoController : ControllerBase
    {
        /// <summary>
        /// Config manipula as configurações em appsettings.json
        /// </summary>
        public readonly IConfiguration Config;

        /// <summary>
        /// UFs é uma lista de objetos do tipo UF
        /// </summary>
        public List<UF> UFs = new List<UF>();
        UFdbContext dbUF = new UFdbContext();

        /// <summary>
        /// Construtor da classe
        /// </summary>
        /// <param name="_config"></param>
        public EFMetodoController(IConfiguration _config) 
        {
            Config = _config;

            dbUF.Database.EnsureCreated();

            if(dbUF.UFs.Count() == 0)
            {
                var UF1 = new UF() { Nome = "AM", Capital = "Manaus" };
                var UF2 = new UF() { Nome = "PA", Capital = "Belém" };
                var UF3 = new UF() { Nome = "PI", Capital = "Teresina" };
                dbUF.UFs.Add(UF1);
                dbUF.UFs.Add(UF2);
                dbUF.UFs.Add(UF3);
                dbUF.SaveChanges();

            }
        }

        /// <summary>
        /// Lista todas as UFs do banco de dados
        /// </summary>
        /// <returns></returns>
        [HttpGet(Name = "ListaUF-EF")]
        [ProducesResponseType(StatusCodes.Status200OK)]
        public ActionResult<IEnumerable<UF>> ListaUF()
        {
            return Ok(dbUF.UFs.ToList());
        }

        /// <summary>
        /// Mostra dados de uma UF baseado no id
        /// </summary>
        /// <param name="IdUF">Id da UF</param>
        /// <returns></returns>
        [HttpGet("{IdUF:int}", Name = "MostraUF-EF")]
        [ProducesResponseType(200)]
        [ProducesResponseType(StatusCodes.Status400BadRequest)]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public ActionResult<UF> MostraUF(int IdUF)
        {
            var res = dbUF.UFs.Where(x => x.Id == IdUF).ToList();
            if (res == null || res.Count ==0)
            {
                return NotFound();
            }
            UF ret = res[0];
            return Ok(ret);
        }

        /// <summary>
        /// Adiciona uma nova UF ao banco de dados
        /// </summary>
        /// <param name="NovaUF"></param>
        /// <returns></returns>
        [HttpPost(Name = "Adiciona-EF")]
        [ProducesResponseType(StatusCodes.Status200OK)]
        [ProducesResponseType(StatusCodes.Status400BadRequest)]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public ActionResult<IEnumerable<UF>> AdicionaUF(UF NovaUF)
        {
            if (NovaUF.Id > 0)
            {
                return AtualizaUF(NovaUF.Id, NovaUF.Nome, NovaUF.Capital);
            }
            dbUF.UFs.Add(NovaUF);
            dbUF.SaveChanges();
            return ListaUF();
        }

        /// <summary>
        /// Altera todos os dados de uma UF baseado em um id
        /// </summary>
        /// <param name="IdUF">Id da UF que será alterada</param>
        /// <param name="NomeUF">Novo nome (sigla) da UF</param>
        /// <param name="CapitalUF">Novo nome da capital</param>
        /// <returns></returns>
        [HttpPut(Name = "Altera-EF")]
        [ProducesResponseType(StatusCodes.Status200OK)]
        [ProducesResponseType(StatusCodes.Status400BadRequest)]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public ActionResult<IEnumerable<UF>> AtualizaUF(int IdUF, string NomeUF, string CapitalUF)
        {
            var res = dbUF.UFs.Where(x => x.Id == IdUF).ToList();
            if (res == null || res.Count == 0)
            {
                return NotFound();
            }
            UF ret = res[0];
            ret.Nome = NomeUF;
            ret.Capital = CapitalUF;
            dbUF.UFs.Update(ret);
            dbUF.SaveChanges();
            return ListaUF();
        }

        /// <summary>
        /// Muda apenas a capital de uma UF baseado no nome da UF
        /// </summary>
        /// <param name="NomeUF">Nome da UF (sigla)</param>
        /// <param name="NovaCapital">Nome da nova capital</param>
        /// <returns></returns>
        [HttpPatch(Name = "MudaCapital-EF")]
        [ProducesResponseType(StatusCodes.Status200OK)]
        [ProducesResponseType(StatusCodes.Status400BadRequest)]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public ActionResult<IEnumerable<UF>> MudaCapital(string NomeUF, string NovaCapital)
        {
            var res = dbUF.UFs.Where(x => x.Nome == NomeUF).ToList();
            if (res == null || res.Count == 0)
            {
                return NotFound();
            }
            foreach (UF uf in res)
            {
                uf.Capital = NovaCapital;
                dbUF.UFs.Update(uf);
            }
            dbUF.SaveChanges();
            return ListaUF();
        }

        /// <summary>
        /// Elimina uma UF baseado no id
        /// </summary>
        /// <param name="DelId">Id da UF que será eliminada</param>
        /// <returns></returns>
        [HttpDelete(Name = "EliminaUF-EF")]
        [ProducesResponseType(StatusCodes.Status200OK)]
        [ProducesResponseType(StatusCodes.Status400BadRequest)]
        [ProducesResponseType(StatusCodes.Status404NotFound)]
        public ActionResult<IEnumerable<UF>> EliminaUF(int DelId)
        {
            var res = dbUF.UFs.Where(x => x.Id == DelId).ToList();
            if (res == null || res.Count == 0)
            {
                return NotFound();
            }
            UF ret = res[0];
            dbUF.UFs.Remove(ret);
            dbUF.SaveChanges();
            return ListaUF();
        }
    }
}

Execute o teste com o Swagger e perceba que agora o programa faz toda a manipulação de dados utilizando o Entity Framework.

Com isso concluímos toda a parte de programação da nossa API. Os próximos tópicos serão referentes à infraestrutura de execução do programa.

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *