本文整理匯總了Python中sqlalchemy.DDL屬性的典型用法代碼示例。如果您正苦於以下問題:Python sqlalchemy.DDL屬性的具體用法?Python sqlalchemy.DDL怎麽用?Python sqlalchemy.DDL使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類sqlalchemy
的用法示例。
在下文中一共展示了sqlalchemy.DDL屬性的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: __init__
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def __init__(
self, element, on=None, bind=None,
include_foreign_key_constraints=None):
"""Create a :class:`.CreateTable` construct.
:param element: a :class:`.Table` that's the subject
of the CREATE
:param on: See the description for 'on' in :class:`.DDL`.
:param bind: See the description for 'bind' in :class:`.DDL`.
:param include_foreign_key_constraints: optional sequence of
:class:`.ForeignKeyConstraint` objects that will be included
inline within the CREATE construct; if omitted, all foreign key
constraints that do not specify use_alter=True are included.
.. versionadded:: 1.0.0
"""
super(CreateTable, self).__init__(element, on=on, bind=bind)
self.columns = [CreateColumn(column)
for column in element.columns
]
self.include_foreign_key_constraints = include_foreign_key_constraints
示例2: upgrade
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def upgrade():
conn = op.get_bind()
func = sa.DDL("""CREATE FUNCTION set_meta_updated()
RETURNS TRIGGER
LANGUAGE plpgsql
AS $$
BEGIN
NEW.meta_updated := now();
RETURN NEW;
END;
$$;""")
conn.execute(func)
for table in updatable_tables:
trigger_params = {'trigger': ('%s_set_meta_updated' % table), 'table': table}
trigger = ("""CREATE TRIGGER %(trigger)s
BEFORE UPDATE ON %(table)s
FOR EACH ROW EXECUTE PROCEDURE set_meta_updated();""" % trigger_params)
conn.execute(trigger)
示例3: add_new_photo_to_session
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def add_new_photo_to_session(session, *, id, **kwargs):
"""Create a new Photo and update the referenced PhotoAnswer."""
try:
answer = (
session
.query(PhotoAnswer)
.filter_by(main_answer=id)
.one()
)
except NoResultFound:
raise PhotoIdDoesNotExistError(id)
with session.begin():
answer.photo = Photo(id=id, **kwargs)
answer.actual_photo_id = answer.main_answer
return answer.photo
# sa.event.listen(
# Photo.__table__,
# 'after_create',
# sa.DDL(
# 'CREATE TRIGGER t_image BEFORE UPDATE OR DELETE ON photo'
# ' FOR EACH ROW EXECUTE PROCEDURE lo_manage(image)'
# ),
# )
示例4: __init__
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def __init__(
self, element, bind=None, include_foreign_key_constraints=None
):
"""Create a :class:`.CreateTable` construct.
:param element: a :class:`_schema.Table` that's the subject
of the CREATE
:param on: See the description for 'on' in :class:`.DDL`.
:param bind: See the description for 'bind' in :class:`.DDL`.
:param include_foreign_key_constraints: optional sequence of
:class:`_schema.ForeignKeyConstraint` objects that will be included
inline within the CREATE construct; if omitted, all foreign key
constraints that do not specify use_alter=True are included.
.. versionadded:: 1.0.0
"""
super(CreateTable, self).__init__(element, bind=bind)
self.columns = [CreateColumn(column) for column in element.columns]
self.include_foreign_key_constraints = include_foreign_key_constraints
示例5: define_tables
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def define_tables(cls, metadata):
# the actual function isn't reflected yet
dv = Table(
"data_values",
metadata,
Column("modulus", Integer, nullable=False),
Column("data", String(30)),
Column("q", Integer),
postgresql_partition_by="range(modulus)",
)
# looks like this is reflected prior to #4237
sa.event.listen(
dv,
"after_create",
sa.DDL(
"CREATE TABLE data_values_4_10 PARTITION OF data_values "
"FOR VALUES FROM (4) TO (10)"
),
)
if testing.against("postgresql >= 11"):
Index("my_index", dv.c.q)
示例6: execute
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def execute(self, bind=None, target=None):
"""Execute this DDL immediately.
Executes the DDL statement in isolation using the supplied
:class:`.Connectable` or
:class:`.Connectable` assigned to the ``.bind``
property, if not supplied. If the DDL has a conditional ``on``
criteria, it will be invoked with None as the event.
:param bind:
Optional, an ``Engine`` or ``Connection``. If not supplied, a valid
:class:`.Connectable` must be present in the
``.bind`` property.
:param target:
Optional, defaults to None. The target SchemaItem for the
execute call. Will be passed to the ``on`` callable if any,
and may also provide string expansion data for the
statement. See ``execute_at`` for more information.
"""
if bind is None:
bind = _bind_or_error(self)
if self._should_execute(target, bind):
return bind.execute(self.against(target))
else:
bind.engine.logger.info(
"DDL execution skipped, criteria not met.")
示例7: execute_at
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def execute_at(self, event_name, target):
"""Link execution of this DDL to the DDL lifecycle of a SchemaItem.
Links this ``DDLElement`` to a ``Table`` or ``MetaData`` instance,
executing it when that schema item is created or dropped. The DDL
statement will be executed using the same Connection and transactional
context as the Table create/drop itself. The ``.bind`` property of
this statement is ignored.
:param event:
One of the events defined in the schema item's ``.ddl_events``;
e.g. 'before-create', 'after-create', 'before-drop' or 'after-drop'
:param target:
The Table or MetaData instance for which this DDLElement will
be associated with.
A DDLElement instance can be linked to any number of schema items.
``execute_at`` builds on the ``append_ddl_listener`` interface of
:class:`.MetaData` and :class:`.Table` objects.
Caveat: Creating or dropping a Table in isolation will also trigger
any DDL set to ``execute_at`` that Table's MetaData. This may change
in a future release.
"""
def call_event(target, connection, **kw):
if self._should_execute_deprecated(event_name,
target, connection, **kw):
return connection.execute(self.against(target))
event.listen(target, "" + event_name.replace('-', '_'), call_event)
示例8: against
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def against(self, target):
"""Return a copy of this DDL against a specific schema item."""
self.target = target
示例9: __call__
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def __call__(self, target, bind, **kw):
"""Execute the DDL as a ddl_listener."""
if self._should_execute(target, bind, **kw):
return bind.execute(self.against(target))
示例10: downgrade
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def downgrade():
conn = op.get_bind()
for table in updatable_tables:
trigger_params = {'trigger': ('%s_set_meta_updated' % table), 'table': table}
trigger = ('DROP TRIGGER %(trigger)s ON %(table)s;' % trigger_params)
conn.execute(trigger)
conn.execute(sa.DDL('DROP FUNCTION set_meta_updated();'))
示例11: setUpModule
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def setUpModule():
"""Create the tables in the doko_test schema."""
engine.execute(DDL('DROP SCHEMA IF EXISTS doko_test CASCADE'))
try:
Base.metadata.create_all(engine)
except Exception:
engine.execute(DDL('DROP SCHEMA IF EXISTS doko_test CASCADE'))
raise
示例12: tearDownModule
# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import DDL [as 別名]
def tearDownModule():
"""Drop the doko_test schema."""
engine.execute(DDL('DROP SCHEMA IF EXISTS doko_test CASCADE'))