WikiSort.ru - Не сортированное

ПОИСК ПО САЙТУ | о проекте
SQLAlchemy
Тип ORM
Разработчик Mike Bayer[1]
Написана на Python
Операционная система Кроссплатформенное ПО
Последняя версия

1.0.14 (6 июля 2016

[2])
Лицензия MIT License
Сайт sqlalchemy.org

SQLAlchemy — это программная библиотека на языке Python для работы с реляционными СУБД с применением технологии ORM. Служит для синхронизации объектов Python и записей реляционной базы данных. SQLAlchemy позволяет описывать структуры баз данных и способы взаимодействия с ними на языке Python без использования SQL[3]. Библиотека была выпущена в феврале 2006 под лицензией открытого ПО MIT[4].

Работает back-end для баз данных: MySQL, PostgreSQL, SQLite, Oracle и других,[5] между которыми можно переключаться изменением конфигурации[3].

Основные возможности

  • Использование ORM не является обязательным
  • Устоявшаяся архитектура
  • Возможность использовать SQL, написанный вручную
  • Поддержка транзакций
  • Создание запросов с использованием функций и выражений Python
  • Модульность и расширяемость
  • Дополнительная возможность раздельного определения объектного отображения и классов
  • Поддержка составных индексов
  • Поддержка отношений между классами, в том числе «один-ко-многим» и «многие-ко-многим»
  • Поддержка ссылающихся на себя объектов
  • Предварительная и последующая обработка данных (параметров запроса, результата)

и другие[6].

Преимущества использования

Использование SQLAlchemy для автоматической генерации SQL-кода имеет несколько преимуществ по сравнению с ручным написанием SQL[7]:

  • Безопасность. Параметры запросов экранируются, что делает атаки типа внедрение SQL-кода маловероятными.
  • Производительность. Повышается вероятность повторного использования запроса к серверу базы данных, что может позволить ему в некоторых случаях применить повторно план выполнения запроса.
  • Переносимость. SQLAlchemy, при должном подходе, позволяет писать код на Python, совместимый с несколькими back-end СУБД. Несмотря на стандартизацию языка SQL, между базами данных имеются различия в его реализации, абстрагироваться от которых и помогает SQLAlchemy.

Пример

Простейший пример с использованием SQLAlchemy в оперативной памяти:

>>> from sqlalchemy import create_engine
>>> engine = create_engine('sqlite:///:memory:')
>>> engine.execute("select 'Hello, World!'").scalar()
u'Hello, World!'

Применение и аналоги

SQLAlchemy находит применение в веб-фреймворках TurboGears, Pylons, Pyramid, Zope[8]. Например, известный социальный новостной сайт Reddit построен с использованием SQLAlchemy[1]. Список организаций, использующих SQLAlchemy, можно найти на сайте проекта.

У SQLAlchemy имеется несколько аналогов, в том числе: SQLObject (англ.) и Storm (англ.).

Примечания

  1. 1 2 AIX and UNIX Technical library, Using SQLAlchemy
  2. Blog - SQLAlchemy
  3. 1 2 Ziadé, 2008, p. 154-155.
  4. PyCon 2007 Wrapup,SQLAlchemy released 0.1.0 in February 2006 — O’Reilly Media
  5. SQLAlchemy Documentation, Engine Configuration (недоступная ссылка). Проверено 30 июля 2012. Архивировано 15 июня 2012 года.
  6. SQLAlchemy Features
  7. Copeland, 2008, p. 15.
  8. SQLAlchemyDA — a new unified database adapter for Zope 2

Ссылки

Литература

  • Rick Copeland. Essential SQLAlchemy. — O'Reilly Media., 2008. — 215 с. ISBN 0-596-51614-2.
  • Tarek Ziadé. Expert Python Programming. — Packt Publishing Ltd., 2008. — 372 с. ISBN 978-1-847194-94-7.

Данная страница на сайте WikiSort.ru содержит текст со страницы сайта "Википедия".

Если Вы хотите её отредактировать, то можете сделать это на странице редактирования в Википедии.

Если сделанные Вами правки не будут кем-нибудь удалены, то через несколько дней они появятся на сайте WikiSort.ru .




Текст в блоке "Читать" взят с сайта "Википедия" и доступен по лицензии Creative Commons Attribution-ShareAlike; в отдельных случаях могут действовать дополнительные условия.

Другой контент может иметь иную лицензию. Перед использованием материалов сайта WikiSort.ru внимательно изучите правила лицензирования конкретных элементов наполнения сайта.

2019-2024
WikiSort.ru - проект по пересортировке и дополнению контента Википедии