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
  • Começando com SQL Server na prática - Parte 2 (Consulta avançada, edição e remoção de dados)


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

Começando com SQL Server na prática - Parte 2 (Consulta avançada, edição e remoção de dados)

Aprenda na prática a desenvolver consultas complexas, manipular e deletar informações no Microsoft SQL Server.

Sumário

  • Introdução
  • Continuando de onde paramos
  • Consultas complexas
    • Criando a view
  • Editando registros
  • Editando Colunas
  • Editando Tabelas
  • Considerações finais
  • Cursos relacionados
  • Referências

Introdução

Este artigo é uma continuação do artigo Começando com SQL Server na pratica (Estrutura, inserção e consulta)) e como descrito no título a proposta é que a pessoa lendo o artigo entenda na prática como funciona o Microsoft Sql Server.

É recomendado que caso no caso da pessoa lendo o artigo esteja começando volte e leia o artigo anterior. Caso já tenha lido e/ou tenha conhecimento nas instruções anteriores. Esta leitura é a parte final deste artigo.

Continuando de onde paramos

Anteriormente fizemos o registro de uma nova categoria, grupo de palestras e um usuário. Também atribuimos o nosso usuário a um grupo. Agora iremos concluir os registros com a criação de um evento. Este é o código usado para registrarmos o evento em nossa base de dados:

BEGIN TRANSACTION
    INSERT INTO [evento] VALUES (
        NEWID(),
        'Persistênca de dados',
        'Uma visão detalhada do processo de persistência.',
        '6ccbe492-8c8c-40fc-8039-c3759b9ab69b',
        GETDATE(),
        GETDATE()+7,
        'e83848d3-cffd-4445-bf7a-2996583e834a',
        0,
        NULL
    )
COMMIT

NOTA I: Sempre que a sequência dos dados que serão inseridos segue a sequência de cascata da tabela ao qual ele está relacionado. Também note que na data do evento (a data em que ele acontecerá) pegamos a data atual e adicionamos 7 dias.

Consultas complexas

Agora faremos uma consulta para conferir se as informações que acabamos de registrar estão corretas, porém iremos pegar apenas determinados campos e antes de exibir vamos renomear as colunas de exibição para melhor entendermos os resultados. Ficando assim:

SELECT TOP (1)
        [evento].[Id] AS 'Id Evento',
        [evento].[Titulo] AS 'Evento',
        [evento].[IdCategoria] AS 'Id Categoria',
        [categoria].[Nome] AS 'Categoria',
        [evento].[DataEvento] AS 'Data do evento',
        [evento].[IdOrganizador] AS 'Id Organizador',
        [usuario].[NomeCompleto] AS 'Organizador'
    FROM [eventos].[dbo].[evento]
        INNER JOIN [categoria] ON [categoria].[Id] = [evento].[IdCategoria]
        INNER JOIN [usuario] ON [usuario].[Id] = [evento].[IdOrganizador]
WHERE [Titulo] LIKE '%dados'

NOTA II: Veja que ao usarmos o where para pesquisar por parte do título do evento, utilizamos o símbolo de porcentagem apenas antes da palavra chave. Assim estamos indicando que nossa consulta deverá retornar apenas eventos que tenham como final do título a palavra "dados".

Já sabemos como pegar determinados campos e exibir em uma consulta, também sabemos como renomear colunas antes de exibir e sabemos a utilidade do INNER JOIN. O que vamos aprender agora é como deixar registrado em nosso banco que quando quisermos pesquisar um evento e retornar com ele as informações básicas do organizador e categoria, iremos apenas chamar uma VIEW e passar o parametro de busca.

Criando a view

CREATE VIEW [buscarEvento] AS
SELECT TOP (1)
        [evento].[Id] AS 'Id Evento',
        [evento].[Titulo] AS 'Evento',
        [evento].[IdCategoria] AS 'Id Categoria',
        [categoria].[Nome] AS 'Categoria',
        [evento].[DataEvento] AS 'Data do evento',
        [evento].[IdOrganizador] AS 'Id Organizador',
        [usuario].[NomeCompleto] AS 'Organizador'
    FROM [eventos].[dbo].[evento]
        INNER JOIN [categoria] ON [categoria].[Id] = [evento].[IdCategoria]
        INNER JOIN [usuario] ON [usuario].[Id] = [evento].[IdOrganizador]

NOTA III: Veja que precisamos apenas adicionar a linha CREATE VIEW [] AS antes do nosso SELECT e removemos a condição WHERE. Desta forma deixamos um padrão de visualização salvo e para consultar estes dados agora em vez de escrever todos os dados como fizemos no primeiro exemplo. Iremos apenas chamar a view e acrescentar nossa condição:

SELECT * FROM [buscarEvento] WHERE [Evento] LIKE '%dados'

O Resultado será o mesmo da nossa consulta anterior. Mas aonde fica armazenada esta view? Bem, caso queira saber, as view podem ser encontradas em uma pasta abaixo das tabelas no nosso banco de dados:

Editando registros

Imagine que você deseja modificar a descriçao de um evento. Neste caso utilizamos o UPDATE e no exemplo abaixo vocÊ pode acompanhar como utilizar ele para editar a descrição de um evento registrado:

BEGIN TRANSACTION
    UPDATE [evento]
    SET
        [Descricao] = 'Aguardando descrição' 
    WHERE [Titulo] LIKE '%dados'
    GO
ROLLBACK

PS: Lembre sempre de modificar o ROLLBACK para COMMIT para que as mudanças sejam aplicadas no banco, do contrário o comando será executado apenas como teste e os dados voltaram ao valor que estavam antes da consulta.

Editando Colunas

Agora digamos que você deseja tornar o campo "Descrição" obrigatório na tabela de eventos. Então será necessário utilizar o ALTER TABLE da seguinte forma:

BEGIN TRANSACTION
    ALTER TABLE [evento]
    ALTER COLUMN [Descricao] VARCHAR(150) NOT NULL;
ROLLBACK

Se quisermos remover uma coluna da tabela podemos fazer da seguinte forma:

BEGIN TRANSACTION
    ALTER TABLE [evento]
    DROP COLUMN [Link];
ROLLBACK

E teriamos retirado a coluna "Link" da nossa tabela de Eventos.

Para adicionar uma coluna podemos utilizar o ADD

BEGIN TRANSACTION
    ALTER TABLE [evento]
    ADD [Link] VARCHAR(255) NULL;
ROLLBACK

E trariamos de volta a existência do campo "Link".

Assim acabamos de reduzir o número máximo de caracteres na descriçao do evento de 200 para 150 e implementamos a obrigatoriedade do campo com o NOT NULL.

Editando Tabelas

Considerações finais

Passamos pela conexão e criação do banco. Estruturação, inserção e consulta dos dados. Na proxíma parte iremos aprender a fazer consultas avançadas, desenvolver stored procedures, editar informações dos registros e tabelas e excluir registros, tabelas e até mesmo bancos de dados inteiros.

NOTA IV: Os contextos exibidos neste artigo podem ser desenvolvidos facilmente. Caso o leitor sinta vontade e/ou necessidade de entender mais detalhadamente os comandos, instruções e ferramentas utilizadas é recomendado acompanhar o curso Fundamentos do SQL Server.

Cursos relacionados

Fundamentos do SQL Server

Referências

Documentação do Microsoft SQL

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

Brewerton Santos

Brewerton Santos

Backend | Cloud | Community

Desenvolvedor de software e entusiasta de tecnologia da informação. Estruturando a carreira com base em tecnologias Microsoft e desenvolvimento open source.





3.133

Aulas disponíveis

292

horas de conteúdo

76.461

Alunos matriculados

53.012

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
  • 67 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