VAGAS DE EMPREGO

balta.io balta.io
  • Cursos
  • Carreiras
  • Para sua Empresa
  • Livros
    • Background Services
    • Blazor com .NET 8
    • Segurança em APIs
    • Futuro do C# 12
    • Nullable Types
    • Clean Code
  • Blog

Seja Premium
balta.io

  • Cursos
  • Carreiras
  • Para sua Empresa
  • Agenda
  • Livros
    • Background Services
    • Blazor com .NET 8
    • Segurança em APIs
    • Futuro do C# 12
    • Nullable Types
    • Clean Code
  • Blog
  • Player
Seja Premium

Entre ou Cadastre-se

  • Home
  • Artigos
  • Criando um CRUD com Dapper


👉 Temos uma versão mais atualizada deste artigo no nosso novo Blog

Criando um CRUD com Dapper

Neste artigo vamos aprender a criar um CRUD com Dapper de uma forma simples e objetiva.

O que é o Dapper?

Dapper é uma biblioteca que facilita nossa vida na hora de consultar, editar, excluir e inserir dados em um banco, seja ele SQL Server, Postgres, MySQL ou qualquer outro.

O Dapper é uma extensão do pacote Microsoft.Data.SqlClient, uma biblioteca que faz parte de um ecossistema chamado ADO (Active Data Objects), ou simplificando, o alicerce de acesso à dados da Microsoft.

Desta forma, o Dapper apenas incrementa o Microsoft.Data.SqlClient, adicionando métodos como Execute e Query ao SqlConnection. Parece um bicho de sete cabeças, mas é bem simples, confere só 👇

O que é CRUD?

CRUD é a sigla para CREATE (CRIAR), READ (LER), UPDATE (ALTERAR) e DELETE (EXCLUIR), ou seja, as quatro operações básicas que temos nos bancos de dados.

O CRUD é conhecido como a "base" que todo programador(a) precisa saber. É quase certeza que em alguma entrevista de emprego você será desafiado a implementá-lo.

Ferramentas necessárias

Para seguir com este tutorial, você precisa do .NET e SQL Server instalados. Você pode encontrar artigos que detalham a instalação destas ferramentas aqui:

  • .NET
  • SQL Server

Criando o projeto

Vamos começar criando um projeto novo, utilizando o comando dotnet new conforme mostrado abaixo. Neste caso, estou utilizando o .NET 7.

dotnet new console -o DapperCrud
cd DapperCrud

Preparando o banco de dados

Antes de fazer qualquer operação, precisamos de um banco criado e pelo menos uma tabela. Não vou estender o artigo para este lado, então abaixo está o código para criação de tudo que precisamos.

CREATE DATABASE [DapperCrud]
GO

USE [DapperCrud]
GO

CREATE TABLE [Category] (
    [Id] INT NOT NULL PRIMARY KEY IDENTITY (1,1),
    [Title] NVARCHAR(80) NOT NULL,
    [Slug] VARCHAR(80) NOT NULL,
    [Description] TEXT
)

Basta executar o código acima no Azure Data Studio conectado ao seu SQL Server, seja ele no Docker ou via SQL Server Express (Somente Windows).

Adicionando o Dapper

Nosso próximo passo é adicionar os dois pacotes que precisamos para realizar operações no banco, conforme mostrado abaixo.

dotnet add package Microsoft.Data.SqlClient
dotnet add package Dapper

CRUD

Agora vamos ao que interessa, realizar as operações no banco. Para isto, precisamos primeiro abrir uma conexão, que pode ser feita via SqlConnection.

const string connectionString =
    "Server=localhost,1433;Database=DapperCrud;User ID=sa;Password=1q2w3e4r@#$;Trusted_Connection=False; TrustServerCertificate=True;";
await using (var connection = new SqlConnection(connectionString))
{
    // ... Operações
}

Note que já aproveitamos para definir nossa Connection String como uma constante. Lembre-se que ela não deve ficar exposta assim no código e sim ser configurada via Application Settings como vemos no curso Fundamentos do Azure, Git, GitHub e DevOps.

Outro ponto é o uso do await antes do using. Este uso é opcional, mas aqui vou mostrar os métodos sendo executados de forma assíncrona. É apenas uma demonstração, não muda nada o uso do async/await neste cenário.

Create

Sendo o Dapper uma extensão do Microsoft.Data.SqlClient, temos a adição do método ExecuteAsync no objeto connection que abrimos no passo anterior. Este método é bem simples e espera apenas dois parâmetros.

await connection.ExecuteAsync("INSTRUÇÃO SQL", PARAMETROS);

Dado que já temos o ID como auto-increment na tabela Category, podemos informar apenas os campos restantes, tendo como resultado a seguinte instrução SQL.

INSERT INTO 
    [Category] 
VALUES(
    @title, 
    @slug, 
    @description)

IMPORTANTE Nunca utilize concatenação de strings nas instruções SQL, isto pode resultar em um SQL Injection. Utilize sempre PARÂMETROS, como os demonstrados acima com @ (Não precisa de aspas duplas nem simples).

Embora o C# seja uma linguagem fortemente tipada, podemos utilizar tipos anônimos para otimizar o tempo. Tem a opção de records também, mas vou focar aqui nos tipos anônimos pela praticidade.

await using (var connection = new SqlConnection(connectionString))
{
    await connection.ExecuteAsync("INSERT INTO [Category] VALUES(@title, @slug, @description)",
        new
        {
            title = "Backend",
            slug = "backend",
            description = "Aprenda tudo sobre backend nesta carreira completa."
        });
}

Pronto, temos um trecho de código que insere uma linha em um banco de dados SQL Server com Dapper de uma forma extremamente simples e eficiente. Ao rodar a aplicação, meu resultado foi este.

1	Backend	backend	Aprenda tudo sobre backend nesta carreira completa.

ExecuteScalar

Apenas para intuito de curiosidade, existe uma sintaxe no SQL Server que retornar o Id do objeto que acabou de ser inserido. Basta utilizar o scope_identity conforme mostrado abaixo.

SELECT CAST(scope_identity() AS INT)

Podemos combinar o scope_identity com o ExecuteScalarAsync<int> do Dapper e retornar o Id da linha que acabamos de inserir.

await using (var connection = new SqlConnection(connectionString))
{
    var id = await connection.ExecuteScalarAsync<int>("INSERT INTO [Category] VALUES(@title, @slug, @description);SELECT CAST(scope_identity() AS INT)",
        new
        {
            title = "Backend",
            slug = "backend",
            description = "Aprenda tudo sobre backend nesta carreira completa."
        });
    
    Console.WriteLine(id);
}

Read

Existem várias formas de ler registros do banco, dentre elas estão o QueryAsync, QueryAsync<T>, QueryFirstOrDefaultAsync e QueryFirstOrDefaultAsync<T> conforme mostrado abaixo.

// Lista todas as categorias
var categories = await connection.QueryAsync("SELECT [Id], [Title], [Slug], [Description] FROM [Category]");
foreach (var category in categories) 
    Console.WriteLine(category.Title);

// Lista a categoria 1
var category = await connection.QueryFirstOrDefaultAsync("SELECT [Id], [Title], [Slug], [Description] FROM [Category] WHERE [Id]=@id", new { id = 1 });
Console.WriteLine(category.Title);

Caso queira tipa explicitamente o retorno dos resultados, podemos utilizar um Struct, Class ou Record. Neste caso vou usar um Record pela simplicidade.

public record Category(int Id, string Title, string Slug, string Description);
// Lista todas as categorias
var categories = await connection.QueryAsync<Category>("SELECT [Id], [Title], [Slug], [Description] FROM [Category]");
foreach (var category in categories) 
    Console.WriteLine(category.Title);

// Lista a categoria 1
var category = await connection.QueryFirstOrDefaultAsync<Category>(
    "SELECT [Id], [Title], [Slug], [Description] FROM [Category] WHERE [Id]=@id", 
    new { id = 1 });
Console.WriteLine(category.Title);

Update

Os métodos a seguir são bem simples e seguem a mesma linha do CREATE, utilizando o método ExecuteAsync para executar a instrução SQL.

await connection.ExecuteAsync(
    "UPDATE [Category] SET [Title]=@title WHERE [Id]=@id",
    new { id = 1, title = "Frontend" });

Delete

Por fim, o DELETE é ainda mais simples, sendo necessário apenas informar o ID do objeto a ser excluído.

await connection.ExecuteAsync(
    "DELETE FROM [Category] WHERE [Id]=@id",
    new { id = 1 });

Quer aprender mais sobre Dapper?

  • Masterclass GRAUITA - Dapper VS Entity Framework
  • CURSO COMPLETO - Acesso à dados com Dapper e SQL Server
  • CURSO COMPLETO - Entity Framework e SQL Server
  • CARREIRA COMPLETO - .NET do ZERO ao PRO

Populares

Priority Queue

Priority Queue ou fila prioritária é um tipo de lista inclusa no C# 10 que permite que seus itens...


Implicit Operators no C#

Implicit Operators permitem adicionar comportamentos de conversão a objetos Built In ou complexos...


ASP.NET 5 – Autenticação e Autorização com Bearer e JWT

Este artigo atualmente utiliza a versão 5.0.0-rc.1 do ASP.NET/.NET, o que significa que ainda não...


Clean Code - Guia e Exemplos

Saiba como manter seu código limpo (Clean Code) seguindo algumas práticas sugeridas pelo Robert C...


Git e GitHub - Instalação, Configuração e Primeiros Passos

Git é um sistema de controle de versões distribuídas, enquanto GitHub é uma plataforma que tem o ...


Compartilhe este artigo



Conheça o autor

André Baltieri

André Baltieri

Microsoft MVP

Me dedico ao desenvolvimento de software desde 2003, sendo minha maior especialidade o Desenvolvimento Web. Durante esta jornada pude trabalhar presencialmente aqui no Brasil e Estados Unidos, atender remotamente times da ?ndia, Inglaterra e Holanda, receber 8x Microsoft MVP e realizar diversas consultorias em empresas e projetos de todos os tamanhos.





3.119

Aulas disponíveis

291

horas de conteúdo

76.349

Alunos matriculados

52.918

Certificados emitidos





Comece de graça agora mesmo!

Temos mais de 21 cursos totalmente de graça e todos com certificado de conclusão.

Começar


Prefere algo mais Premium?

Conheça nossos planos



Premium anual

Compra única, parcelada em até
12x no cartão de crédito


12x R$

99

,79

=R$ 1.197,44
  • 1 ano de acesso
  • Acesso à todo conteúdo
  • Emissão de Certificado
  • Tira Dúvidas Online
  • 66 cursos disponíveis
  • 10 carreiras disponíveis
  • 161 temas de tecnologia
  • Conteúdo novo todo mês
  • Encontros Premium

Começar agora

Política de privacidade



Precisa de ajuda?

Dúvidas frequentes



  • Posso começar de graça?

    Sim! Basta criar sua conta gratuita no balta.io e começar seus estudos. Nós contamos com diversos cursos TOTALMENTE gratuitos e com certificado de conclusão.

  • Vou ter que pagar algo?

    Nós temos cursos gratuitos e pagos, porém você não precisa informar nenhum dado de pagamento para começar seus estudos gratuitamente conosco. Os cursos gratuitos são completos e com certificado de conclusão, você não paga nada por eles.

    Porém, caso queira algo mais Premium , você terá acesso à diversos benefícios que vão te ajudar ainda mais em sua carreira.

  • Por onde devo começar?

    Siga SEMPRE as nossas Carreiras , elas vão te orientar em todos os sentidos. Os cursos já estão organizados em categorias e carreiras para facilitar seu aprendizado.
    Nossa sugestão para aprendizado é começar pelo Backend e seguindo para Frontend e Mobile.

    • Backend
    • Frontend
    • Mobile

  • Os cursos ensinam tudo que preciso?

    Nenhum curso no mundo vai te ensinar tudo, desculpa ser sincero! Os cursos são uma base, eles fornecem por volta de 30% do que você precisa aprender, o resto é com você, com dedicação e MUITA prática.

  • O que eu devo estudar?

    Java ou .NET? Angular ou React? Xamarin ou Flutter? A resposta é simples e direta: "Você já sabe o básico?"

    Se você ainda não sabe BEM o básico, ou seja, os fundamentos, OOP, SOLID, Clean Code, está perdendo tempo estudando Frameworks ou até coisas mais avançadas como Docker. Foque nos seus objetivos primeiro.
    Agora se você está indeciso sobre qual Framework estudar, a boa notícia é que o mercado neste momento está bem aquecido e você tem várias oportunidade. Desta forma o que levaríamos em conta para tomar esta decisão seria:

    • Já sei o básico
    • O Framework/Tecnologia tem mercado onde eu estou (região)
    • O Framework/Tecnologia é utilizado em uma empresa onde quero atual
    • O Framework/Tecnologia resolve meu problema
    • Eu gosto de utilizar o Framework/Tecnologia

  • Estou pronto para estudar no balta.io?

    Com certeza! O primeiro passo é começar e você pode fazer isto agora mesmo!

    Começar de graça

Ainda tem dúvidas?





Assine nosso Newsletter

Receba em primeira mão todas as nossas novidades.

Cadastrar


balta.io

Sobre

  • Como funciona?
  • Seja Premium
  • Agenda
  • Blog
  • Todos os cursos

Cursos

  • Frontend
  • Backend
  • Mobile
  • Fullstack

Suporte

  • Termos de uso
  • Privacidade
  • Cancelamento
  • Central de ajuda

Redes Sociais

  • Telegram
  • Facebook
  • Instagram
  • YouTube
  • Twitch
  • LinkedIn
  • Discord