添加表纪录
方式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