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中的装饰器详解
Apr 13 Python
Python+pandas计算数据相关系数的实例
Jul 03 Python
Python爬虫实现验证码登录代码实例
May 10 Python
Python 监测文件是否更新的方法
Jun 10 Python
Python assert语句的简单使用示例
Jul 28 Python
基于Python安装pyecharts所遇的问题及解决方法
Aug 12 Python
pytorch中的卷积和池化计算方式详解
Jan 03 Python
解决Python数据可视化中文部分显示方块问题
May 16 Python
Python使用grequests并发发送请求的示例
Nov 05 Python
Python图像处理之膨胀与腐蚀的操作
Feb 07 Python
使用python向MongoDB插入时间字段的操作
May 18 Python
Python数据类型最全知识总结
May 31 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 checkdate、getdate等日期时间函数操作详解
2010/03/11 PHP
PHP中使用GD库创建圆形饼图的例子
2014/11/19 PHP
php中实现进程锁与多进程的方法
2016/09/18 PHP
php操作路径的经典方法(必看篇)
2016/10/04 PHP
yii2.0整合阿里云oss删除单个文件的方法
2017/09/19 PHP
CSS3画一个阴阳八卦图
2021/03/09 HTML / CSS
Stop SQL Server
2007/06/21 Javascript
jQuery 对象中的类数组操作
2009/04/27 Javascript
jquery 模拟雅虎首页的点击对话框效果
2010/04/11 Javascript
js复制网页内容并兼容各主流浏览器的代码
2013/12/17 Javascript
jquery插件开发之实现md5插件
2014/03/17 Javascript
jQuery中slideUp()方法用法分析
2014/12/24 Javascript
JavaScript仿淘宝页面图片滚动加载及刷新回顶部的方法解析
2016/05/24 Javascript
js简单时间比较的方法
2016/08/02 Javascript
jquery tmpl模板(实例讲解)
2017/09/02 jQuery
nodejs中art-template模板语法的引入及冲突解决方案
2017/11/07 NodeJs
详解使用webpack打包编写一个vue-toast插件
2017/11/08 Javascript
Angular异步变同步处理方法
2018/08/13 Javascript
[03:07]DOTA2英雄基础教程 冰霜诅咒极寒幽魂
2013/12/06 DOTA
Python中使用Beautiful Soup库的超详细教程
2015/04/30 Python
Python上传package到Pypi(代码简单)
2016/02/06 Python
Python实现自动添加脚本头信息的示例代码
2016/09/02 Python
CentOS7下python3.7.0安装教程
2018/07/30 Python
python抓取网页内容并进行语音播报的方法
2018/12/24 Python
Python元组知识点总结
2019/02/18 Python
详解Django中views数据查询使用locals()函数进行优化
2020/08/24 Python
HTML5 Geolocation API的正确使用方法
2018/12/04 HTML / CSS
在HTML5 Canvas中放入图片和保存为图片的方法
2014/05/03 HTML / CSS
微信小程序canvas实现水平、垂直居中效果
2020/02/05 HTML / CSS
新英格兰最大的特色礼品连锁店:The Paper Store
2018/07/23 全球购物
化学工程专业求职信
2014/08/10 职场文书
公司承诺书格式范文
2015/04/28 职场文书
关于元旦的广播稿2016
2015/12/17 职场文书
关于感恩的歌曲整理(8首)
2019/08/14 职场文书
MySQL触发器的使用
2021/05/24 MySQL
Python 使用 Frame tkraise() 方法在 Tkinter 应用程序中的Frame之间切换
2022/04/24 Python