我们的orm里面分为:

jQueryset集合,

还有对象,

我们的jqueryset集合里面可以有多个对象,这句话的意思就是我们的对象是最小的单位,不可以再拆分了,我们的jQueryset集合就相当于是一个容器我们的一个个对象就放到这个容器里面,不论容器里面是否只有一个对象,还是没有对象,容器就是容器,本质是不会变的,就像我们的碗,即便是空碗里面什么都没有,它本质也是一个碗一样.

这里要强调它的本质,是因为我们的jQueryset集合和对象是分属于不同的领域,他们对应的方法也是不一样的,我们的jQueryset集合根本上的主流应用场景就是对我们的数据库的表格操作,对象也是一样的,

那么我们首先是需要先得到jQueryset集合或者是对象然后才能拿着它去数据库里面进行操作,下面的api常用方法就是帮我们拿到jQueryset集合或者是对象的方法,使用它们会有返回值,我们根据得到的返回值就可以知道是对象还是jQueryset集合,然后我们调用对应的方法

我们的对数据库的操作就是增删改查,

在jQueryset集合里面,我们的这个容器就类似于一个集合,我们的集合数据类型是可以在里面添加,修改,删除,查询对象的.

在对象里面,我们可以得到一个对象,然后对这个对象它本身就是最小的单位了,就像我们上面提到的,它是不可再拆分的,那么我们得到了它之后就无需再对它进行查询了,它本身就是我们查询的结果,然后同理,它本身就是结果了,我们也无需再对它进行增加了,它本身就是最小的单位了,无从增加,但是可以进行修改和删除,我们可以得到了这个对象然后把它删除,或者修改它,使用字典里面直接等于的方法,例如:对象.字段名(需要修改的字段值)=[新赋值的变量值]然后对象名.save()保存修改即可,我们的字典是直接使用到了key=新赋予的变量值,然后就完成了修改,但是在orm里面我们需要多一步操作保存修改save(),

teacher_obj=models.Teacher.objects.get(id=arg)

teacher_obj.tname=tname

teacher_obj.save()

所以我们的对象就只有删除和更改两个应用场景的操作,删除使用delete(),修改用赋值的方式加上save()

而jQueryset集合里面有增删改查,{创建数据使用create(),} add(),delete(),update(),-----[exclude,all,filter]这里的中括号里面的都是查询

queryset与惰性机制

我们的queryset内部是一个可迭代对象,它的特点就是惰性运算,我们的数据在里面生成之后就只是保存到里面而已,如果不调用他们,就会一直在里面存着不会显露出来,直到我们调用它才会有数据倒出来,queryset特点: 可迭代,可切片

objs=models.Book.objects.all()  # 假设objs里面有很多个值[obj1,obj2,obj3,,,,,]

for i in objs:

  print('obj:' i)

print(objs[1])

print(objs[1:4])

print(objs[::-1])  # 这里如果忘记了就提醒一下,我们的切片是从0到0,然后倒序切,从后往前开始切隔一个取一个值,

queryset的高效使用:

<1>django的queryset是惰性的
django的queryset对应于数据库的若干记录row,通过可选的查询来过滤,例如,下面的代码会得到数据库中国名字为'Dave'的所有人:Person_set=Person.objects.filter(first_name='Dave')
上面的代码并没有运行任何的数据库查询,你可以使用person_set,给它加上一些过滤条件,或者将它传给某个函数,这些操作都不会发送给数据库,这是对的,因为数据库的查询是显著影响文本应用性能的因素之一, <2>要真正从数据库获得数据,你可以遍历queryset或者使用if queryset,总之你用到数据时就会执行sql,为了验证这些,需要在setting里加入logging(验证方式)
obj=models.Book.objects.filter(id=3)
#for i in obj:
# print(i)
# if obj:
# print('ok') <3>queryset是具有cache的当你遍历queryset时,所有匹配的记录会从数据库获取,然后转换成django的model.这被称为执行(evaluation).这些model会保存在queryset内置的cache中,这样如果你再次遍历这个queryset,你不需要重复运行通用的查询, obj=models.Book.objects.filter(id=3)
# for i in obj:
# print(i) models.Book.objects.filter(id=2).update(title='go')
obj_new=models.Book.objects.filter(id=4)
# for i in obj:
# print(i) # logging只会打印一次 <4>简单的使用if语句进行判断也会完全执行整个queryset并把数据放入cache,虽然你并不需要这些数据!,为了避免这个,可以用exists()方法来检查是否有数据: obj=Book.objects.filter(id=2)
exists() 的检查可以避免数据放入queryset的cache,
if obj.exists():
print('hello world!') <5>当queryset非常巨大时,cache会成为问题处理成千上万的记录时,将它们一次装入内存是很浪费的,更糟糕的是,巨大的queryset可能会锁住系统进程,让你的程序濒临崩溃,要避免在遍历数据的同时产生queryset cache, 可以使用iterator()方法来获取数据,处理完数据就将其丢弃,
objs=Book.objects.all().iterator()
iterator()可以一次只从数据库获取少量数据,这样可以节省内存
for i in objs:
print(obj.name)
# but,在此遍历没有打印,因为迭代器已经在一次遍历(next)到最后一次了,没得遍历了,
for i in objs:
print(i.name) # 当然,使用iterator()方法来防止生成cache,意为这遍历同一queryset时会重复执行查询,所以使用iterator()的时候要当心,确保你的代码在操作一个大的queryset时没哟重复执行查询 总结:queryset的cache是用于减少程序对数据库的查询,在通常的使用下会保证只有在需要的时候才会查询数据库,使用exists()和iterator()方法可以以优化程序对内存的使用,不过,由于它们并不会生成queryset cache,可能会造成额外的数据库查询

前情回顾一下,:

django项目

安装:

创建项目

配置(setting,static,csrf)

创建app,python manage.py startapp app1

三部分

urls.py路由配置

1,普通正则

2分组正则

传位置参数:url(r'^blog/(\d+)/',views.blog)

3分组命名(得到的是关键字参数)

url(r'^blog/(?P<year>(\d+)/',views.blog'))    视图函数要传参blog(request,year)

4用name指定别名

url(r'^blog/$', views.blog, name='blog') 这里我们使用别名来进行反向解析,为了得到动态的HTML页面跳转效果

html里面:{%url 'blog'%}

views函数里面from django.urls import reverse

函数返回值里面return reverse("blog")

5使用命名空间

url(r'^blog/', include(app1.urls,namespace='num1' 2017 12))  这里也牵涉到反向解析

HTML里面{% url 'num1:blog'%}  url后面空一格写单引号,引号里面写namespace然后冒号name

views里面:from django.urls import reverse 返回值return redirect(reverse("num1:blog",arg=(2017,12)))

views.py

request对象

response对象

FBV和CBV

模板语言

{{变量}}

{{变量.}}如果变量是一个字典,我们直接使用这样的方法去取值

{%for%}循环

{%endfor%}结束循环

{%if%}判断

{%endif%}结束判断

过滤器(filter)  {{变量名|filter_name:参数}}

{{时间对象|date:'Y-m-d'}}

{%url%}

{%load static%}

{%static 'img/1.png'%}

母板,继承,块,组件

连接数据库(orm)

五步四部分

1创建数据库

2在app下的models.py里面创建model类,继承models.Model

3.在setting.py里面配置数据库连接信息

4在项目project的init里面写上import pymysql, pymysql.install_as_mysqldb()  # 这一句使用我们的pycharm会自动补全,有提示信息

5,发命令

python manage.py makemigrations  # 收集变更

python manage.py migrate  # 翻译成sql语句执行

四部分

models.py

django

pymysql

mysql

orm:类   数据表

类的属性

数据列 (表里面的字段)

对象   数据行

对表格进行增删改查:

查:

models.类名,objects.all()  取到所有的数据是一个列表  [取不到值是不会报错的,就显示为空]

models.类名,objects.get()  取到一个对象[特点是取不到值就会报错]

models.类名.objects.exclude(条件)  得到除了这个条件的其他的结果

models.类名.objects.first()

models.类名.objects.last()

增加:

一种方式:

models.类名.objects.create(name='peter')

一种方式:

obj = models.类名(name='peter')

obj.save()

删除:

models.类名,objects.filter(age=19).delete()

修改:

models.类名.objects.filter(age=90).update(name='greate')

单个对象是不能够调用update的[只有jQueryset才可以调用update方法]

update()方法对于任何结果集queryset均有效,这意味着我们可以同时更新多条记录update返回的是一个整型数据类型,表示受影响的条数

我们的对象要想使用修改操作只能够使用下面的方式直接赋值

obj=models.类名.objects.get(id=1)

obj.name='green'

obj.save()

今日内容:

单标的增删改查

单表查询的api介绍:

13条常用数据:

返回的是queryset对象

0.update()

1.all()

2.filter()

3.exclude()

4.values()

5.values_list()

6.order_by()

7.reverse()

8.distinct()

9.create()

10.delete()

11.order_by()

12.values()

13.values_list()

返回数字的:

count()

返回bool值的:

exists()

返回具体的数据对象的:

get()

first()

last()

delete()

下划线用法:

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

models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in models.Tb1.objects.filter(name__contains="ven") # 获取name字段包含"ven"的
models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感 models.Tb1.objects.filter(id__range=[1, 3]) # id范围是1到3的,等价于SQL的bettwen and 类似的还有:startswith,istartswith, endswith, iendswith  date字段还可以:
models.Class.objects.filter(first_day__year=2017)

在我们的pycharm里面python console里面先引入我们的models, from app名称 import models

然后就输入上面的命令即可

logging配置参数:

logging={

'version':1,  # 目前为止只有这一个值,当前使用版本

'disable_existing_loggers':false,  # 不禁用已经存在的logger实例

# 定义一些日志的处理方式

'handlers':{

'console':{

'level':''DEBUG'',

'class':'logging.streamhandler',

},

},

'loggers':{

'django.db.backends':{

'handlers':['console'],

'propagate':True,  # 向上传导

'level':''DEBUG'',

},

}

}

day 68 django 之api操作 | jQueryset集合与对象的更多相关文章

  1. Django QuerySet API文档

    在查询时发生了什么(When QuerySets are evaluated) QuerySet 可以被构造,过滤,切片,做为参数传递,这些行为都不会对数据库进行操作.只要你查询的时候才真正的操作数据 ...

  2. Django模型-数据库操作

    前言 前边记录的URLconf和Django模板全都是介绍页面展示的东西,也就是表现层的内容.由于Python先天具备简单而强大的数据库查询执行方法,Django 非常适合开发数据库驱动网站. 这篇开 ...

  3. django模型查询操作

    一旦创建好了数据模型,Django就会自动为我们提供一个数据库抽象API,允许创建.检索.更新和删除对象操作 下面的示例都是通过下面参考模型来对模型字段进行操作说明: from django.db i ...

  4. Django 2.0 学习(16):Django ORM 数据库操作(下)

    Django ORM数据库操作(下) 一.增加表记录 对于表单有两种方式: # 方式一:实例化对象就是一条表记录france_obj = models.Student(name="海地&qu ...

  5. django 通过orm操作数据库

    Django Model 每一个Django Model都继承自django.db.models.Model 在Model当中每一个属性attribute都代表一个database field 通过D ...

  6. Django~表的操作

    增(create  ,  save) from app01.models import *   #create方式一:   Author.objects.create(name='Alvin')    ...

  7. django models 数据库操作

    django models 数据库操作 创建模型 实例代码如下 from django.db import models class School(models.Model): pass class ...

  8. jackson学习之三:常用API操作

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  9. Django之ORM操作

    Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...

随机推荐

  1. 4)协程一(yeild)

    一:什么协程 协程: coroutine/coro - 轻量级线程(一个线程) - 调度由用户控制 - 有独立的寄存器上下文和栈 - 切换时保存状态,回来时恢复 二:协程和多线程比较 协程: coro ...

  2. HTML之Position用法

    在此,先做声明,本篇仅是摘录自互联网,个人认为这篇文章讲的很不错,附于此地与大家共同欣赏. position的四个属性值: 1.relative2.absolute3.fixed4.static下面分 ...

  3. Confluence 6 配置日志

    我们推荐你根据你的需求来配置你自己的 Confluence 日志.你可以有下面 2 种方法来修改你的日志: 通过 Confluence 管理员控制台进行配置 – 你的修改仅在本次修改有效,下次重启后将 ...

  4. Vue.extend和Vue.component的联系与差异

    extend 是构造一个组件的语法器. 你给它参数 他给你一个组件 然后这个组件 你可以作用到Vue.component 这个全局注册方法里, 也可以在任意vue模板里使用apple组件 var ap ...

  5. 学习Spring Boot:(一)入门

    微服务 现在微服务越来越火了,Spring Boot热度蹭蹭直升,自学下. 微服务其实是服务化思路的一种最佳实践方向,遵循SOA(面向服务的架构)的思路,各个企业在服务化治理上面的道路已经走得很远了, ...

  6. SpringBoot端口和访问路径

    更改启动端口:在application.properties配置文件中修改server.port=9090 更改项目访问路径:在application.properties配置文件中修改server. ...

  7. 【python】spark+kafka使用

    网上用python写spark+kafka的资料好少啊 自己记录一点踩到的坑~ spark+kafka介绍的官方网址:http://spark.apache.org/docs/latest/strea ...

  8. Metasploit one test

    1.对Metasploit的文件结构层次做一个目录结构图 2.漏洞利用的原理及其过程 攻击者发送一个附加攻击载荷的漏洞攻击代码给存在漏洞的系统.漏洞攻击代码首先执行,如果执行成功,攻击载荷中的实际代码 ...

  9. bzoj 3566

    非常好也是比较难的题 首先,不难看出这是一道树形的概率dp 那么我们就要考虑转移 我们发现,一个点能充上电的概率是这个点本身通电的概率+这个点的子节点给他传过来电的概率+这个点的父节点给他传过来电的概 ...

  10. js 对象(object)合并

    var obj1 = { name:'lisi', checked:'true' }; var obj2 = { name:'zhangsan', age:18 }; Object.assign(ob ...