1.查询方法:
<1> all(): 查询所有结果
<2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象
<3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
<4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象
<5> order_by(*field): 对查询结果排序('-id')
<6> reverse(): 对查询结果反向排序
<8> count(): 返回数据库中匹配查询(QuerySet)的对象数量。
<9> first(): 返回第一条记录
<10> last(): 返回最后一条记录
<11> exists(): 如果QuerySet包含数据,就返回True,否则返回False
<12> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列
model的实例化对象,而是一个可迭代的字典序列
<13> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列
<14> distinct(): 从返回结果中剔除重复纪录
2.双下划綫之模糊查询:
<1> all(): 查询所有结果
<2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象
<3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
<4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象
<5> order_by(*field): 对查询结果排序('-id')
<6> reverse(): 对查询结果反向排序
<8> count(): 返回数据库中匹配查询(QuerySet)的对象数量。
<9> first(): 返回第一条记录
<10> last(): 返回最后一条记录
<11> exists(): 如果QuerySet包含数据,就返回True,否则返回False
<12> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列
model的实例化对象,而是一个可迭代的字典序列
<13> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列
<14> distinct(): 从返回结果中剔除重复纪录
单表查询练习
import os
if __name__ == '__main__':
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "template_import.settings")
import django
django.setup()
from template001 import models
book = models.Book.objects.create(name='红楼梦', price=23.8, publish='人民出版社', author='曹雪芹', create_data='2018-09-17')
book = models.Book.objects.create(name='红楼梦', price=23.8, publish='人民出版社', author='曹雪芹', create_data='2018-09-17')
import datetime
ctime = datetime.datetime.now()
book = models.Book.objects.create(name='西游记', price=100, publish='北京出版社', author='吴承恩', create_data=ctime)
ret = models.Book.objects.all()
print(ret)
#
# 1
# 查询老男孩出版社出版过的价格大于200的书籍
book = models.Book.objects.filter(price__gt='200',publish='老男孩出版社')
print(book)
# 2
# 查询2017年8月出版的所有以py开头的书籍名称
book = models.Book.objects.filter(name__startswith='py',create_data__range=['2018-08-01','2018-08-31'])
print(book)
# 3
# 查询价格为50, 100
# 或者150的所有书籍名称及其出版社名称
book = models.Book.objects.filter(price__in=['50','100'])
book2 = models.Book.objects.filter(price=150).values('name','price')
print(book)
print(book2)
# 4
# 查询价格在100到200之间的所有书籍名称及其价格
book = models.Book.objects.filter(price__range=[100, 200]).values('name','price')
print(book)
# 5
# 查询所有人民出版社出版的书籍的价格(从高到低排序,去重)
book = models.Book.objects.filter(publish='人民出版社').order_by('-price')
print(book)
# 6
# 查找所有书名里包含楼的书
book = models.Book.objects.filter(name__contains='楼')
print(book)
# 7
# 查找出版日期是2017年的书
book = models.Book.objects.filter(create_data__year='2017')
print(book)
# 8
# 查找出版日期是2017年的书名
book = models.Book.objects.filter(create_data__year='2017').values('name')
print(book)
# 9
# 查找价格大于10元的书
print('-----------')
book = models.Book.objects.filter(price__gt='10')
print(book)
# 10
# 查找价格大于10元的书名和价格
book = models.Book.objects.filter(price__gt='10').values('name','price')
print(book)