books = Book.objects.filter(pk=3)
print(connection.queries)
打印出django底层执行的sql语句:是一个空的列表[]
def index(request):
books = Book.objects.all()
for book in books:
print(book)
print(connection.queries)
return HttpResponse('SUCCESS')
此时就会返回django底层执行的sql语句:
[{'sql': 'SELECT @@SQL_AUTO_IS_NULL', 'time': '0.000'},
{'sql': 'SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED', 'time': '0.000'},
{'sql': 'SELECT `book`.`id`, `book`.`name`, `book`.`pages`, `book`.`price`, `book`.`rating`, `book`.`author_id`, `book`.`publisher_id`, `book`.`score` FROM `book`', 'time': '0.000'}]
# 在做切片操作的时候【start,end,步长】,注意:不包括end位置的数据
books = Book.objects.all()[0:6:2]
for book in books:
print(book)
print(connection.queries)
return HttpResponse('SUCCESS')
返回的结果如下:
# 每两条数据去一条
Book object (1)
Book object (3)
Book object (5)
[{'sql': 'SELECT @@SQL_AUTO_IS_NULL', 'time': '0.000'},
{'sql': 'SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED', 'time': '0.016'},
{'sql': 'SELECT `book`.`id`, `book`.`name`, `book`.`pages`, `book`.`price`, `book`.`rating`, `book`.`author_id`, `book`.`publisher_id`, `book`.`score` FROM `book` LIMIT 6', 'time': '0.000'}]
def index(request):
# 调用len函数
books = Book.objects.filter(bookorder__price__gt=90)
print(len(books))
print(connection.queries)
return HttpResponse('SUCCESS')
执行的结果如下:
1
[{'sql': 'SELECT @@SQL_AUTO_IS_NULL', 'time': '0.000'},
{'sql': 'SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED', 'time': '0.000'},
{'sql': 'SELECT `book`.`id`, `book`.`name`, `book`.`pages`, `book`.`price`, `book`.`rating`, `book`.`author_id`, `book`.`publisher_id`, `book`.`score` FROM `book` INNER JOIN `book_order` ON (`book`.`id` = `book_order`.`book_id`) WHERE `book_order`.`price` > 90.0e0', 'time': '0.000'}]
def index(request):
books = Book.objects.all()
print(list(books))
print(connection.queries)
return HttpResponse('SUCCESS')
[{'sql': 'SELECT @@SQL_AUTO_IS_NULL', 'time': '0.000'},
{'sql': 'SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED', 'time': '0.000'},
{'sql': 'SELECT `book`.`id`, `book`.`name`, `book`.`pages`, `book`.`price`, `book`.`rating`, `book`.`author_id`, `book`.`publisher_id`, `book`.`score` FROM `book`', 'time': '0.000'}]
def index(request):
books = Book.objects.filter(bookorder__price__gte=90)
if books:
for book in books:
print(book)
print(connection.queries)
return HttpResponse('SUCCESS')
打印出结果:
Book object (2)
[07/Feb/2020 13:56:18] "GET / HTTP/1.1" 200 7
[{'sql': 'SELECT @@SQL_AUTO_IS_NULL', 'time': '0.000'},
{'sql': 'SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED', 'time': '0.000'},
{'sql': 'SELECT `book`.`id`, `book`.`name`, `book`.`pages`, `book`.`price`, `book`.`rating`, `book`.`author_id`, `book`.`publisher_id`, `book`.`score` FROM `book` INNER JOIN `book_order` ON (`book`.`id` = `book_order`.`book_id`) WHERE `book_order`.`price` >= 90.0e0', 'time': '0.000'}]
93.QuerySet转换为SQL的条件:迭代,切片(指定步长),len函数,list函数,判断
原文:https://www.cnblogs.com/guyan-2020/p/12272900.html