从Django QuerySet获取SQL

这个问题在这里已经有了答案:

  • 我怎样才能看到Django正在运行的原始SQL查询? 11个答案

  • 您打印queryquery属性。

    >>> queryset = MyModel.objects.all()
    >>> print queryset.query
    SELECT "myapp_mymodel"."id", ... FROM "myapp_mymodel"
    

    简单:

    print my_queryset.query
    

    例如:

    from django.contrib.auth.models import User
    print User.objects.filter(last_name__icontains = 'ax').query
    

    还应该提到的是,如果您有DEBUG = True,那么您的所有查询都会被记录下来,并且您可以通过访问connection.queries来获取它们:

    from django.db import connections
    connections['default'].queries
    

    django调试工具栏项目使用它以整洁的方式在页面上显示查询。


    在使用Django 1.4.4时,我接受的答案并不适用于我。 而不是原始查询,返回对Query对象的引用: <django.db.models.sql.query.Query object at 0x10a4acd90>

    以下内容返回了查询:

    >>> queryset = MyModel.objects.all()
    >>> queryset.query.__str__()
    
    链接地址: http://www.djcxy.com/p/38687.html

    上一篇: Getting the SQL from a Django QuerySet

    下一篇: Using Tag model to create ManytoMany relationship