ORMs: ¿solución o problemas en puerta?

dev.to

Una reflexión desde la experiencia práctica sobre una decisión que muchos equipos toman sin medir sus consecuencias.

Hay decisiones tecnológicas que se toman de manera casi automática, sin demasiado debate y con la convicción de que son la opción moderna y correcta. El uso de ORMs —Object-Relational Mappers, herramientas como Entity Framework en .NET o Hibernate en Java— es una de ellas. Esta no es una crítica a los ORMs como herramienta; son, en muchos contextos, soluciones brillantes. El problema surge cuando se los adopta como arquitectura base de acceso a datos en sistemas complejos, de gran escala, sin analizar seriamente las consecuencias.

El ORM como decisión por defecto
En la mayoría de los equipos medianos, la elección del ORM no es producto de un análisis arquitectónico profundo. Es el resultado de la presión por entregar rápido y la familiaridad de los desarrolladores con la herramienta. El ORM reduce la fricción inicial de manera notable: permite interactuar con la base de datos sin escribir SQL y ver resultados en minutos. Eso tiene valor. El problema es que esa facilidad oscurece una complejidad que no desaparece, simplemente se difiere. Y cuando aparece —y siempre aparece— lo hace cuando el sistema ya tiene usuarios, los datos ya son muchos y nadie tiene tiempo de refactorizar.

El problema de visibilidad compartida
En sistemas de cierta escala, el equipo de datos ve planes de ejecución, índices y consultas lentas, pero no el código que las genera. El desarrollador ve modelos de objetos y LINQ, pero no lo que el ORM produce realmente ni cómo impacta en el motor. En el medio está el ORM, actuando como caja negra que traduce de un mundo al otro sin que ninguno de los dos equipos tenga control real sobre esa traducción.
El resultado es predecible: el equipo de datos pasa sus días agregando índices y ajustando estadísticas sin atacar la raíz, que muchas veces es una consulta mal construida por el ORM que ningún índice va a salvar. Un índice puede mejorar una consulta ineficiente, pero no puede convertirla en una consulta bien diseñada.

El argumento de la portabilidad y otros mitos
El argumento de la portabilidad —poder cambiar el motor de base de datos sin tocar el código— suena razonable en teoría. En la práctica, en sistemas maduros con años de historia, es casi una fantasía. Sacrificar performance cotidiana para estar preparado para algo que probablemente nunca ocurra no es arquitectura prudente: es arquitectura ansiosa. El argumento del versionado tampoco se sostiene: con herramientas como los Database Projects de SSDT, Flyway o Liquibase, los objetos de base de datos viven en el repositorio con historial completo e integración CI/CD. En 2026, ese argumento es técnicamente débil.

La separación de responsabilidades y los procedimientos almacenados
El argumento más sólido contra los stored procedures es el de la separación de responsabilidades: si un SP contiene lógica de negocio, algo que pertenece a la capa de aplicación está viviendo en la base de datos. Eso es un problema real. Pero hay una distinción que frecuentemente se ignora: un SP que decide si un cliente recibe un descuento mezcla responsabilidades; un SP que ejecuta un join complejo sobre millones de registros está haciendo exactamente lo que corresponde, cerca del motor que almacena los datos. El problema no es la herramienta sino cómo se usa. Y la diferencia clave es que un SP mal escrito es un problema conocido y localizado; un ORM mal configurado produce problemas difusos y emergentes que aparecen de formas inesperadas a medida que el sistema escala.

Por qué los referentes técnicos no siempre ayudan
Los desarrolladores que publican contenido técnico son, en su mayoría, expertos en código, patrones y frameworks, no necesariamente en arquitectura de datos. Cuando alguien muy bueno en su área opina sobre un área adyacente, lo hace con puntos ciegos. El problema es que la audiencia no siempre distingue entre 'es muy bueno en desarrollo' y 'es una autoridad en todo lo que el desarrollo toca'. Hay además un componente estético: una consulta LINQ se ve elegante en pantalla; un stored procedure, no. En el mundo del contenido técnico, eso influye más de lo que nos gusta admitir.

Lo que hacen los sistemas serios
Empresas como Amazon, Google o Netflix no usan ORMs para sus sistemas críticos. Trabajan con acceso a datos muy controlado y consultas nativas, porque la escala no les permite el lujo de una capa de abstracción opaca. Los sistemas bancarios y financieros de primer nivel siguen usando procedimientos almacenados extensivamente. No por conservadurismo irracional, sino porque necesitan trazabilidad, control absoluto y performance predecible. Un banco no puede permitirse que una consulta generada por un ORM cambie su plan de ejecución porque se actualizó una versión del framework. No es conservadurismo irracional; es la experiencia acumulada de sistemas que no pueden fallar, escrita en decisiones arquitectónicas concretas.

Entonces, ¿cuál es el lugar del ORM?
El ORM tiene un lugar legítimo: operaciones CRUD simples, equipos pequeños, prototipos, sistemas donde la escala no es el problema central. El problema no es la herramienta sino la ausencia de criterio sobre cuándo usarla y cuándo no. En sistemas complejos con equipos diferenciados y grandes volúmenes de datos, la arquitectura de acceso a datos debería ser una decisión explícita, no el resultado de tomar el camino de menor resistencia.
Ted Neward, arquitecto con más de treinta años de experiencia, lo describió hace casi dos décadas con una analogía que sigue siendo vigente: el ORM es el Vietnam de las ciencias de la computación. Empieza bien, se complica con el tiempo, y antes de que te des cuenta estás atrapado en un compromiso sin salida clara. La experiencia práctica —no los tutoriales de YouTube— tiende a llegar a las mismas conclusiones. Y eso, en sí mismo, dice bastante.

— Reflexión basada en experiencia práctica en desarrollo y arquitectura de software.

Source: dev.to

arrow_back Back to News