Django ORM (2)

mac2022-06-30  102

添加表纪录

方式1

# create方法的返回值book_obj就是插入book表中的python葵花宝典这本书籍纪录对象 book_obj=Book.objects.create(title="python葵花宝典",state=True,price=100,publish="苹果出版社",pub_date="2012-12-12")

方式2

1 book_obj=Book(title="python葵花宝典",state=True,price=100,publish="苹果出版社",pub_date="2012-12-12") 2 book_obj.save()

查询表纪录

查询API

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 < 1 > all ():                  查询所有结果    < 2 > filter ( * * kwargs):       它包含了与所给筛选条件相匹配的对象    < 3 > get( * * kwargs):          返回与所给筛选条件相匹配的对象,返回结果有且只有一个,                              如果符合筛选条件的对象超过一个或者没有都会抛出错误。    < 4 > exclude( * * kwargs):      它包含了与所给筛选条件不匹配的对象   < 5 > order_by( * field):       对查询结果排序    < 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():            从返回结果中剔除重复纪录

 (1) all() :                调用者:objects管理器  返回queryset    (2) filter() :          调用者:objects管理器  返回queryset    (3) get方法():        调用者:objects管理器  返回查询到model对象 (注意:查询结果有且只有一个才执行)    (4) first(),last()方法:   调用者:queryset   返回model对象    (5) exclude():     调用者:objects管理器  返回queryset    (6) order_by():     由queryset对象调用,返回值是queryset    (7) count :数数  :  由queryset对象调用 返回int    (8) reverse():     由queryset对象调用,返回值是queryset    (9) exists():        由queryset对象调用 返回值布尔值    (10)values()方法:      由queryset对象调用,返回值是queryset    (11)values_list():  由queryset对象调用,返回值是queryset    (12)distinct():     由queryset对象调用,返回值是queryset

基于双下划线的模糊查询  

1 2 3 4 5 6 7 8 Book.objects. filter (price__in = [ 100 , 200 , 300 ])  # 其一 Book.objects. filter (price__gt = 100 )       # 大于 Book.objects. filter (price__gte = 100 )       # 大于等于 Book.objects. filter (price__lt = 100 )       # 小于 Book.objects. filter (price__range = [ 100 , 200 ])   # 域内 Book.objects. filter (title__contains = "python" )  # 包含 Book.objects. filter (title__icontains = "python" ) # 不区分大小写的 Book.objects. filter (title__startswith = "py" )   # 以...开头 Book.objects. filter (pub_date__year = 2012 )    #时间

删除表纪录

删除方法就是 delete()。它运行时立即删除对象而不返回任何值。例如:

1 model_obj.delete()

你也可以一次性删除多个对象。每个 QuerySet 都有一个 delete() 方法,它一次性删除 QuerySet 中所有的对象。

例如,下面的代码将删除 pub_date 是2005年的 Entry 对象:

1 Entry.objects. filter (pub_date__year = 2005 ).delete()

在 Django 删除对象时,会模仿 SQL 约束 ON DELETE CASCADE 的行为,换句话说,删除一个对象时也会删除与它相关联的外键对象。例如:

1 2 3 b = Blog.objects.get(pk = 1 ) # This will delete the Blog and all of its Entry objects. b.delete()

要注意的是: delete() 方法是 QuerySet 上的方法,但并不适用于 Manager 本身。这是一种保护机制,是为了避免意外地调用 Entry.objects.delete() 方法导致 所有的 记录被误删除。如果你确认要删除所有的对象,那么你必须显式地调用:

1 Entry.objects. all ().delete()  

如果不想级联删除,可以设置为:

1 pubHouse = models.ForeignKey(to = 'Publisher' , on_delete = models.SET_NULL, blank = True , null = True )

修改表纪录

1 Book.objects. filter (title__startswith = "py" ).update(price = 120 )

此外,update()方法对于任何结果集(QuerySet)均有效,这意味着你可以同时更新多条记录update()方法会返回一个整型数值,表示受影响的记录条数。

转载于:https://www.cnblogs.com/jiumo/p/9925759.html

最新回复(0)