diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-02-11 17:00:47 -0500 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-02-12 16:55:48 -0500 |
| commit | c1f310df44033d943413170de878ce95fafa387e (patch) | |
| tree | 1c053d5a0bf8610393ba38bbb19a576383da357b /doc | |
| parent | bb7b353d6f97184d2689c8c682bab5caac4ec1e7 (diff) | |
| download | sqlalchemy-c1f310df44033d943413170de878ce95fafa387e.tar.gz | |
Allow SQL expression for ORM primary keys
A SQL expression can now be assigned to a primary key attribute for an ORM
flush in the same manner as ordinary attributes as described in
:ref:`flush_embedded_sql_expressions` where the expression will be evaulated
and then returned to the ORM using RETURNING, or in the case of pysqlite,
works using the cursor.lastrowid attribute.Requires either a database that
supports RETURNING (e.g. Postgresql, Oracle, SQL Server) or pysqlite.
Fixes: #3133
Fixes: #4494
Change-Id: I83da8357354de002cb04fa4a553f2a2f90c5157d
Diffstat (limited to 'doc')
| -rw-r--r-- | doc/build/changelog/unreleased_13/3133.rst | 10 | ||||
| -rw-r--r-- | doc/build/orm/persistence_techniques.rst | 38 |
2 files changed, 48 insertions, 0 deletions
diff --git a/doc/build/changelog/unreleased_13/3133.rst b/doc/build/changelog/unreleased_13/3133.rst new file mode 100644 index 000000000..c163e5296 --- /dev/null +++ b/doc/build/changelog/unreleased_13/3133.rst @@ -0,0 +1,10 @@ +.. change:: + :tags: feature, orm + :tickets: 3133 + + A SQL expression can now be assigned to a primary key attribute for an ORM + flush in the same manner as ordinary attributes as described in + :ref:`flush_embedded_sql_expressions` where the expression will be evaulated + and then returned to the ORM using RETURNING, or in the case of pysqlite, + works using the cursor.lastrowid attribute.Requires either a database that + supports RETURNING (e.g. Postgresql, Oracle, SQL Server) or pysqlite. diff --git a/doc/build/orm/persistence_techniques.rst b/doc/build/orm/persistence_techniques.rst index a26be6b4c..0a40e7795 100644 --- a/doc/build/orm/persistence_techniques.rst +++ b/doc/build/orm/persistence_techniques.rst @@ -32,6 +32,44 @@ flush/commit operation, the ``value`` attribute on ``someobject`` above is expired, so that when next accessed the newly generated value will be loaded from the database. +The feature also has conditional support to work in conjunction with +primary key columns. A database that supports RETURNING, e.g. PostgreSQL, +Oracle, or SQL Server, or as a special case when using SQLite with the pysqlite +driver and a single auto-increment column, a SQL expression may be assigned +to a primary key column as well. This allows both the SQL expression to +be evaluated, as well as allows any server side triggers that modify the +primary key value on INSERT, to be successfully retrieved by the ORM as +part of the object's primary key:: + + + class Foo(Base): + __tablename__ = 'foo' + pk = Column(Integer, primary_key=True) + bar = Column(Integer) + + e = create_engine("postgresql://scott:tiger@localhost/test", echo=True) + Base.metadata.create_all(e) + + session = Session(e) + + foo = Foo(pk=sql.select([sql.func.coalesce(sql.func.max(Foo.pk) + 1, 1)]) + session.add(foo) + session.commit() + +On PostgreSQL, the above :class:`.Session` will emit the following INSERT: + +.. sourcecode:: sql + + INSERT INTO foo (foopk, bar) VALUES + ((SELECT coalesce(max(foo.foopk) + %(max_1)s, %(coalesce_2)s) AS coalesce_1 + FROM foo), %(bar)s) RETURNING foo.foopk + +.. versionadded:: 1.3 + SQL expressions can now be passed to a primary key column during an ORM + flush; if the database supports RETURNING, or if pysqlite is in use, the + ORM will be able to retrieve the server-generated value as the value + of the primary key attribute. + .. _session_sql_expressions: Using SQL Expressions with Sessions |
