==== Disciplinas para Graduação ==== === DCC011 - Introdução a Bancos de Dados -- Primeiro Semestre de 2023 === == PLANO DE ENSINO == Plano de ensino [[https://virtual.ufmg.br/20231/mod/resource/view.php?id=88676|PDF (no Moodle)]] 2023/1 **Objetivos:** Introduzir os fundamentos que permitam ao aluno adquirir o domínio básico da tecnologia de banco de dados. **Ementa:** Conceitos básicos de banco de dados. Modelos de dados e linguagens. Projeto de bancos de dados. Novas tecnologias e aplicações de banco de dados. ==Material de apoio== **Livro** * Elmasri, R.; Navathe, S. B. Sistemas de Banco de Dados. 7ª. ed. Pearson, 2019. Outras edições podem ser usadas, inclusive edições em inglês. [[https://wps.pearsoned.com/aw_elmasri_fundatasys_7/|Student resources (em inglês)]] **Artigos selecionados** * Chen, P. (1976) The entity-relationship model — toward a unified view of data. ACM Transactions on Database Systems 1(1) (March 1976), 9–36. [[https://doi.org/10.1145/320434.320440|PDF]] * Codd, E. F. (1970) A Relational Model of Data for Large Shared Data Banks. Communications of the ACM 13(6):377-387. [[https://dl.acm.org/doi/pdf/10.1145/362384.362685|PDF]] [[https://dl.acm.org/doi/pdf/10.5555/77708|Livro online de Codd sobre o modelo relacional]] **Slides e material de aula:** vide abaixo ==Recursos online== * [[http://aqui.io/geosql | GeoSQL+]] disponível por meio do [[http://labcsx.dcc.ufmg.br/ | Interdisciplinary Computer Science Lab]] da UFMG. Outros produtos e protótipos do LabCS+x estão disponíveis em [[http://aqui.io | aqui.io]]. * [[http://sqlfiddle.com/ | SQL Fiddle ]] ==Software recomendado== * [[http://www.postgresql.org | PostgreSQL ]] * Downloads: [[https://www.postgresql.org/download/|postgresql]] * Guias de instalação: [[https://www.devmedia.com.br/instalando-postgresql/23364|Windows]] [[https://www.hostinger.com.br/tutoriais/instalar-postgresql-ubuntu|Ubuntu]] [[https://www.postgresql.org/download/macosx/|Mac]] * Video sobre pgAdmin, no contexto da disciplina * [[http://draw.io | Draw.io ]] * Usar o template "Entity-Relationship Diagram". Há também um template para UML. ==Datasets== Banco de dados de comércio exterior: script de criação de tabelas e carga de dados [[https://virtual.ufmg.br/20202/mod/resource/view.php?id=201456|No Moodle da disciplina]] Banco de dados Cinema/IMDb - [[https://www.dropbox.com/s/cbfuvezgt8jhj6c/cinemicro.sql.zip?dl=0|Backup do BD cinemicro]] == Unidades == **Playlist das aulas no YouTube:** [[https://www.youtube.com/playlist?list=PLPF3oU9gY8Cna2dM8Rw1OMfvBEKtsMRU7|Playlist]] 1. **Introdução** * Apresentação da disciplina (versão 2021/2) [[https://virtual.ufmg.br/20221/mod/resource/view.php?id=74981|Slides]] [[https://www.youtube.com/watch?v=b_71EFBUGko|Video 2021/2]] * Conceitos básicos * Parte 1 - conceitos [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD01a Conceitos.pdf|Slides]] [[https://www.youtube.com/watch?v=TksC9xRF-8o|Video]] * Parte 2 - memória [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD01b Conceitos - disco.pdf|Slides]] [[https://www.youtube.com/watch?v=KDihGJ4b0E8|Video]] * Parte 3 - modelos de dados e arquitetura de SGBD [[https://www.dropbox.com/s/h7c1f40rwmb19rr/IBD01c%20Modelos%20e%20Arquitetura.pdf?dl=0|Slides]] [[https://www.youtube.com/watch?v=J0HKxZ_eGvw|Video]] 2. **Modelos de Dados e Linguagens** * Modelo entidade-relacionamento * Parte 1 - Entidades [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD02a ER entidades.pdf|Slides]] [[https://www.youtube.com/watch?v=J3iPZ65HzDc|Video]] * Parte 2 - Relacionamentos [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD02b ER relacionamentos.pdf|Slides]] [[https://www.youtube.com/watch?v=lXNT4LjgyKU|Video]] * Parte 3 - Exemplos [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD02c ER exemplos.pdf|Slides]] [[https://www.youtube.com/watch?v=M2BQ1uzARYo|Video]] * Modelo ER: extensões e tópicos adicionais * ER estendido [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD03a ER estendido.pdf|Slides]] [[https://www.youtube.com/watch?v=HXgNwlPa964|Video]] * ER conceitos adicionais [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD03b ER conceitos adicionais.pdf|Slides]] [[https://www.youtube.com/watch?v=WOGnn_feLm4|Video]] * Notações alternativas de ER e ERE [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD03c ER-ERE notacoes alternativas.pdf|Slides]] [[https://www.youtube.com/watch?v=n_A_PSOmqF8|Video]] * UML [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD04 UML.pdf|Slides]] [[https://www.youtube.com/watch?v=weqWbgHTlPs|Video]] * Modelo Relacional * Modelo Relacional [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD05a Modelo Relacional.pdf|Slides]] [[https://www.youtube.com/watch?v=gmPZ5hBE6Jk|Video]] * Modelo Relacional: avançado [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD05b Modelo Relacional avancado.pdf|Slides]] [[https://www.youtube.com/watch?v=1vTQo9k4f1k|Video]] * Álgebra Relacional [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD05c Algebra Relacional parte 1.pdf|Slides parte 1]] [[https://www.dropbox.com/s/e1utekq7x5unz5w/IBD05d%20Algebra%20Relacional%20parte%202.pdf?dl=0|Slides parte 2]] [[https://www.youtube.com/watch?v=1aqM6GXyK9Y|Video parte 1]] [[https://www.youtube.com/watch?v=CB51y47Y2D0|Video parte 2]] * SQL * Parte 1: SQL e consultas básicas [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD06a SQL parte 1.pdf|Slides parte 1]] [[https://youtu.be/1x4nVWxM9QA|Video parte 1]] * Parte 2: DDL e DML [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD06b SQL parte 2.pdf|Slides parte 2]] [[https://youtu.be/TcMmSI7oNZU|Video parte 2]] * Parte 3: Consultas avançadas [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD06c SQL parte 3.pdf|Slides parte 3]] [[https://youtu.be/s6JO_kI3XRI|Video parte 3]] 3. **Projeto de Bancos de Dados** * Projeto lógico e Mapeamento ER/Relacional [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD05e Projeto logico e mapeamento ER-relacional.pdf|Slides]] [[https://youtu.be/X7UoeQJER_E|Video]] * Normalização [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD05f Normalizacao.pdf|Slides]] [[https://www.youtube.com/watch?v=pLC2a_9_-t8|Video parte 1]] [[https://youtu.be/y2spYBzINPY|Video parte 2]] 4. **Novas tecnologias e aplicações de bancos de dados** * NoSQL: conceitos gerais [[http://www.dcc.ufmg.br/~clodoveu/files/IBD/Aulas/IBD07 NoSQL.pdf|Slides]] [[https://www.youtube.com/watch?v=Wc56iWEu--c|Video]] AVISO: video com 58 minutos de duração * Gerenciamento de dados geoespaciais [[https://youtu.be/BEIFe5QdHEo|Video: geoinformática]] * Gerência de Dados e Informação: a área de pesquisa no PPGCC/DCC [[https://www.youtube.com/watch?v=iDjkD0OZo14|Video]] * Mineração de Dados e Ciência dos Dados: a área de pesquisa no PPGCC/DCC [[https://photos.app.goo.gl/Ef45VC6fYSVa3uUc6|Video]] == Atividades Práticas e Avaliações == ** Exercícios de modelagem ** * Empresa (modelo do livro-texto) [[https://www.dropbox.com/s/20jwsidcrmfs6gh/Exercicio%20modelagem%20empresa%20elmasri%20navathe.pdf?dl=0|Requisitos]] [[https://www.dropbox.com/s/2lqyo5sholi4nl3/IBD02e0%20Exercicio%20modelagem%20ER%20empresa%20E%26N.pdf?dl=0|Slides]] * Aluguel de imóveis [[https://www.dropbox.com/s/dp01gd59dqf3guc/Exercicio%20modelagem%20aluguel%20de%20imoveis.pdf?dl=0|Requisitos]] [[https://www.dropbox.com/s/l3mc6n8c3x8ifcw/IBD02e1%20Exercicio%20modelagem%20ER%20aluguel%20de%20imoveis.pdf?dl=0|Slides]] * Oficina de consertos [[https://www.dropbox.com/s/ku3i5lbxk9h1tnh/Exercicio%20modelagem%20oficina%20de%20consertos.pdf?dl=0|Requisitos]] [[https://www.dropbox.com/s/gwtzdcypf3n3k5r/IBD02e6%20Exercicio%20modelagem%20ER%20oficina%20de%20consertos.pdf?dl=0|Slides]] * Netflix [[https://www.dropbox.com/s/mvloazi6hdfu62i/Exercicio%20modelagem%20NetFlix.pdf?dl=0|Requisitos]] [[https://www.dropbox.com/s/jyvikq6pjo7sthn/IBD02e2%20Exercicio%20modelagem%20ER%20Netflix.pdf?dl=0|Slides]] * Empresa industrial [[https://www.dropbox.com/s/onbgg4b1zctep19/Exercicio%20modelagem%20empresa%20industrial.pdf?dl=0|Requisitos]] [[https://www.dropbox.com/s/7pvtru5cafsp1dz/IBD02e5%20Exercicio%20modelagem%20ER%20empresa%20industrial.pdf?dl=0|Slides]] * Processos judiciais (ERE) [[https://www.dropbox.com/s/kee6zn35516dsu3/Exercicio%20modelagem%20processos%20judiciais.pdf?dl=0|Requisitos]] [[https://www.dropbox.com/s/p1kpp126ruj3h5a/IBD02e7%20Exercicio%20modelagem%20ER%20processos%20judiciais.pdf?dl=0|Slides]] * Campeonato de futebol (ERE/UML) [[https://www.dropbox.com/s/x0wo626y87g1deg/Exercicio%20modelagem%20campeonato%20de%20futebol.pdf?dl=0|Requisitos]] [[https://www.dropbox.com/s/h6smfo3kpa2fl3i/Exercicio%20campeonato%20de%20futebol%20UML.pdf?dl=0|Diagrama]] ** Exercícios de mapeamento ER-Relacional ** * Processos judiciais [[https://www.dropbox.com/s/lz75omz6ey6ffvy/20210720%20RESOLUCAO%20exercicio%20mapeamento%20ER%20relacional%20processos%20judiciais.pdf?dl=0 | Resolução]] * Cadastro urbano [[https://www.dropbox.com/s/xop8jcamb1lu8nm/20211216%20RESOLUCAO%20exercicio%20mapeamento%20ER%20relacional%20cadastro%20urbano.pdf?dl=0 | Resolução]] ** Exercícios de álgebra relacional ** * Comércio exterior [[https://www.dropbox.com/s/rlaoo38l3sr0py4/20210201%20exercicio%20algebra%20relacional%20comercio%20exterior.pdf?dl=0 | Enunciado]] [[https://www.dropbox.com/s/cltw8238l5h5ohf/20210201%20RESOLUCAO%20exercicio%20algebra%20relacional%20comercio%20exterior.pdf?dl=0 | Soluções]] ** Exercícios de SQL ** * Comércio exterior [[https://www.dropbox.com/s/693trnt4yqg0ttk/20201230%20exercicio%20consultas%20comercio%20exterior.pdf?dl=0 | Enunciado, questões, estrutura das tabelas ]] Obs: script de criação de tabelas e carga de dados disponível acima, nesta página. == Calendário == ^Aula ^Data ^Conteúdo previsto ^Modalidade ^ |1 |14/03/2023 |Apresentação da disciplina |Presencial | |2 |16/03/2023 |Conceitos básicos em bancos de dados. Modelos de dados, esquemas, instâncias |Presencial | |3 |21/03/2023 |Arquitetura de um SBD; componentes de um SGBD |Presencial | |4 |23/03/2023 |Projeto conceitual: modelo ER |Presencial | |5 |28/03/2023 |Projeto conceitual: modelo ER; variações de notação em esquemas conceituais |Presencial | |6 |30/03/2023 |ER: exercício |Presencial - exercício | |7 |04/04/2023 |ER: exercício |Presencial - exercício | |8 |11/04/2023 |Modelo ER estendido; UML; conceitos adicionais |Presencial | |9 |13/04/2023 |ERE: exercício |Presencial | |10 |18/04/2023 |ERE/UML: exercício |Presencial | |11 |20/04/2023 |Modelo Relacional |Presencial | |12 |25/04/2023 |Restrições de integridade - Revisão para prova 1 |Presencial | |13 |27/04/2023 |Prova 1: conceitos e modelagem conceitual |Presencial | |14 |02/05/2023 |Mapeamento ER/UML para relacional |Prova presencial -- individual | |15 |04/05/2023 |Mapeamento ER/UML para relacional: exercícios |Presencial | |16 |09/05/2023 |Álgebra relacional |Presencial | |17 |11/05/2023 |Álgebra relacional: exercícios |Presencial - exercício | |18 |16/05/2023 |Normalização - Revisão para Prova 2 |Presencial | |19 |18/05/2023 |Prova 2: modelo relacional e álgebra |Prova presencial -- individual | |20 |23/05/2023 |A linguagem SQL: conceitos, DDL, mapeamento relacional-SQL |Presencial | |21 |25/05/2023 |SQL: inserção e atualização |Presencial | |22 |30/05/2023 |SQL: consultas |Presencial | |23 |01/06/2023 |SQL: exercícios|Presencial - exercício | |24 |06/06/2023 |SQL: exercícios |Presencial - exercício | |25 |13/06/2023 |NoSQL: conceitos gerais |Presencial | |26 |15/06/2023 |SQL: exercícios |Presencial - exercício | |27 |20/06/2023 |Revisão para Prova 3 |Presencial | |28 |22/06/2023 |Prova 3: SQL e NoSQL |Prova presencial -- individual | |29 |27/06/2023 |Tópico extra: gerenciamento de dados não convencionais: dados geoespaciais |A definir | |30 |29/06/2023 |Prova de reposição OU tópico extra: a definir |Presencial |