Django中更新多个对象数据与删除对象的方法


Posted in Python onJuly 17, 2015

更新多个对象

例如说我们现在想要将Apress Publisher的名称由原来的”Apress”更改为”Apress Publishing”。若使用save()方法,如:

>>> p = Publisher.objects.get(name='Apress')
>>> p.name = 'Apress Publishing'
>>> p.save()

这等同于如下SQL语句:

SELECT id, name, address, city, state_province, country, website
FROM books_publisher
WHERE name = 'Apress';

UPDATE books_publisher SET
  name = 'Apress Publishing',
  address = '2855 Telegraph Ave.',
  city = 'Berkeley',
  state_province = 'CA',
  country = 'U.S.A.',
  website = 'http://www.apress.com'
WHERE id = 52;

(注意在这里我们假设Apress的ID为52)

在这个例子里我们可以看到Django的save()方法更新了不仅仅是name列的值,还有更新了所有的列。 若name以外的列有可能会被其他的进程所改动的情况下,只更改name列显然是更加明智的。 更改某一指定的列,我们可以调用结果集(QuerySet)对象的update()方法: 示例如下:

>>> Publisher.objects.filter(id=52).update(name='Apress Publishing')

与之等同的SQL语句变得更高效,并且不会引起竞态条件。

UPDATE books_publisher
SET name = 'Apress Publishing'
WHERE id = 52;

update()方法对于任何结果集(QuerySet)均有效,这意味着你可以同时更新多条记录。 以下示例演示如何将所有Publisher的country字段值由'U.S.A'更改为'USA':

>>> Publisher.objects.all().update(country='USA')
2

update()方法会返回一个整型数值,表示受影响的记录条数。 在上面的例子中,这个值是2。
删除对象

删除数据库中的对象只需调用该对象的delete()方法即可:

>>> p = Publisher.objects.get(name="O'Reilly")
>>> p.delete()
>>> Publisher.objects.all()
[<Publisher: Apress Publishing>]

同样我们可以在结果集上调用delete()方法同时删除多条记录。这一点与我们上一小节提到的update()方法相似:

>>> Publisher.objects.filter(country='USA').delete()
>>> Publisher.objects.all().delete()
>>> Publisher.objects.all()
[]

删除数据时要谨慎! 为了预防误删除掉某一个表内的所有数据,Django要求在删除表内所有数据时显示使用all()。 比如,下面的操作将会出错:

>>> Publisher.objects.delete()
Traceback (most recent call last):
 File "<console>", line 1, in <module>
AttributeError: 'Manager' object has no attribute 'delete'

而一旦使用all()方法,所有数据将会被删除:

>>> Publisher.objects.all().delete()

如果只需要删除部分的数据,就不需要调用all()方法。再看一下之前的例子:

>>> Publisher.objects.filter(country='USA').delete()

Python 相关文章推荐
pip matplotlib报错equired packages can not be built解决
Jan 06 Python
用于业余项目的8个优秀Python库
Sep 21 Python
使用pyqt5 tablewidget 单元格设置正则表达式
Dec 13 Python
python实现提取COCO,VOC数据集中特定的类
Mar 10 Python
python matplotlib.pyplot.plot()参数用法
Apr 14 Python
python/golang实现循环链表的示例代码
Sep 14 Python
Python 实现3种回归模型(Linear Regression,Lasso,Ridge)的示例
Oct 15 Python
Python下使用Trackbar实现绘图板
Oct 27 Python
使用Python通过oBIX协议访问Niagara数据的示例
Dec 04 Python
Python的logging模块基本用法
Dec 24 Python
python 基于DDT实现数据驱动测试
Feb 18 Python
opencv实现图像平移效果
Mar 24 Python
Django框架中数据的连锁查询和限制返回数据的方法
Jul 17 #Python
Django中对数据查询结果进行排序的方法
Jul 17 #Python
在Python的Django框架中获取单个对象数据的简单方法
Jul 17 #Python
Python的Django框架中的数据过滤功能
Jul 17 #Python
在Python的Django框架中更新数据库数据的方法
Jul 17 #Python
在Django框架中运行Python应用全攻略
Jul 17 #Python
Python的Django框架中的数据库配置指南
Jul 17 #Python
You might like
PHP中文件读、写、删的操作(PHP中对文件和目录操作)
2012/03/06 PHP
zf框架的校验器使用使用示例(自定义校验器和校验器链)
2014/03/13 PHP
Docker搭建自己的PHP开发环境
2018/02/24 PHP
一页面多XMLHttpRequest对象
2007/01/22 Javascript
用js查找法实现当前栏目的高亮显示的代码
2007/11/24 Javascript
ExtJs之带图片的下拉列表框插件
2010/03/04 Javascript
script标签的 charset 属性使用说明
2010/12/04 Javascript
纯JAVASCRIPT图表动画插件Highcharts Examples
2011/04/16 Javascript
Javascript中的方法链(Method Chaining)介绍
2015/03/15 Javascript
新手快速学习JavaScript免费教程资源汇总
2015/06/25 Javascript
jquery.form.js框架实现文件上传功能案例解析(springmvc)
2016/05/26 Javascript
AngularJS入门教程之MVC架构实例分析
2016/11/01 Javascript
JS简单生成随机数(随机密码)的方法
2017/05/11 Javascript
vue-router之解决addRoutes使用遇到的坑
2020/07/19 Javascript
在服务器端实现无间断部署Python应用的教程
2015/04/16 Python
谈谈Python进行验证码识别的一些想法
2016/01/25 Python
Python3.6简单反射操作示例
2018/06/14 Python
深入分析python中整型不会溢出问题
2018/06/18 Python
详解python 注释、变量、类型
2018/08/10 Python
浅谈django orm 优化
2018/08/18 Python
python读取xlsx的方法
2018/12/25 Python
Pytorch Tensor的索引与切片例子
2019/08/18 Python
GDAL 矢量属性数据修改方式(python)
2020/03/10 Python
python pandas.DataFrame.loc函数使用详解
2020/03/26 Python
Python requests.post方法中data与json参数区别详解
2020/04/30 Python
CSS3美化表单控件全集
2016/06/29 HTML / CSS
纯CSS3实现自定义Tooltip边框涂鸦风格的教程
2014/11/05 HTML / CSS
HTML5 常见面试题之PC端和移动端区别介绍
2018/01/22 HTML / CSS
丝芙兰巴西官方商城:SEPHORA巴西
2016/10/31 全球购物
求职简历中的自我评价分享
2013/12/08 职场文书
卫生巾广告词
2014/03/18 职场文书
质量管理标语
2014/06/12 职场文书
2015年三万活动总结
2015/03/25 职场文书
银行资信证明
2015/06/17 职场文书
Java elasticsearch安装以及部署教程
2021/06/28 Java/Android
idea下配置tomcat避坑详解
2022/04/12 Servers