當前位置: 首頁>>代碼示例>>Python>>正文


Python sqlalchemy.DDL屬性代碼示例

本文整理匯總了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 
開發者ID:jpush,項目名稱:jbox,代碼行數:24,代碼來源:ddl.py

示例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) 
開發者ID:opentrials,項目名稱:collectors,代碼行數:21,代碼來源:20170123151655_add_trigger_for_meta_updated.py

示例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)'
#     ),
# ) 
開發者ID:SEL-Columbia,項目名稱:dokomoforms,代碼行數:27,代碼來源:answer.py

示例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 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:22,代碼來源:ddl.py

示例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) 
開發者ID:sqlalchemy,項目名稱:sqlalchemy,代碼行數:25,代碼來源:test_reflection.py

示例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.") 
開發者ID:jpush,項目名稱:jbox,代碼行數:32,代碼來源:ddl.py

示例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) 
開發者ID:jpush,項目名稱:jbox,代碼行數:36,代碼來源:ddl.py

示例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 
開發者ID:jpush,項目名稱:jbox,代碼行數:6,代碼來源:ddl.py

示例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)) 
開發者ID:jpush,項目名稱:jbox,代碼行數:7,代碼來源:ddl.py

示例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();')) 
開發者ID:opentrials,項目名稱:collectors,代碼行數:10,代碼來源:20170123151655_add_trigger_for_meta_updated.py

示例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 
開發者ID:SEL-Columbia,項目名稱:dokomoforms,代碼行數:10,代碼來源:util.py

示例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')) 
開發者ID:SEL-Columbia,項目名稱:dokomoforms,代碼行數:5,代碼來源:util.py


注:本文中的sqlalchemy.DDL屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。