Django调试工具栏不显示SQL

ban*_*rjs 9 django django-debug-toolbar django-1.3

我最近安装了django-debug-toolbar.工具栏工作,我可以看到侧面的标签.但是,即使我明显执行了SQL查询(例如在管理员中),SQL选项卡中也没有显示任何内容: 在此输入图像描述

我的设置如下:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2'
        'NAME': 'mydatabase'
         ....
    }
}

# Backwards compatability with apps
DATABASE_ENGINE = DATABASES['default']['ENGINE'].split('.')[-1]
DATABASE_NAME = DATABASES['default']['NAME']

MIDDLEWARE_CLASSES = (
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'debug_toolbar.middleware.DebugToolbarMiddleware',
)

INSTALLED_APPS = (
    ...
    'debug_toolbar',
    ...
)

# Settings for the django-debug-toolbar
DEBUG_TOOLBAR_PANELS = (
    'debug_toolbar.panels.version.VersionDebugPanel',
    'debug_toolbar.panels.cache.CacheDebugPanel',
    'debug_toolbar.panels.timer.TimerDebugPanel',
    'debug_toolbar.panels.settings_vars.SettingsVarsDebugPanel',
    'debug_toolbar.panels.headers.HeaderDebugPanel',
    'debug_toolbar.panels.request_vars.RequestVarsDebugPanel',
    'debug_toolbar.panels.template.TemplateDebugPanel',
    'debug_toolbar.panels.sql.SQLDebugPanel',
    'debug_toolbar.panels.signals.SignalDebugPanel',
    # 'debug_toolbar.panels.logger.LoggingPanel',
)

def custom_show_toolbar(request):
    return request.user.is_staff

DEBUG_TOOLBAR_CONFIG = {
    'INTERCEPT_REDIRECTS':False,
    'SHOW_TOOLBAR_CALLBACK':custom_show_toolbar,
    'SHOW_TEMPLATE_CONTEXT':True,
    'HIDE_DJANGO_SQL':False,
}
Run Code Online (Sandbox Code Playgroud)

我正在使用Django 1.3和工具栏版本0.8.5.对这个问题的任何帮助都会很棒......

编辑: 根据答案,我决定发布我如何处理我的视图功能:

def func1(query, var1):
    query = query.filter(var__icontains=var1)
    return query

def func2(query, var2):
    query = query.filter(var__icontains=var2)
    return query

def parse(**kwargs):
    # Based on some logic call func1 and func2
    return query

def view(request, template="display.html"):
    # Do some request processing
    query = parse(request.GET.items())
    return render(request, template, { 'items':list(query) })
Run Code Online (Sandbox Code Playgroud)

Ale*_*x Q 6

确保在处理请求的同一线程中运行SQL.

Django调试工具栏似乎只是查看当前线程中运行的SQL语句,并假设这些是唯一与处理的请求相关的语句.


jpi*_*pic 2

我刚刚找到一个方法:

  • 右键单击“默认”
  • 单击检查元素
  • 找到附近有 style="display:none" 的表格
  • 编辑样式属性以将其删除

我不知道为什么我必须做这一切......