diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2014-11-29 16:31:30 -0500 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2014-11-29 16:31:30 -0500 |
commit | 2851811c9fdaa7b5d62288b31a38b1a8e6c8e8d0 (patch) | |
tree | 6983bb387ecbc0aff20e8c81fed8671acaa1992b /docs | |
parent | 2a06536d6e4bbdf8e3973877912ada1c0a54664c (diff) | |
download | alembic-2851811c9fdaa7b5d62288b31a38b1a8e6c8e8d0.tar.gz |
- Repaired the inspection, copying and rendering of CHECK constraints
and so-called "schema" types such as Boolean, Enum within the batch
copy system; the CHECK constraint will not be "doubled" when the table is
copied, and additionally the inspection of the CHECK constraint for
its member columns will no longer fail with an attribute error.
fixes #249
- Added two new arguments
:paramref:`.Operations.batch_alter_table.reflect_args`
and :paramref:`.Operations.batch_alter_table.reflect_kwargs`, so that
arguments may be passed directly to suit the
:class:`~.sqlalchemy.schema.Table`
object that will be reflected.
Diffstat (limited to 'docs')
-rw-r--r-- | docs/build/batch.rst | 53 | ||||
-rw-r--r-- | docs/build/changelog.rst | 27 |
2 files changed, 79 insertions, 1 deletions
diff --git a/docs/build/batch.rst b/docs/build/batch.rst index 338ab8a..4c03a66 100644 --- a/docs/build/batch.rst +++ b/docs/build/batch.rst @@ -61,6 +61,55 @@ which is the one kind of column-level ALTER statement that SQLite supports. to run "move and copy" unconditionally in all cases, including on databases other than SQLite; more on this is below. +.. _batch_controlling_table_reflection: + +Controlling Table Reflection +---------------------------- + +The :class:`~sqlalchemy.schema.Table` object that is reflected when +"move and copy" proceeds is performed using the standard ``autoload=True`` +approach. This call can be affected using the +:paramref:`~.Operations.batch_alter_table.reflect_args` and +:paramref:`~.Operations.batch_alter_table.reflect_kwargs` arguments. +For example, to override a :class:`~sqlalchemy.schema.Column` within +the reflection process such that a :class:`~sqlalchemy.types.Boolean` +object is reflected with the ``create_constraint`` flag set to ``False``:: + + with self.op.batch_alter_table( + "bar", + reflect_args=[Column('flag', Boolean(create_constraint=False))] + ) as batch_op: + batch_op.alter_column( + 'flag', new_column_name='bflag', existing_type=Boolean) + +Another use case, add a listener to the :class:`~sqlalchemy.schema.Table` +as it is reflected so that special logic can be applied to columns or +types, using the :meth:`~sqlalchemy.events.DDLEvents.column_reflect` event:: + + def listen_for_reflect(inspector, table, column_info): + "correct an ENUM type" + if column_info['name'] == 'my_enum': + column_info['type'] = Enum('a', 'b', 'c') + + with self.op.batch_alter_table( + "bar", + reflect_kwargs=dict( + listeners=[ + ('column_reflect', listen_for_reflect) + ] + ) + ) as batch_op: + batch_op.alter_column( + 'flag', new_column_name='bflag', existing_type=Boolean) + +The reflection process may also be bypassed entirely by sending a +pre-fabricated :class:`~sqlalchemy.schema.Table` object; see +:ref:`batch_offline_mode` for an example. + +.. versionadded:: 0.7.1 + added :paramref:`.Operations.batch_alter_table.reflect_args` + and :paramref:`.Operations.batch_alter_table.reflect_kwargs` options. + Dealing with Constraints ------------------------ @@ -101,6 +150,8 @@ the recreation of unnamed UNIQUE constraints, either they should be named in the first place, or again specified within :paramref:`.Operations.batch_alter_table.table_args`. +.. _batch_offline_mode: + Working in Offline Mode ----------------------- @@ -113,7 +164,7 @@ get this information, which means that "online" mode is required; the To support offline mode, the system must work without table reflection present, which means the full table as it intends to be created must be passed to :meth:`.Operations.batch_alter_table` using -:paramref:`.Operations.batch_alter_table.copy_from`:: +:paramref:`~.Operations.batch_alter_table.copy_from`:: meta = MetaData() some_table = Table( diff --git a/docs/build/changelog.rst b/docs/build/changelog.rst index 2287b9b..3c9927c 100644 --- a/docs/build/changelog.rst +++ b/docs/build/changelog.rst @@ -4,6 +4,33 @@ Changelog ========== .. changelog:: + :version: 0.7.1 + + .. change:: + :tags: bug, batch + :tickets: 249 + + Repaired the inspection, copying and rendering of CHECK constraints + and so-called "schema" types such as Boolean, Enum within the batch + copy system; the CHECK constraint will not be "doubled" when the table is + copied, and additionally the inspection of the CHECK constraint for + its member columns will no longer fail with an attribute error. + + .. change:: + :tags: feature, batch + + Added two new arguments + :paramref:`.Operations.batch_alter_table.reflect_args` + and :paramref:`.Operations.batch_alter_table.reflect_kwargs`, so that + arguments may be passed directly to suit the + :class:`~.sqlalchemy.schema.Table` + object that will be reflected. + + .. seealso:: + + :ref:`batch_controlling_table_reflection` + +.. changelog:: :version: 0.7.0 :released: November 24, 2014 |