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


Python sqlalchemy.event方法代碼示例

本文整理匯總了Python中sqlalchemy.event方法的典型用法代碼示例。如果您正苦於以下問題:Python sqlalchemy.event方法的具體用法?Python sqlalchemy.event怎麽用?Python sqlalchemy.event使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sqlalchemy的用法示例。


在下文中一共展示了sqlalchemy.event方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: register_table

# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import event [as 別名]
def register_table(table):
	"""
	Register a database table. This will populate the information provided in
	DATABASE_TABLES dictionary. This also forwards signals to the appropriate
	listeners within the :py:mod:`server.signal` module.

	:param cls table: The table to register.
	"""
	metatable = table.metatable()
	database_tables[metatable.name] = metatable

	sqlalchemy.event.listen(table, 'before_delete', forward_signal_delete)
	sqlalchemy.event.listen(table, 'before_insert', forward_signal_insert)
	sqlalchemy.event.listen(table, 'before_update', forward_signal_update)
	return table 
開發者ID:rsmusllp,項目名稱:king-phisher,代碼行數:17,代碼來源:models.py

示例2: _install_session_variables_setter

# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import event [as 別名]
def _install_session_variables_setter(self):
        session_variables = collections.OrderedDict(self.constant_session_variables)
        session_variables.update(
            sorted(self.config[self.config_section_session_variables].iteritems()))

        setter_sql = 'SET ' + ' , '.join(
            'SESSION {} = {}'.format(name, value)
            for name, value in session_variables.iteritems())

        @sqlalchemy.event.listens_for(self.engine, 'connect')
        def set_session_variable(dbapi_connection, connection_record):
            """
            Execute "SET SESSION <var1> = <val1>, ..." to set the
            variables specified by the `constant_session_variables`
            attribute and in the appropriate configuration section.

            To be called automatically whenever a new low-level
            connection to the database is established.

            WARNING: for simplicity, the variable names and values are
            inserted "as is", *without* any escaping -- we assume we
            can treat config options (and, even more so, Python-level
            object attributes, of course) as a *trusted* source of
            data.
            """
            cursor = dbapi_connection.cursor()
            try:
                cursor.execute(setter_sql)
                cursor.execute('COMMIT')
            finally:
                cursor.close()

    # TODO after SQLAlchemy upgrade to 1.2+:
    # * add `pool_pre_ping = true :: bool` to config
    # * remove this method and the copyright note concerning this method... 
開發者ID:CERT-Polska,項目名稱:n6,代碼行數:37,代碼來源:config.py

示例3: _install_reconnector

# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import event [as 別名]
def _install_reconnector(self):
        # copied from:
        # http://docs.sqlalchemy.org/en/rel_0_9/core/pooling.html#disconnect-handling-pessimistic
        # and slightly adjusted
        @sqlalchemy.event.listens_for(sqlalchemy.pool.Pool, "checkout")
        def ping_connection(dbapi_connection, connection_record, connection_proxy):
            cursor = dbapi_connection.cursor()
            try:
                cursor.execute("SELECT 1")
            except Exception:
                # dispose the whole pool instead of invalidating one at a time
                connection_proxy._pool.dispose()
                # pool will try connecting again up to three times before giving up
                raise sqlalchemy.exc.DisconnectionError()
            cursor.close() 
開發者ID:CERT-Polska,項目名稱:n6,代碼行數:17,代碼來源:config.py

示例4: add_cors_headers_response_callback

# 需要導入模塊: import sqlalchemy [as 別名]
# 或者: from sqlalchemy import event [as 別名]
def add_cors_headers_response_callback(event):
    def cors_headers(request, response):
        response.headers.update({
        'Access-Control-Allow-Origin': '*',
        'Access-Control-Allow-Methods': 'POST,GET,DELETE,PUT,OPTIONS',
        'Access-Control-Allow-Headers': 'Origin, Content-Type, Accept, Authorization',
        'Access-Control-Allow-Credentials': 'true',
        'Access-Control-Max-Age': '1728000',
        })
    event.request.add_response_callback(cors_headers) 
開發者ID:ksanislo,項目名稱:TitleDB,代碼行數:12,代碼來源:__init__.py


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