Skip to content

Base de Datos para una aplicación de taxis , diagrama ER, SQL, Linea de comandos

Notifications You must be signed in to change notification settings

Sandrarodriguezrey/Proyecto6_SQL

Repository files navigation

Proyecto de práctica 6: Proyecto para trabajar en consola con los logs y la base de datos para una aplicación de taxis.

Instrucciones para el Desarrollo del Proyecto

Este proyecto consta de dos partes. Consola y en Base de datos.

Consola - indicaciones:

Ejercicio 1

Averiguar qué solicitudes han venido de una dirección IP. Una dirección IP consta de cuatro números separados por un punto. Necesitas direcciones que comiencen con "233.201".

Los logs están en un servidor remoto en logs/2019/12. No sabes qué día ocurrió el error.

Tu tarea es averiguar qué solicitudes fueron enviadas.

Ejercicio 2

Se ha detectado un error en el sistema. Estaba activo el 12.30.2019. En ese momento, había errores 400 y 500. Tu tarea consiste en guardar los logs que se registraron durante este periodo en un archivo independiente.

Después, debes poner estos logs en archivos por separado con base en los errores.

En el directorio de inicio del servidor remoto, crea un directorio llamado bug1.
Pon todas las solicitudes que ocurrieron en el archivo main.txt en el directorio bug1.
Dentro del directorio bug1 , crea un directorio events.
Dentro del directorio events, crea archivos de error 400 y 500. Llama a estos archivos 400.txt y 500.txt, respectivamente. Identifica en ellos los logs utilizando el error correspondiente del archivo main.txt.

Base de datos - indicaciones:

🤷‍♀️ Base de datos de los viajes en taxi de Chicago:

Cuadro relacional de datos de taxi

La tabla neighborhoods, con información sobre los barrios de la ciudad:

neighborhood_id: código del vecindario.
name: nombre del vecindario.

La tabla cabs, con información sobre los taxis:

cab_id: código único del vehículo.
vehicle_id: identificador técnico del vehículo.
company_name: la compañía dueña del automóvil.

La tabla trips, con información sobre viajes:

trip_id: código de viaje.
cab_id: el código del automóvil usado para el viaje.
start_ts: fecha y hora del inicio del viaje (tiempo redondeado a la hora más próxima).
end_ts: fecha y hora del fin del viaje (tiempo redondeado a la hora más próxima).
duration_seconds: la duración del viaje en segundos.
distance_miles: la distancia del viaje en millas.
pickup_location_id: el código del vecindario donde inició el viaje.
dropoff_location_id: el código del vecindario donde terminó el viaje.

La tabla weather_records (registros meteorológicos), con información sobre el clima:

record_id: código del registro de observación meteorológica.
ts: fecha y hora de la observación (tiempo redondeado a la hora más próxima).
temperature: temperatura a la hora de la observación.
description: una breve descripción de las condiciones meteorológicas (p. ej., lluvia ligera o nubes dispersas).

Ejercicio 1

Tienes una base de datos con los viajes en taxi. El plan era tener 10,550 vehículos disponibles, lo que cubre la demanda del usuario; sin embargo, el equipo recibió muchas quejas de que no había vehículos suficientes. ¿Cuántos taxis hay actualmente en las calles? La información sobre todos los automóviles suficientes está en la tabla cabs.

Ve al servidor remoto.
Conéctate a la base de datos chicago_taxi
Cuenta el número total de automóviles en la tabla cabs. Recuerda que un automóvil podría pertenecer a distintas compañías.

Ejercicio 2

En la tabla cabs, cuenta el número de automóviles de cada compañía. Ordena los valores en orden descendente. El equipo piensa que algunas compañías no tuvieron suficientes automóviles disponibles.

Devuelve las compañías con menos de 100 automóviles. Llama cnt (contados) al campo con el número de automóviles, y company_name al campo con el nombre de la compañía.

Para resolver el problema, utiliza el operador HAVING, una analogía de WHERE para las funciones agregadas. Estudia la documentación para aprender cómo funciona el operador:

Ejercicio 3

La aplicación de taxis calcula el coeficiente del costo del viaje. Si el clima es bueno, el valor del coeficiente es 1. Si llueve o hay tormentas en el exterior, el coeficiente aumenta a 2. El equipo tiene una hipótesis de que hay un error en el cálculo del coeficiente. Para revisar el cálculo del coeficiente, el equipo necesita una selección de datos: el área de desarrollo puede comparar el coeficiente con los datos en los logs y corregir el bug. Tu tarea es obtener una selección.

Para hacerlo:

Obtén una descripción de las condiciones meteorológicas de la tabla weather_records para cada hora.
Divide todas las horas en dos grupos a través del operador CASE: Está Bad ("mal") si el campo description contiene las palabras "rain" (lluvia) o "storm" (tormenta); Good ("bien"), para todas las demás horas.
Pon el nombre weather_conditions al campo resultante.
La tabla resultante debe tener dos campos: fecha y hora (ts) y weather_conditions.

Haz una selección para el periodo entre 11-05-2017 12:00 a. m. a 11-06-2017 12:00 a. m.

Ejercicio 4

La compañía de taxis comienza a reportar que la ganancia que reciben no coincide con los datos que proporciona la aplicación. El equipo de desarrollo sugiere que el problema puede estar en los datos sobre el número de viajes.

Para determinar si hay un bug, debes obtener la selección del número de viajes de cada compañía de taxi para los días 15 y 16 de noviembre de 2017.

Devuelve el campo company_name. Nombra trips_amount (cantidad de viajes) al campo con el número de viajes y devuélvelo.
Organiza en orden descendente los resultados obtenidos en el campo trips_amount.

Desarrollo del Proyecto: Se abordaron dos áreas principales: trabajo con logs en consola y consultas en una base de datos.

Consola: realicé dos ejercicios fundamentales:

Ejercicio 1: Identifiqué las solicitudes realizadas desde una dirección IP específica (233.201) dentro de un archivo de logs remoto.
Ejercicio 2: Filtré los logs de un error ocurrido el 30 de diciembre de 2019, separando los errores 400 y 500 en archivos distintos y almacenándolos en una estructura de directorios organizada.

Base de Datos: Trabajé con una base de datos de taxis en Chicago, con tablas que incluyen información de vecindarios, taxis, viajes y condiciones meteorológicas.

Ejercicio 1: Contabilicé el número total de taxis disponibles en la ciudad.
Ejercicio 2: Determiné cuántos vehículos pertenecen a cada compañía y encontrar las compañías con menos de 100 automóviles.
Ejercicio 3: Investigué un posible error en el cálculo de un coeficiente de costo basado en las condiciones meteorológicas, utilizando la tabla de registros meteorológicos.
Ejercicio 4: Verifiqué discrepancias entre las ganancias reportadas por la aplicación y los datos reales de los viajes realizados en los días 15 y 16 de noviembre de 2017.

Para más detalles en las respuestas puedes consultar el archivo en el siguiente enlace: ("https://github.com/Sandrarodriguezrey/Proyecto6_SQL/blob/main/Proyecto%20Sprint%206%20Sandra%20Rodriguez.pdf")

Herramientas utilizadas:

SQL Para realizar consultas sobre la base de datos y analizar la información relacional

Hojas de calculo Google sheets. Para documentar y organizar los resultados obtenidos durante las consultas y análisis realizados.

CONCLUSIÓN

Este proyecto me permitió profundizar muchos mas mis habilidades en el manejo de logs en consola como en la manipulación de bases de datos SQL. Aprendí a trabajar con grandes volúmenes de datos en un entorno realista, lo que me dio una comprensión más clara de cómo se gestionan los errores. Entendí la importancia de organizar y clasificar los datos de manera eficiente, tanto en la parte de logs como en la base de datos, para facilitar su análisis y diagnóstico.


GRACIAS por visitar este proyecto.

MUCHAS ESTRELLITAS DE LUZ PARA TI 🌟🌟🌟🌟

Si tienes preguntas puedes contactarme en mi Linkedln. 👉 www.linkedin.com/in/sandrarodriguez461428179

About

Base de Datos para una aplicación de taxis , diagrama ER, SQL, Linea de comandos

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published