2

当 DEBUG=True 和 DEBUG=False 时,是否有可能看到原始 sql?对于方法 delete() 和 save()?我想记录我的应用程序的所有请求,但我不明白如何记录原始 sql。

4

1 回答 1

2

确保您阅读了有关 logging 的文档

您需要django.db.backends记录器RequireDebugFalse过滤器

示例设置:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        }
    },
    'handlers': {
        'console':{
            'level':'DEBUG',
            'filters': ['require_debug_false'],
            'class':'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers':['console'],
            'propagate': True,
            'level':'DEBUG',
        },
    }
}

注意:您也可以在 SQL 服务器配置中启用 SQL 查询日志记录,而无需接触 django。有关详细信息,请参阅您的 SQL Server 文档。

于 2013-07-04T11:37:53.290 回答