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‘: 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"

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

 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"
时间: 2024-10-05 23:03:23

Django学习系列之ORM-QuerySetAPI的相关文章

Django学习系列之模型

Django ORM简介 介绍 关系对象映射(Object Relational Mapping) Django中遵循Code first的原则,即根据代码中定义的类生成数据库 ORM中: 我们写的类表示数据库的表名 根据这个类创建的对象是表结构 Django ORM 一对多关系例子 定义urls.py from django.conf.urls import url from django.contrib import admin #导入django admin admin.autodisco

Django学习系列之django restframework

曾几何时,Ajax已经统治了Web开发中的客户端,而REST成为web世界中最流行的架构风格(architecture style).所以我们的选择变得很简单:前端ajax访问后端的RESTful API对资源进行操作Django中有一些可选的REST framework,比如django-piston,django-tasypie. 但是我和google(呵呵,不好意思)推荐这个:Django REST framework django-framework就是定义一个url,可以利用这个url

Django学习系列之中间件

中间件的定义 中间件是一个.一个的管道,如果相对任何所有的通过Django的请求进行管理都需要自定义中间件 中间件可以对进来的请求和出去的请求进行控制 中间件是一类 django请求生命周期 自定义中间件 process_request(self,request): 请求到达之后之后先执行这个中间件 process_view(self, request, callback, callback_args, callback_kwargs): process_exception(self, requ

Django学习系列之Form表单和ajax

ajax 通过ajax发送一条数据 定义urls.py from django.conf.urls import url from django.contrib import admin from cmdb import views urlpatterns = [ url(r'^ajax_demo/', views.ajax_demo), ] 定义views.py from django.shortcuts import render from django.shortcuts import H

Django学习系列之路由系统

一.基于App的路由 作用: 根据App对路由规则进行分类,在全局urls.py包含某个项目的urls.py 示例 定义全局urls.py(全局路由系统) #导入include from django.conf.urls import url,include from django.contrib import admin #导入app下的view函数 from learn import views urlpatterns = [ url(r'^admin/', admin.site.urls)

Django学习系列之CSRF

Django CSRF 什么是CSRF CSRF, Cross Site Request Forgery, 跨站点伪造请求.举例来讲,某个恶意的网站上有一个指向你的网站的链接,如果 某个用户已经登录到你的网站上了,那么当这个用户点击这个恶意网站上的那个链接时,就会向你的网站发来一个请求, 你的网站会以为这个请求是用户自己发来的,其实呢,这个请求是那个恶意网站伪造的 Django提供的CSRF防护机制 django 第一次响应来自某个客户端的请求时,会在服务器端随机生成一个 token,把这个 t

Django学习系列之基础

Django介绍 Django简介 Django是一个基于MVC构造的框架.但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Django 里更关注的是模型(Model).模板(Template)和视图(Views),称为 MTV模式,它们各自的职责如下: 模型(Model),即数据存取层 处理与数据相关的所有事务: 如何存取.如何验证有效性.包含哪些行为以及数据之间的关系等 视图(View),即表现层 处理与表现相关的决定: 如何在页面或其他类型文档中进行显示;模型与模板的桥

Django学习系列之模板系统

一.模板标签 if/else {%  if  %}标签检查一个变量的值是否为真或者等于另外一个值,如果为真,系统会执行{%  if  %}和{%  endif  %}之间的代码块,例如: {% if today_is_weekend %} <p>Welcome to the weekend!</p> {% endif %} {%  else  %}标签是可选的,如果不为真则执行{%  else  %}和{%  endif  %}之间的代码块 注意:一定要用{%  endif  %}

Django学习系列之Form验证

基与上篇文章,在这里我们用3种方式来验证表单. 1.表单字段的验证器 详见:https://docs.djangoproject.com/en/1.6/ref/validators/ from django.core.exceptions import ValidationError def validate_nickname(value):     if value == "badboy":         raise ValidationError(u'%s is private,