{"id":22276854,"url":"https://github.com/raizertechdev/tarefastackx-tabelas-query","last_synced_at":"2025-03-25T17:43:42.831Z","repository":{"id":264721650,"uuid":"892912844","full_name":"RaizerTechDev/tarefaStackX-tabelas-query","owner":"RaizerTechDev","description":"Tarefa desenvolvida no curso StackX, utilizando Node.js e MongoDB Atlas para criar e executar queries a partir de uma tabela fornecida!","archived":false,"fork":false,"pushed_at":"2024-11-27T21:31:06.000Z","size":103,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-01-30T15:40:52.934Z","etag":null,"topics":["javascript","mongodb-atlas","nodejs"],"latest_commit_sha":null,"homepage":"https://github.com/RaizerTechDev/tarefaStackX-tabelas-query/blob/master/Documentation.md","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/RaizerTechDev.png","metadata":{"files":{"readme":"Readme.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-11-23T03:18:27.000Z","updated_at":"2024-11-27T21:31:10.000Z","dependencies_parsed_at":"2024-11-26T01:17:56.640Z","dependency_job_id":"327f3f9f-0652-4843-910c-2fb20bb30c36","html_url":"https://github.com/RaizerTechDev/tarefaStackX-tabelas-query","commit_stats":null,"previous_names":["raizertechdev/tarefastackx-tabelas-query"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefaStackX-tabelas-query","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefaStackX-tabelas-query/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefaStackX-tabelas-query/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefaStackX-tabelas-query/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/RaizerTechDev","download_url":"https://codeload.github.com/RaizerTechDev/tarefaStackX-tabelas-query/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245512257,"owners_count":20627552,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["javascript","mongodb-atlas","nodejs"],"created_at":"2024-12-03T14:16:24.171Z","updated_at":"2025-03-25T17:43:42.808Z","avatar_url":"https://github.com/RaizerTechDev.png","language":"JavaScript","readme":"# Tarefa - Banco de Dados -Tabela Query\r\n\r\n## Índice\r\n\r\n- [Objetivo](#-objetivo)\r\n- [Documentação](#-documentação-do-projeto)\r\n- [Instalação](#instalação-com-bash)\r\n- [Gerenciamento de Tabelas - Operações de Listar e Deletar](#gerenciamento-de-tabelas---operações-de-listar-e-deletar)\r\n- [Demonstração Código Resumido](#demonstração-código-resumido)\r\n  - [- `models/Aluno.js`](#--modelsalunojs)\r\n  - [- `database/index.js`](#--databaseindexjs)\r\n  - [- `app.js`](#--appjs)\r\n\r\n## 🌟 Objetivo:\r\n\r\n### 🎯 Veja essa tabela e escreva a query pedida no fim:\r\n\r\nTabela - provas\r\n📍Colunas:\r\n📍 id_aluno - número\r\n📍 id_materia - número\r\n📍 nota - número flutuante\r\n📍 data_da_prova data\r\n\r\nTabela - aluno\r\n📍 colunas:\r\n📍 id numero\r\n📍 nome string\r\n📍 data_nascimento numero\r\n\r\nTabela - professor\r\n📍 colunas:\r\n📍 id numero\r\n📍 nome string\r\n📍 data_nascimento numero\r\n\r\nTabela - materia\r\n📍 colunas:\r\n📍 id numero\r\n📍 nome string\r\n📍 id_professor numero\r\n\r\n🎯 Crie 3 alunos;\r\n🎯 Crie uma matéria e um professor;\r\n🎯 Crie 1 prova para cada aluno nessa matéria e diga que nota eles tiraram.\r\n\r\n\u003cbr\u003e\r\n\r\n---\r\n\r\n## 📖 Documentação do Projeto\r\n\r\n \u003cdiv align=\"center\"\u003e\r\n\r\n\u003cimg src =\"././public/assets/images/doc.png\" alt=\"Descrição da Imagem\" height=\"45\"\u003e\r\n\r\n[✨ **Clique aqui para saber mais da documentação** ✨](https://github.com/RaizerTechDev/tarefaStackX-tabelas-query/blob/master/Documentation.md)\r\n\r\n\u003cbr\u003e\r\n\r\n\u003cdiv align=\"center\"\u003e\r\n  \r\n\u003cimg src= \"https://media.giphy.com/media/3zSF3Gnr7cxMbi6WoP/giphy.gif\" align=\"center\" height=\"55\" width=\"55\"\u003e [Demonstração-Tabelas] \u003cimg src= \"https://media.giphy.com/media/E5DzZsofmgxc9wjbhX/giphy.gif\" align=\"center\" height=\"35\" width=\"35\"\u003e\r\n\r\n\u003cimg height=\"480em\" src=\"././public/assets/images/readme-tabelas-query.png\"  align=\"center\"\u003e\r\n\r\n\u003cbr\u003e\r\n\r\n---\r\n\r\n\u003cdiv align=\"left\"\u003e\r\n\r\n## Instalação com bash\r\n\r\n- Clone o repositório:\r\n\r\n```\r\ngit clone https://github.com/seu-usuario/nome-do-repositorio.git\r\n```\r\n\r\n- Navegue até o diretório do projeto:\r\n\r\n```\r\ncd nome-do-repositorio\r\n```\r\n\r\n- Instale as dependências:\r\n\r\n```\r\nnpm install dotenv mongoose cli-table3\r\n```\r\n\r\n- Instalando pacotes para formatação\r\n\r\n```\r\nnpm install --save-dev eslint eslint-config-prettier eslint-plugin-prettier prettier\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n- Inicie o servidor:\r\n\r\n```\r\nnpm start\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n- Vai iniciar no terminal a consulta das Tabelas.\r\n\r\n---\r\n\r\n## Gerenciamento de Tabelas - Operações de Listar e Deletar\r\n\r\nNesta parte do projeto serve para fornecer ferramentas simples para listar e deletar tabelas. Abaixo estão as instruções detalhadas para realizar essas operações.\r\n\r\n### Como usar\r\n\r\n#### 1. Listar Tabelas:\r\n\r\nPara listar todas as tabelas disponíveis no sistema, execute o seguinte comando:\r\n\r\n```bash\r\nnode src/services/list.js\r\n```\r\n\r\n#### 2. Deletar Tabelas:\r\n\r\nPara deletar todas as tabelas disponíveis no sistema, execute o seguinte comando:\r\n\r\n```bash\r\nnode src/services/delete.js\r\n```\r\n\r\n---\r\n\r\n## Demonstração Código Resumido\r\n\r\n#### - `models/Aluno.js`\r\n\r\n```javascript\r\nconst mongoose = require('mongoose');\r\n\r\nconst AlunoSchema = new mongoose.Schema({\r\n  nome: { type: String, required: true },\r\n  data_nascimento: { type: Date, required: true },\r\n});\r\n\r\nmodule.exports = mongoose.model('Aluno', AlunoSchema);\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n#### - `database/index.js`\r\n\r\n```javascript\r\nconst mongoose = require('mongoose');\r\nrequire('dotenv').config();\r\n\r\nconst connectDB = async () =\u003e {\r\n  const uri = process.env.MONGODB_URI;\r\n\r\n  if (!uri) {\r\n    console.error('Erro: MONGODB_URI não está definido no arquivo .env');\r\n    process.exit(1);\r\n  }\r\n\r\n  try {\r\n    await mongoose.connect(uri);\r\n    console.log('Conectado ao MongoDB!');\r\n  } catch (err) {\r\n    console.error('Erro ao conectar ao MongoDB:', err);\r\n    process.exit(1);\r\n  }\r\n};\r\n\r\nmodule.exports = connectDB;\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n#### - `app.js`\r\n\r\n```javascript\r\nconst connectDB = require('./src/database');\r\nconst seedData = require('./src/seed/seedData');\r\nconst Aluno = require('./src/models/Aluno');\r\n\r\nconst start = async () =\u003e {\r\n  await connectDB();\r\n  await seedData();\r\n  await showTables(); // Chama a função para exibir as tabelas\r\n};\r\n\r\nstart();\r\n```\r\n\r\n---\r\n\r\n## Tecnologias\r\n\r\n\u003cimg src=\"https://media.giphy.com/media/iT138SodaACo9LImgi/giphy.gif\" align=\"center\" height=\"75\" width=\"75\"\u003e Tecnologias utilizadas no projeto:\r\n\r\n- `JavaScript (JS)`\r\n  \"Linguagem de Programação do Navegador\".\r\n  \"Scripting Dinâmico para Web\".\r\n  \u003cbr\u003e\r\n\r\n- `Node.js`\r\n  \"Ambiente de Execução JavaScript do Lado do Servidor\".\r\n  \"Servidor Escalável em JavaScript\".\r\n  \u003cbr\u003e\r\n\r\n- `Documentation.md`\r\n  \"Guia detalhado para uso e manutenção do projeto.\"\r\n  \"Referência central para funcionalidades, práticas e requisitos.\"\r\n  \u003cbr\u003e\r\n\r\n- `Git`\r\n  \"Sistema de controle de versões\"\r\n  \u003cbr\u003e\r\n\r\n- `Github`\r\n  \"Plataforma para hospedagem de código-fonte\"\r\n  \u003cbr\u003e\r\n\r\n- `Visual Studio Code`\r\n  \"Editor de código-fonte\"\r\n  \u003cbr\u003e\r\n\r\n---\r\n\r\n## Licença\r\n\r\n- Esse projeto está sob a licença MIT.\r\n  \u003cbr\u003e\r\n\r\n---\r\n\r\n\u003cimg src=\"https://media.giphy.com/media/ImmvDZ2c9xPR8gDvHV/giphy.gif\" align=\"center\" height=\"25\" width=\"25\"\u003e Autor\r\n\r\n\u003cp\u003e\r\n    \u003cimg align=left margin=10 width=80 src=\"https://avatars.githubusercontent.com/u/87991807?v=4\"/\u003e\r\n    \u003cp\u003e\u0026nbsp\u0026nbsp\u0026nbspRafaelRaizer-Dev\u003cbr\u003e\r\n    \u0026nbsp\u0026nbsp\u0026nbsp\u003ca href=\"https://api.whatsapp.com/send/?phone=47999327137\"\u003eWhatsapp\u003c/a\u003e\u0026nbsp;|\u0026nbsp;\u003ca href=\"https://www.linkedin.com/in/rafael-raizer//\"\u003eLinkedIn\u003c/a\u003e\u0026nbsp;|\u0026nbsp;\u003ca href=\"https://github.com/RaizerTechDev\"\u003eGitHub\u003c/a\u003e|\u0026nbsp;\u003ca href=\"https://public.tableau.com/app/profile/rafael.raizer\"\u003eTableau\u003c/a\u003e|\u0026nbsp;\u003ca href=\"https://raizertechdev-portfolio.netlify.app/\"\u003ePortfólio\u003c/a\u003e\u0026nbsp;\u003c/p\u003e\r\n\u003c/p\u003e\r\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fraizertechdev%2Ftarefastackx-tabelas-query","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fraizertechdev%2Ftarefastackx-tabelas-query","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fraizertechdev%2Ftarefastackx-tabelas-query/lists"}