Ejercicio de programación: Proyecto API REST con MySQL
Este ejercicio de programación está diseñado para poner a prueba tus conocimientos en Flask. Es un ejercicio avanzado que pondrá a prueba tus conocimientos expertos.
Información adicional del ejercicio
Proyecto integrador en el que se construye una API REST completa con Flask y SQLAlchemy conectada a MySQL. La aplicación gestiona un catálogo de productos organizados por categorías, implementando todas las operaciones CRUD con validación de datos, manejo de errores y relaciones entre modelos. Se combinan los conceptos de rutas REST, modelos SQLAlchemy con asociaciones, migraciones con Flask-Migrate y buenas prácticas de estructura de proyecto Flask. La API devuelve respuestas JSON con códigos de estado HTTP adecuados y gestiona errores de forma consistente.
Contenido del ejercicio
- Crea la estructura del proyecto con un archivo principal
app.py, un módulomodels.pypara los modelos SQLAlchemy, un móduloroutes.pypara los endpoints y un archivo.envcon las variables de configuración. Configura la aplicación Flask con la cadena de conexión a MySQL desde las variables de entorno. - Define el modelo
Categoriacon los camposid(clave primaria entera),nombre(cadena de hasta 100 caracteres, obligatorio y único) ydescripción(texto opcional). Añade una relaciónproductosque enlace con el modelo Producto. - Define el modelo
Productocon los camposid(clave primaria entera),nombre(cadena de hasta 200 caracteres, obligatorio),precio(decimal con dos decimales, obligatorio),stock(entero, por defecto 0) ycategoria_id(clave foránea que referencia a Categoría, obligatorio). Añade un métodoto_dict()en ambos modelos que devuelva un diccionario con todos los campos. - Implementa los endpoints para Categoría:
GET /api/categorias(listar todas),GET /api/categorias/<id>(obtener una por id),POST /api/categorias(crear con validación de nombre obligatorio),PUT /api/categorias/<id>(actualizar) yDELETE /api/categorias/<id>(eliminar, comprobando que no tenga productos asociados). - Implementa los endpoints para Producto:
GET /api/productos(listar todos con filtro opcional por categoría mediante query paramcategoria_id),GET /api/productos/<id>(obtener uno),POST /api/productos(crear validando nombre, precio y categoria_id),PUT /api/productos/<id>(actualizar) yDELETE /api/productos/<id>(eliminar). - Configura manejadores de error globales para los códigos 404 y 500 que devuelvan respuestas JSON con un campo
errordescriptivo. Valida que las peticiones POST y PUT contengan los campos obligatorios y devuelve un error 400 si faltan. - Inicializa Flask-Migrate, genera la migración inicial y aplícala. Verifica que las tablas se crean correctamente en MySQL y que las operaciones CRUD funcionan realizando peticiones con curl o herramientas similares.
Más ejercicios de Flask
Explora más ejercicios de programación en Flask para mejorar tus habilidades y obtener tu certificación.
Ver más ejercicios de FlaskExplora el curso completo de Flask
Descubre más contenido de Flask con lecciones, ejercicios y módulos organizados para tu aprendizaje.
Lecciones de Flask
Aprende los conceptos fundamentales con tutoriales detallados
Ejercicios de Flask
Practica con más ejercicios de programación
Módulos de Flask
Explora todos los módulos del curso organizados por temas
Curso completo de Flask
Ver el temario completo con todos los contenidos del curso
Todas las tecnologías
Explora todos los cursos de programación disponibles
Alan Sastre
Ingeniero de Software y formador, CEO en CertiDevs
Ingeniero de software especializado en Full Stack y en Inteligencia Artificial. Como CEO de CertiDevs, Flask es una de sus áreas de expertise. Con más de 15 años programando, 6K seguidores en LinkedIn y experiencia como formador, Alan se dedica a crear ejercicios prácticos y contenido educativo de calidad para desarrolladores de todos los niveles.
Solución al ejercicio de programación en Flask
¡Desbloquea la solución completa!
Completa el ejercicio de programación en Flask para acceder a la solución paso a paso, explicaciones detalladas y mejores prácticas.
Practica con ejercicios de programación en Flask
Mejora tus habilidades con cientos de ejercicios de práctica, recibe retroalimentación instantánea y obtén tu certificación cuando estés listo.
Asistente de IA
Aprende de tus errores
Progreso
Mide tu avance
Certificación
Valida tus habilidades
Ejercicios de programación en Flask: Práctica y Certificación
Los ejercicios de programación son fundamentales para dominar Flask. Este ejercicio está diseñado para poner a prueba tus conocimientos prácticos y ayudarte a consolidar lo aprendido en las lecciones teóricas. La práctica constante con ejercicios de programación es la clave para convertirte en un desarrollador experto.
¿Por qué resolver ejercicios de programación?
Resolver ejercicios de programación en Flask te permite:
- Aplicar conocimientos teóricos: Poner en práctica los conceptos aprendidos en las lecciones de Flask.
- Identificar áreas de mejora: Descubrir qué conceptos necesitas reforzar en tu aprendizaje de Flask.
- Prepararte para certificaciones: Los ejercicios te preparan para obtener certificados profesionales en Flask.
- Mejorar tu perfil profesional: Demostrar tus habilidades prácticas en Flask.
Metodología de aprendizaje
Nuestros ejercicios de programación están diseñados siguiendo una metodología probada de aprendizaje progresivo. Cada ejercicio en Flask está cuidadosamente estructurado para llevar tus habilidades al siguiente nivel. Comenzamos con conceptos fundamentales y avanzamos gradualmente hacia desafíos más complejos que reflejan situaciones reales del desarrollo de software profesional.
Certificación y validación de conocimientos
Al completar ejercicios de programación, no solo mejoras tus habilidades técnicas, sino que también puedes obtener certificados que validan tu expertise en Flask. Estos certificados son reconocidos por empresas y pueden ser una gran adición a tu perfil profesional de LinkedIn o tu CV como desarrollador.
Los ejercicios están alineados con los estándares de la industria y cubren desde conceptos básicos hasta técnicas avanzadas de programación en Flask. Cada ejercicio incluye casos de prueba y ejemplos prácticos que te ayudarán a comprender mejor cómo aplicar lo aprendido en proyectos reales.