Mejores prácticas de modelos en Django: guía breve y accionable para proyectos de software a medida y aplicaciones a medida con foco en claridad, mantenibilidad y rendimiento. Estas pautas evitan sorpresas en producción, facilitan pruebas con SQLite en memoria y reducen el coste total de propiedad.
Diez noes esenciales 1 No confíes en que el ORM permita modelos con el mismo nombre entre apps y lo resuelva solo con prefijos de tabla 2 No adoptes un campo is_deleted global ni sobreescribas managers como all o filter para ocultar registros 3 No permitas dualidad en el filtrado define un único punto de verdad para las consultas 4 No ignores la comodidad de usar SQL directo cuando ahorre complejidad técnica siempre reflejado en código 5 No sigas dogmas particulares de un ORM sigue buenas prácticas generales de arquitectura 6 No acoples algoritmos a filas concretas de la base de datos 7 No hagas nada en la base de datos que no esté reflejado en el repositorio de código y migraciones 8 No temas denormalizar de forma selectiva para mantener la lógica de dominio y evitar un CQRS prematuro 9 No edites migraciones salvo necesidad extrema crea nuevas migraciones coherentes 10 No uses características específicas de un motor si contemplas cambiar de proveedor ejecutar tests en SQLite o distribuir on premise
Nombres de modelos y tablas Usa nombres de clase claros y únicos con prefijo de dominio cuando sea necesario por ejemplo UserGroup y PostGroup 2 Define Meta db_table de forma explícita en snake case 3 Describe los campos M2M en la tabla secundaria y nómbralas con el patrón modelo__campo por ejemplo post__liked post__shared 4 Da nombres semánticos a FKs y M2M por ejemplo author en lugar de user 5 En relaciones M2M con through aplica el mismo patrón de nombres para la tabla intermedia modelo__campo 6 Especifica siempre default_related_name en Meta en snake case plural 7 Cuando el nombre por defecto no sea viable por múltiples FKs usa related_name con el patrón campo_modelo_plural 8 Completa Meta con db_table_comment verbose_name y verbose_name_plural para documentación 9 Documenta en el código la intención de cada relación y tabla secundaria
Gestión de borrados Evita el patrón is_deleted universal y on_delete PROTECT por norma 2 Acepta que a veces la basura es basura y hay que borrarla 3 Considera la historia que necesitas preservar y usa on_delete SET_NULL o PROTECT según tu dominio 4 Emplea un booleano is_active con default y db_default y filtra por is_active True cuando aplique 5 Para pruebas e importaciones masivas facilita limpieza sin tocar registros históricos críticos
Default y db_default Si un campo tiene default también debe tener db_default en versiones modernas de Django garantizas consistencia al crear filas fuera del ORM y mejoras la robustez de migraciones y seeds
Booleanos Nunca uses null True en BooleanField 2 Define siempre default y db_default por ejemplo is_active con default False y db_default False
Fechas y horas default timezone.now cuando quieres pre poblar al renderizar formularios 2 auto_now_add True para sellar creación sin intervención del usuario 3 auto_now True para actualizar automáticamente cada edición útil para updated_at
Texto y cadenas La documentación recomienda no usar null en campos de texto pero en la práctica en CharField es válido usar null True y blank True cuando el valor es opcional o meramente descriptivo 2 Evita default cadena vacía en CharField 3 Usa max_length 255 si aún no está claro el tamaño 4 En TextField emplea null únicamente si realmente necesitas diferenciar ausencia de texto de vacío
Estados y choices Prioriza TextChoices sobre IntegerChoices por legibilidad portabilidad y depuración 2 Nombra la clase en plural y define valores en mayúsculas para indicar que no son cadenas libres por ejemplo Statuses CREATED COMPLETED 3 Declara la clase de choices dentro del modelo salvo que vaya a compartirse 4 Configura default y db_default al valor inicial del estado 5 Evita modelos tabla para estados y FKs a Status lo mismo aplica a derechos y permisos salvo requisitos muy específicos
Portabilidad y pruebas Evita funciones específicas del SGBD desencadenadores o tipos exóticos si vas a probar en SQLite cambiar a otro proveedor o desplegar en entornos variados 2 Si necesitas optimizaciones específicas encapsúlalas y ofréceles fallback documentado
Migraciones No edites migraciones ya aplicadas salvo emergencia crea nuevas migraciones que corrijan el estado real 2 Mantén comentarios y nombres descriptivos en las operaciones para auditar la historia del esquema
Denormalización con criterio Prefiere columnas derivadas o materializaciones ligeras si reduce la complejidad de consultas y mantiene la lógica de dominio visible en código 2 Mide y observa antes de introducir CQRS y evita diseños demasiado complejos de forma prematura
Trabajo directo con la base de datos Puedes usar SQL crudo vistas índices y consultas especializadas cuando simplifiquen la solución pero deja todo reflejado en código y migraciones y proporciona tests que validen estos contratos
En Q2BSTUDIO impulsamos equipos y productos digitales aplicando estas prácticas para construir software a medida y aplicaciones a medida que escalan con seguridad y rendimiento además de servicios de inteligencia artificial ia para empresas agentes IA ciberseguridad servicios cloud aws y azure servicios inteligencia de negocio y analítica con power bi Si buscas un socio técnico que te ayude a aterrizar estas decisiones de arquitectura y a acelerar tu hoja de ruta técnica descubre cómo abordamos el desarrollo de software y aplicaciones a medida con un enfoque pragmático y orientado a negocio