django之单表操作
Posted zhaijihai
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django之单表操作相关的知识,希望对你有一定的参考价值。
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)
以上是关于django之单表操作的主要内容,如果未能解决你的问题,请参考以下文章