Files
sqlalchemy/examples/beaker_caching/helloworld.py
T
Mike Bayer 5ab558004c - The beaker_caching example has been reorgnized
such that the Session, cache manager,
declarative_base are part of environment, and
custom cache code is portable and now within
"caching_query.py".  This allows the example to
be easier to "drop in" to existing projects.
2010-07-21 16:19:08 -04:00

63 lines
2.6 KiB
Python

"""helloworld.py
Illustrate how to load some data, and cache the results.
"""
from environment import Session
from model import Person
from caching_query import FromCache
# load Person objects. cache the result under the namespace "all_people".
print "loading people...."
people = Session.query(Person).options(FromCache("default", "all_people")).all()
# remove the Session. next query starts from scratch.
Session.remove()
# load again, using the same FromCache option. now they're cached
# under "all_people", no SQL is emitted.
print "loading people....again!"
people = Session.query(Person).options(FromCache("default", "all_people")).all()
# want to load on some different kind of query ? change the namespace
# you send to FromCache
print "loading people two through twelve"
people_two_through_twelve = Session.query(Person).\
options(FromCache("default", "people_on_range")).\
filter(Person.name.between("person 02", "person 12")).\
all()
# the data is cached under the "namespace" you send to FromCache, *plus*
# the bind parameters of the query. So this query, having
# different literal parameters under "Person.name.between()" than the
# previous one, issues new SQL...
print "loading people five through fifteen"
people_five_through_fifteen = Session.query(Person).\
options(FromCache("default", "people_on_range")).\
filter(Person.name.between("person 05", "person 15")).\
all()
# ... but using the same params as are already cached, no SQL
print "loading people two through twelve...again!"
people_two_through_twelve = Session.query(Person).\
options(FromCache("default", "people_on_range")).\
filter(Person.name.between("person 02", "person 12")).\
all()
# invalidate the cache for the three queries we've done. Recreate
# each Query, which includes at the very least the same FromCache,
# same list of objects to be loaded, and the same parameters in the
# same order, then call invalidate().
print "invalidating everything"
Session.query(Person).options(FromCache("default", "all_people")).invalidate()
Session.query(Person).\
options(FromCache("default", "people_on_range")).\
filter(Person.name.between("person 02", "person 12")).invalidate()
Session.query(Person).\
options(FromCache("default", "people_on_range")).\
filter(Person.name.between("person 05", "person 15")).invalidate()