Django学习系列之ORM-QuerySetAPI

Posted 差点点温柔

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django学习系列之ORM-QuerySetAPI相关的知识,希望对你有一定的参考价值。

基本操作

 #
  
 models.Tb1.objects.create(c1=xx, c2=oo)  #增加一条数据,可以接受字典类型数据 **kwargs
  
 obj = models.Tb1(c1=xx, c2=oo)
 obj.save()
 
    dic = {c1:xx,c2:oo}
  models.Tb1.objects.create(**dic)         #Form的产出结果是一个字典,可以根据这个Form的字典和**直接在数据库创建数据

 #
models.Tb1.objects.get(id=123)                # 获取单条数据,不存在则报错(不建议)
models.Tb1.objects.all()                      # 获取全部     .first()  取第一条数据
models.Tb1.objects.filter(name=seven)       # 获取指定条件的数据   也可以用**的方式传参数
 
#
 
models.Tb1.objects.filter(name=seven).delete() # 删除指定条件的数据
 
#
 
models.Tb1.objects.filter(name=seven).update(gender=0)  # 将指定条件的数据更新,均支持 **kwargs

obj = models.Tb1.objects.get(id=1)
obj.c1 = 111
obj.save()                                                 # 修改单条数据

细看从数据库取出的类型

 w = models.Simp.objects.all()
 print w, type(w)
 [<Simp: chenc>, <Simp: zan>, <Simp: zhangsan>]    <class django.db.models.query.QuerySet>
 #可以看到,从数据库取出个数据看起来像包含对象的列表。而实际上整个数据为django中的特殊类型 QuerySet 。

.all() 是取得所有列的数据,可以加 .values() 取出某一列,每一项的值为一个 字典 :

 w = models.Simp.objects.all().values(username)
 print w, type(w)

[{username: uchenc}, {username: uzan}, {username: uzhangsan}] <class django.db.models.query.QuerySet>

.values_list(),获取到的值为一个 元组

w = models.Simp.objects.all().values_list(username)
print w, type(w)

[(uchenc,), (uzan,), (uzhangsan,)] <class django.db.models.query.QuerySet>

.values_list() 也可以添加多个参数:( 可以配合Form在前端生成动态的select )

w = models.Simp.objects.all().values_list(id, username)
print w, type(w)

[(1, uchenc), (2, uzan), (3, uzhangsan)] <class django.db.models.query.QuerySet>

query 可以查看执行的sql语句:

b = models.Simp.objects.all()
print b.query

SELECT "app01_simp"."id", "app01_simp"."username", "app01_simp"."password" FROM "app01_simp"

利用双下划线将字段和对应的操作连接起来

 

 1     # 获取个数
 2     #
 3     # models.Tb1.objects.filter(name=‘seven‘).count()
 4 
 5     # 大于,小于
 6     #
 7     # models.Tb1.objects.filter(id__gt=1)              # 获取id大于1的值
 8     # models.Tb1.objects.filter(id__lt=10)             # 获取id小于10的值
 9     # models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 获取id大于1 且 小于10的值
10 
11     # in
12     #
13     # models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
14     # models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in
15 
16     # contains
17     #
18     # models.Tb1.objects.filter(name__contains="ven")
19     # models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
20     # models.Tb1.objects.exclude(name__icontains="ven")
21 
22     # range
23     #
24     # models.Tb1.objects.filter(id__range=[1, 2])   # 范围bettwen and
25 
26     # 其他类似
27     #
28     # startswith,istartswith, endswith, iendswith,
29 
30     # order by
31     #
32     # models.Tb1.objects.filter(name=‘seven‘).order_by(‘id‘)    # asc 从小到大
33     # models.Tb1.objects.filter(name=‘seven‘).order_by(‘-id‘)   # desc 从大到小
34 
35     # limit 、offset
36     #
37     # models.Tb1.objects.all()[10:20]
38 
39     # group by
40     from django.db.models import Count, Min, Max, Sum
41     # models.Tb1.objects.filter(c1=1).values(‘id‘).annotate(c=Count(‘num‘))
42     # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"

 

以上是关于Django学习系列之ORM-QuerySetAPI的主要内容,如果未能解决你的问题,请参考以下文章

Django学习系列之captcha 验证码插件

Django学习系列之模型

Django学习系列之路由系统

Django学习系列之模板

Django学习系列之中间件

Django学习系列之CSRF