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 相关文章推荐
Python中动态创建类实例的方法
Mar 24 Python
Python中单、双下划线的区别总结
Dec 01 Python
Django使用httpresponse返回用户头像实例代码
Jan 26 Python
Python3中关于cookie的创建与保存
Oct 21 Python
python实现三次样条插值
Dec 17 Python
Python绘图Matplotlib之坐标轴及刻度总结
Jun 28 Python
tensorflow没有output结点,存储成pb文件的例子
Jan 04 Python
PyTorch的torch.cat用法
Jun 28 Python
详解pytorch中squeeze()和unsqueeze()函数介绍
Sep 03 Python
Python实现异步IO的示例
Nov 05 Python
opencv检测动态物体的实现
Jul 21 Python
详解Python中的for循环
Apr 30 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令牌 Token改进版
2008/07/18 PHP
PHP Document 代码注释规范
2009/04/13 PHP
php 变量定义方法
2009/06/14 PHP
mac环境中使用brew安装php5.5.15
2014/08/18 PHP
PHP实现百度人脸识别
2019/05/06 PHP
javascript 判断字符串是否包含某字符串及indexOf使用示例
2013/10/18 Javascript
javascript判断css3动画结束 css3动画结束的回调函数
2015/03/10 Javascript
NodeJS连接MongoDB数据库时报错的快速解决方法
2016/05/13 NodeJs
JS实现图片垂直居中显示小结
2016/12/13 Javascript
详解Vue用axios发送post请求自动set cookie
2017/05/10 Javascript
使用javascript函数编写简单银行取钱存钱流程
2018/05/26 Javascript
详解如何给React-Router添加路由页面切换时的过渡动画
2019/04/25 Javascript
[02:55]2018DOTA2国际邀请赛勇士令状不朽珍藏Ⅲ饰品一览
2018/08/01 DOTA
[02:47]2018年度DOTA2最佳辅助位选手4号位-完美盛典
2018/12/17 DOTA
Python实现对比不同字体中的同一字符的显示效果
2015/04/23 Python
python变量不能以数字打头详解
2016/07/06 Python
Python Nose框架编写测试用例方法
2017/10/26 Python
python Flask实现restful api service
2017/12/04 Python
Pycharm代码无法复制,无法选中删除,无法编辑的解决方法
2018/10/22 Python
python 字典的打印实现
2019/09/26 Python
如何利用pygame实现简单的五子棋游戏
2019/12/29 Python
Python numpy大矩阵运算内存不足如何解决
2020/11/19 Python
canvas实现烟花的示例代码
2020/01/16 HTML / CSS
eBay法国购物网站:eBay.fr
2017/10/21 全球购物
泰国的头号网上婴儿用品店:Motherhood.co.th
2019/04/09 全球购物
物理力学求职信
2014/02/18 职场文书
2014年乡镇植树节活动方案
2014/02/28 职场文书
企业安全生产责任书
2014/04/14 职场文书
大学班级学风建设方案
2014/05/01 职场文书
杨善洲电影观后感
2015/06/04 职场文书
致接力运动员加油稿
2015/07/21 职场文书
2015年秋季校长开学典礼致辞
2015/07/29 职场文书
新教师教学工作总结
2015/08/14 职场文书
财务年终工作总结大全
2019/06/20 职场文书
写作技巧:如何撰写商业计划书
2019/08/08 职场文书
实用干货:敬酒词大全,帮你应付各种场合
2019/11/21 职场文书