Sophie

Sophie

distrib > Fedora > 20 > i386 > by-pkgid > e21865d196ae2bae9c46b9ac75aa7226 > files > 33

python-flask-sqlalchemy-1.0-2.fc20.noarch.rpm

.. _contexts:

.. currentmodule:: flask.ext.sqlalchemy

Introduction into Contexts
==========================

If you are planning on using only one application you can largely skip
this chapter.  Just pass your application to the :class:`SQLAlchemy`
constructor and you're usually set.  However if you want to use more than
one application or create the application dynamically in a function you
want to read on.

If you define your application in a function, but the :class:`SQLAlchemy`
object globally, how does the latter learn about the former?  The answer
is the :meth:`~SQLAlchemy.init_app` function::

    from flask import Flask
    from flask.ext.sqlalchemy import SQLAlchemy

    db = SQLAlchemy()

    def create_app():
        app = Flask(__name__)
        db.init_app(app)
        return app


What it does it preparing the application to work with
:class:`SQLAlchemy`.  However that does not now bind the
:class:`SQLAlchemy` object to your application.  Why doesn't it do that?
Because there might be more than one application created.

So how does :class:`SQLAlchemy` now really know about your application?
You will have to setup a request context.  If you are working inside a
Flask view function, that automatically happens.  However if you are
working inside the interactive shell, you will have to do that yourself
(see `Creating a Request Context
<http://flask.pocoo.org/docs/shell/#creating-a-request-context>`_).

In a nutshell, do something like this:

>>> from yourapp import create_app
>>> app = create_app()
>>> app.test_request_context().push()

Inside scripts it makes also sense to use the with-statement::

    def my_function():
        with app():
            user = db.User(...)
            db.session.add(user)
            db.session.commit()

Some functions inside Flask-SQLAlchemy also accept optionally the
application to operate on:

>>> from yourapp import db, create_app
>>> db.create_all(app=create_app())