SQLAlchemy - SQLAlchemy
Автор (ы) оригинала | Майкл Байер |
---|---|
Первый выпуск | 14 февраля 2006 г . |
Стабильный выпуск | 1.4.15 / 11 мая 2021 г .
|
Репозиторий | |
Написано в | Python |
Операционная система | Кроссплатформенность |
Тип | Объектно-реляционное отображение |
Лицензия | Лицензия MIT |
Веб-сайт |
www |
SQLAlchemy - это набор инструментов SQL с открытым исходным кодом и объектно-реляционный преобразователь (ORM) для языка программирования Python, выпущенный по лицензии MIT .
Описание
Философия SQLAlchemy заключается в том, что реляционные базы данных ведут себя не так, как коллекции объектов, по мере увеличения масштаба и производительности, в то время как коллекции объектов ведут себя меньше как таблицы и строки, поскольку в них создается больше абстракции. По этой причине он принял шаблон сопоставления данных (аналогичный Hibernate для Java ), а не шаблон активной записи, используемый рядом других объектно-реляционных сопоставителей. Однако дополнительные плагины позволяют пользователям разрабатывать с использованием декларативного синтаксиса.
История
SQLAlchemy был впервые выпущен в феврале 2006 года и быстро стал одним из наиболее широко используемых инструментов объектно-реляционного сопоставления в сообществе Python наряду с ORM Django .
Пример
В следующем примере представлены отношения n-к-1 между фильмами и их режиссерами. Показано, как определенные пользователем классы Python создают соответствующие таблицы базы данных, как экземпляры со связями создаются с обеих сторон связи и, наконец, как можно запрашивать данные, демонстрируя автоматически сгенерированные SQL- запросы как для отложенной, так и для активной загрузки.
Определение схемы
Создание двух классов Python и соответствующих таблиц базы данных в СУБД:
from sqlalchemy import *
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relation, sessionmaker
Base = declarative_base()
class Movie(Base):
__tablename__ = "movies"
id = Column(Integer, primary_key=True)
title = Column(String(255), nullable=False)
year = Column(Integer)
directed_by = Column(Integer, ForeignKey("directors.id"))
director = relation("Director", backref="movies", lazy=False)
def __init__(self, title=None, year=None):
self.title = title
self.year = year
def __repr__(self):
return "Movie(%r, %r, %r)" % (self.title, self.year, self.director)
class Director(Base):
__tablename__ = "directors"
id = Column(Integer, primary_key=True)
name = Column(String(50), nullable=False, unique=True)
def __init__(self, name=None):
self.name = name
def __repr__(self):
return "Director(%r)" % (self.name)
engine = create_engine("dbms://user:pwd@host/dbname")
Base.metadata.create_all(engine)
Вставка данных
Можно вставить отношение режиссер-фильм через любую сущность:
Session = sessionmaker(bind=engine)
session = Session()
m1 = Movie("Robocop", 1987)
m1.director = Director("Paul Verhoeven")
d2 = Director("George Lucas")
d2.movies = [Movie("Star Wars", 1977), Movie("THX 1138", 1971)]
try:
session.add(m1)
session.add(d2)
session.commit()
except:
session.rollback()
Запрос
alldata = session.query(Movie).all()
for somedata in alldata:
print(somedata)
SQLAlchemy выдает следующий запрос к СУБД (без псевдонимов):
SELECT movies.id, movies.title, movies.year, movies.directed_by, directors.id, directors.name
FROM movies LEFT OUTER JOIN directors ON directors.id = movies.directed_by
Выход:
Movie('Robocop', 1987L, Director('Paul Verhoeven'))
Movie('Star Wars', 1977L, Director('George Lucas'))
Movie('THX 1138', 1971L, Director('George Lucas'))
lazy=True
Вместо этого при установке (по умолчанию) SQLAlchemy сначала будет выдавать запрос для получения списка фильмов и только при необходимости (ленивый) для каждого режиссера запрос, чтобы получить имя соответствующего режиссера:
SELECT movies.id, movies.title, movies.year, movies.directed_by
FROM movies
SELECT directors.id, directors.name
FROM directors
WHERE directors.id = %s
Смотрите также
Рекомендации
- Заметки
- Дар, Ной (12 августа 2008 г.). «Использование SQLAlchemy» . Developerworks . IBM . Проверено 8 февраля 2011 года . CS1 maint: обескураженный параметр ( ссылка )
- Рик Коупленд, Essential SQLAlchemy, O'Reilly , 2008, ISBN 0-596-51614-2