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之单表操作的主要内容,如果未能解决你的问题,请参考以下文章

django之单表操作

Django之单表的增删改查

MYSQL基础操作之单表的增删改查

java进阶|MySQL数据库系列文章之单表操作SQL语句

MySQL基础语法之单表查询

MySQL之单表(增删改查)+ 基本命令