在Django中显示原始SQL,DEBUG = True& for delete()和save()

时间:2013-07-04 11:28:23

标签: python django

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

1 个答案:

答案 0 :(得分:2)

请务必阅读docs on logging

您需要django.db.backends loggerRequireDebugFalse filter

示例设置:

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 Server配置中启用SQL查询日志记录,而无需触及django。有关详细信息,请参阅SQL Server文档。