Первые впечатления
Недавно я столкнулся с задачей выбора ORM для нового проекта на Python, и мое внимание привлекла TortoiseORM. Скажу честно, я был удивлен тем, насколько эта ORM упрощает работу с базами данных в асинхронных приложениях.
Как разработчик, я привык к таким инструментам, как SQLAlchemy и Peewee. Однако интеграция асинхронности в этих ORM зачастую требует дополнительных настроек и может быть довольно запутанной. TortoiseORM же изначально спроектирована с учетом асинхронности, что сразу облегчает жизнь.
Знакомый синтаксис
Один из самых больших плюсов — синтаксис, напоминающий Django ORM. Если вы работали с Django, вам не составит труда начать использовать TortoiseORM. Определение моделей выглядит интуитивно понятно:
from tortoise.models import Model
from tortoise import fields
class User(Model):
id = fields.IntField(pk=True)
username = fields.CharField(max_length=50)
email = fields.CharField(max_length=100)
Выполнение запросов тоже не вызывает сложностей:
user = await User.filter(username="test_user").first()
Почему TortoiseORM впечатляет
Нативная асинхронность
Поддержка async/await
встроена по умолчанию. Это значит, что вы можете эффективно работать с большим количеством одновременных запросов без дополнительной настройки.
Простота и удобство
В отличие от некоторых других ORM, здесь нет необходимости погружаться в сложную документацию или изучать новые концепции. Все просто и понятно с первого взгляда.
Производительность
В моих тестах TortoiseORM показала высокую производительность при работе с большими объемами данных. Асинхронные операции выполняются быстро и без задержек, что критично для высоконагруженных приложений.
Сравнение с другими ORM
Peewee: Отличная ORM для синхронных приложений, но отсутствие нативной асинхронности может стать препятствием в современных проектах.
SQLAlchemy: Мощный инструмент с большим количеством возможностей, но сложность настройки асинхронности и громоздкий синтаксис могут отпугнуть.
PonyORM: Удобный декларативный синтаксис, но в некоторых случаях уступает TortoiseORM в производительности и простоте использования.
Плюсы TortoiseORM
Асинхронность из коробки: Нет необходимости в дополнительных библиотеках или сложных настройках.
Знакомый синтаксис: Быстрое освоение благодаря сходству с Django ORM.
Высокая производительность: Оптимизирована для работы с большим количеством одновременных запросов.
Широкая поддержка баз данных: Работает с PostgreSQL, MySQL, SQLite и другими.
Активное развитие: Сообщество активно поддерживает и развивает проект.
Заключение
Это моя первая статья, и, хотя у меня нет большого опыта в написании, мне хотелось поделиться своей находкой с другими. Открыв для себя TortoiseORM, я был приятно удивлен ее возможностями и удобством. Для разработчиков на Python, которым нужна эффективная и простая в использовании асинхронная ORM, это решение может стать настоящей находкой. Рекомендую попробовать TortoiseORM в своих проектах — возможно, она удивит вас так же, как и меня.
Комментарии (13)
kalbas
15.10.2024 16:24С тех пор, как я слез с иглы ORM на сырые SQL-запросы, моя жизнь заиграла новыми красками. Я даже не представляю себе, как там сейчас, с этими ормами. Как вы там пишете заковыристые цте-шки? Оконные функции? Че вообще с производительностью?
rebug
15.10.2024 16:24А как у вас дела в плане инъекций? Я вот использую орм, чтобы такого не произошло. А как вы решаете данную проблему?
kalbas
15.10.2024 16:24Так это не ORM решает эту проблему, а библиотека реализующая интерфейс к базе. В случае с постгресом, который я преимущественно использую, это asyncpg, которая и выполняет подстановку параметров в запрос. Кстати тот же самый asyncpg использует и tortoise под капотом.
katb
15.10.2024 16:24SqlAlchemy поддерживает все это
kalbas
15.10.2024 16:24Она то умеет и довольно давно. Вот только Алхимией тоже пользоваться не особо тянет. Когда для каких-то специфичных вещей приходилось импортировать из
dbname.dialects
и вообще в каких-то нестандартных ситуациях городить огороды. Речь про первую версию, вторую я не смотрел. Кстати, когда там появилась поддержка async не напомните? И что с перформансом? И что с легкостью чтения кода?
titan_pc
15.10.2024 16:24Использовал однажды этот ОРМ подрубил к СУБД и накатил 200 таблиц. Потребление приложения при запуске tortoise.init-models() 30 Гигабайт RAM. Выбросил на помойку такую "Производительность"
WinLin2
15.10.2024 16:24На каждый асинхронный запрос ORM создает соединение с базой? Выигрыш в совмещении работы с базой и другими вычислениями?
rebug
15.10.2024 16:24А где минусы работы с тортойзом? Почему в статье нет ничего даже о банальном - проблемы с аннотациями? Такое чувство, будто вы вообще не работали с ним и написали (это еще вопрос сами ли) статью
ipakeev
15.10.2024 16:24Для меня минусом было постоянное чувство хрупкости и неполноценности ORM.
Ещё нужно упомянуть aerich: местами сыроват. Год назад испытал много головной боли в тестах или когда требовался откат миграции. Возвращаться нет желания.
MrSmitix
ChatGPT, напиши статью... А вообще можно было раскрыть больше кейсов в примерах. Раз уж решил писать. Привести бенчмарки в сравнений с остальными, как минимум. ORM хорошая и заслуживает внимания, но тема не раскрыта :(
Morty00 Автор
Это моя первая статья, и мне еще многому предстоит научиться в плане раскрытия тем и предоставления детальной информации. Я просто хотел рассказать о TortoiseORM, потому что мало людей до сих пор знают про нее.
RodionGork
Наверное легче научиться если посмотреть хорошие статьи коллег на эту тему. У вас честно говоря вышло так будто вы решили посвятить написанию статьи не больше 15 минут :) возможно сама тема выбрана не очень удачно если по ней оказалось нечего в общем-то сказать.