Ssylka

Почему стоит отказаться от ORM?

Современные ORM, вроде Hibernate или SQLAlchemy, создают дополнительный уровень абстракции, требуя от разработчиков изучения как минимум двух языков: SQL и языка запросов ORM. Это удваивает объем знаний, необходимых для работы с базой данных, и часто приводит к проблемам с производительностью и композицией сложных запросов.
Почему стоит отказаться от ORM?
Изображение носит иллюстративный характер

Вместо сложных ORM предлагается использовать простой API для прямого взаимодействия с базой данных, позволяющий писать запросы на нативном SQL. Такой подход позволяет разработчикам лучше контролировать запросы, получать нужные проекции данных и избегать дополнительных слоев абстракций, таких как сущности и репозитории.

Ключевым моментом является прямое использование SQL, что позволяет проверять запросы и типы аргументов на этапе компиляции и автоматически выводить типы результатов. Это унифицирует типовое пространство между бэкендом и схемой базы данных, упрощая разработку.

Предлагаемый подход не является новым витком развития ORM, вроде ActiveRecord или QueryBuilder, которые по сути являются ORM-подходами. Основная идея – использовать нативный SQL и базовый API для взаимодействия с базой данных, что потенциально упрощает и ускоряет разработку.


Новое на сайте

7556Грузовой мустанг: обзор Shulz The Tentacle 7555Космическая Одиссея: рекордные прогулки и затянувшаяся экспедиция на МКС 7554Астероид 2024 YR4: космическая угроза, требующая пристального внимания 7553Металлический путь Желтой реки: от земли к живым организмам 7552Скрытые рифы: как "мусорная" еда губит здоровье чернопёрых рифовых акул 7551Может ли аквакультура спасти королевского конха от вымирания? 7550Аллокаторы памяти в играх: оптимизация и выбор 7549Возрождение образования: путь к человеческому процветанию, а не религиозному контролю 7548Империя на коне: подвиги и тайны Александра Македонского 7547Белое карликовое сердце: рекордные пульсации звезды WD J0135+5722 7546Голоса разума: пути развития шизофрении 7545DeepSeek vs ChatGPT: сравнительный анализ генерации SwiftUI кода 7544Могут ли материалы помнить последовательность событий вопреки всем правилам? 7543Загадки C23 и Boolean в Chocolate Doom 7542Опасность на прилавках: масштабный отзыв салатов из-за сальмонеллы