Django2 QuerySetAPI常用API

# 增
  
 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.filtet(name__icontains='Searcher')      #过滤name字段包含Searcher的值并且不区分大小写,i是不区分大小写,contains是包含
models.Tb1.objects.filter(name='server').exclude(age='16') #获取指定条件的数据,但是排除某个条件(获取所有name=server的内容,但是排除age=16的)

# 删
 
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()                                                  # 修改单条数据

#排除
models.Tb1.objects.order_by('name')            #升序
models.Tb1.objects.order_by('-name')           #降序

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

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

[{'username': u'chenc'}, {'username': u'zan'}, {'username': u'zhangsan'}] <class 'django.db.models.query.QuerySet'>

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

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

[(u'chenc',), (u'zan',), (u'zhangsan',)] <class 'django.db.models.query.QuerySet'>

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

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

[(1, u'chenc'), (2, u'zan'), (3, u'zhangsan')] <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"
# 获取个数
    #
    # models.Tb1.objects.filter(name='seven').count()

    # 大于,小于
    #
    # models.Tb1.objects.filter(id__gt=1)              # 获取id大于1的值
    # models.Tb1.objects.filter(id__lt=10)             # 获取id小于10的值
    # models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 获取id大于1 且 小于10的值

    # in
    #
    # models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
    # models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in

    # contains
    #
    # models.Tb1.objects.filter(name__contains="ven")
    # models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
    # models.Tb1.objects.exclude(name__icontains="ven")

    # range
    #
    # models.Tb1.objects.filter(id__range=[1, 2])   # 范围bettwen and

    # 其他类似
    #
    # startswith,istartswith, endswith, iendswith,

    # order by
    #
    # models.Tb1.objects.filter(name='seven').order_by('id')    # asc 从小到大
    # models.Tb1.objects.filter(name='seven').order_by('-id')   # desc 从大到小

    # limit 、offset
    #
    # models.Tb1.objects.all()[10:20]

    # group by
    from django.db.models import Count, Min, Max, Sum
    # models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num'))
    # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"

多对多关系操作

1.创建多对多关系表

model.py

class Aihao(models.Model):
''爱好表'''
    name = models.CharField(max_length=122)
    person = models.ManyToManyField('Person')
 
    def __str__(self):
        return self.name
 
class Person(models.Model):
''人表'''
    name=  models.CharField(max_length=122)
 
    def __str__(self):
        return self.name
 
 
一个人有多个爱好,一个爱好可以被多个人拥有

2.生成数据库

python manage.py  makemigrations
python manage.py  migrate

3.在数据库客户端的展示

-爱好表里有一条数据,id是1

-人表里有一条数据,id是1

这张表是自动创建的,存储人和爱好的对应关系,这个表就是把人和爱好关联起来,可以看到aihao_id就是代表的爱好ID,person_id就是代表的人,就是person为Alex,爱好为吃饭

4.操作

查询

从人出发获取爱好

from  app01.models  import *
 
>>> p = Person.objects.get(id=2)  #获取一个人 的对象
 
>>> p.aihao.all()                 #获取这个人的所有爱好
<QuerySet [<Aihao: 吃饭>, <Aihao: 玩电脑>]>

从爱好出发获取人

>>> a = Aihao.objects.get(id=3)  #获取一个爱好 的对象
 
>>> a.person_set.all()           #获取有这个爱好的所有人
<QuerySet [<Person: Alex>]>  

删除

from app01.models import *
 
#删除和一个人相关的所有爱好
>>> d = Person.objects.get(id=3)   #获取Person表中id=3的人
>>> d.aihao.all()                           #获取第三张表中(关系对应表) id=3这个人的爱好
<QuerySet [<Aihao: 吃饭>, <Aihao: 玩电脑>]>
>>>d.aihao.clear()                         #在第三张表(关系对应表)中删除和id=3这个人关联的数据
>>> d.aihao.all()                            #获取第三张表中 id=3这个人的爱好
<QuerySet [<>]>                           #现在已经没了
 
 
#删除和这个爱好相关的所有人
>>> d = Person.objects.get(id=2)  #获取一个人 的对象
>>> d.aihao.clear()                       #删除和这个人关联的所有爱好 

一对多关系操作

class User(models.Model):
'''用户表'''
    name = models.CharField(max_length=20)
 
    def __str__(self):
        return self.name
 
 
 
class UserType(models.Model):
'''用户类型表'''
    name = models.CharField(max_length=20)
    user = models.ForeignKey(User) 

在数据库客户端查看

User表:

UserType表:

注:user_id字段就是User表的外键

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值