首页 > 编程 > Python > 正文

Django中的Model操作表的实现

2020-02-15 22:30:08
字体:
来源:转载
供稿:网友

Model 操作表

一、基本操作

# 增models.Tb1.objects.create(c1='xx', c2='oo') #增加一条数据,可以接受字典类型数据 **kwargsobj = 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') # 将指定条件的数据更新,均支持 **kwargsobj = 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': 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.querySELECT "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"            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表