Flask: Proyecto API REST con MySQL

Proyecto de programación
Avanzado
Flask
Curso de Flask
120 min
200 XP
Actualizado: 04/05/2026

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.

Tipo: Proyecto 120 minutos estimados 200 puntos de experiencia

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

  1. Crea la estructura del proyecto con un archivo principal app.py, un módulo models.py para los modelos SQLAlchemy, un módulo routes.py para los endpoints y un archivo .env con las variables de configuración. Configura la aplicación Flask con la cadena de conexión a MySQL desde las variables de entorno.
  2. Define el modelo Categoria con los campos id (clave primaria entera), nombre (cadena de hasta 100 caracteres, obligatorio y único) y descripción (texto opcional). Añade una relación productos que enlace con el modelo Producto.
  3. Define el modelo Producto con los campos id (clave primaria entera), nombre (cadena de hasta 200 caracteres, obligatorio), precio (decimal con dos decimales, obligatorio), stock (entero, por defecto 0) y categoria_id (clave foránea que referencia a Categoría, obligatorio). Añade un método to_dict() en ambos modelos que devuelva un diccionario con todos los campos.
  4. 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) y DELETE /api/categorias/<id> (eliminar, comprobando que no tenga productos asociados).
  5. Implementa los endpoints para Producto: GET /api/productos (listar todos con filtro opcional por categoría mediante query param categoria_id), GET /api/productos/<id> (obtener uno), POST /api/productos (crear validando nombre, precio y categoria_id), PUT /api/productos/<id> (actualizar) y DELETE /api/productos/<id> (eliminar).
  6. Configura manejadores de error globales para los códigos 404 y 500 que devuelvan respuestas JSON con un campo error descriptivo. Valida que las peticiones POST y PUT contengan los campos obligatorios y devuelve un error 400 si faltan.
  7. 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 Flask
Alan Sastre - Autor del ejercicio

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

Contenido bloqueado

¡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.

solution.js
JavaScript
1 function solveChallenge ( input ) {
2 // Algoritmo optimizado O(n log n)
3 const data = parseInput ( input );
4 const sorted = data . sort (( a , b ) => a - b );
5
6 // Aplicar técnica de dos punteros
7 let left = 0 , right = sorted . length - 1 ;
8 const result = [];
9
10 while ( left < right ) {
11 const sum = sorted [ left ] + sorted [ right ];
12 if ( sum === target ) {
13 result . push ([ sorted [ left ], sorted [ right ]]);
14 left ++; right --;
15 } else if ( sum < target ) {
16 left ++;
17 } else {
18 right --;
19 }
20 }
21
22 return result ;
23 }
Código completo
Explicaciones
Mejores prácticas
+1.200 developers han resuelto este ejercicio de programación

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.

Nota: Para obtener el máximo beneficio de este ejercicio de programación, te recomendamos revisar primero las lecciones relacionadas de Flask y asegurarte de comprender los conceptos básicos antes de intentar resolver el ejercicio.