A session keeps track of ORM objects and their changes, manages transactions and is used to perform queries.
A session is usually obtained using sessionmaker, which creates a Session class unique to your application. Most commonly, the Session class is bound to an engine, allowing instances to use the engine implicitly.
from sqlalchemy.orm import sessionmaker
# Initial configuration arguments
Session = sessionmaker(bind=engine)
The engine and Session should only be created once.
A session is an instance of the class we created:
# This session is bound to provided engine
session = Session()
Session.configure() can be used to configure the class later, e.g. application startup rather than import time.
Session = sessionmaker()
# later
Session.configure(bind=engine)
Arguments passed to Session directly override the arguments passed to sessionmaker.
session_bound_to_engine2 = Session(bind=engine2)
New or detached objects may be added to the session using add():
session.add(obj)
A sequence of objects may be added using add_all():
session.add_all([obj1, obj2, obj3])
An INSERT will be emitted to the database during the next flush, which happens automatically. Changes are persisted when the session is committed.