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不规范的日期字符串处理类
Jun 10 Python
Python中关于字符串对象的一些基础知识
Apr 08 Python
Python 创建空的list,以及append用法讲解
May 04 Python
使用Python实现微信提醒备忘录功能
Dec 04 Python
pyttsx3实现中文文字转语音的方法
Dec 24 Python
Python实战之制作天气查询软件
May 14 Python
使用python将mysql数据库的数据转换为json数据的方法
Jul 01 Python
python编程进阶之异常处理用法实例分析
Feb 21 Python
django之从html页面表单获取输入的数据实例
Mar 16 Python
解决pymysql cursor.fetchall() 获取不到数据的问题
May 15 Python
用python绘制樱花树
Oct 09 Python
python gui开发——制作抖音无水印视频下载工具(附源码)
Feb 07 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的宝库目录--PEAR
2006/10/09 PHP
PHP执行SQL文件并将SQL文件导入到数据库
2015/09/17 PHP
thinkPHP和onethink微信支付插件分享
2019/08/11 PHP
Jquery 滑入滑出效果实现代码
2010/03/27 Javascript
利用JQuery动画制作滑动菜单项效果实现步骤及代码
2013/02/07 Javascript
JavaScript利用append添加元素报错的解决方法
2014/07/01 Javascript
原生js实现复制对象、扩展对象 类似jquery中的extend()方法
2014/08/30 Javascript
JavaScript接口的实现三种方式(推荐)
2016/06/14 Javascript
关于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法
2016/06/30 Javascript
BootStrap Table复选框默认选中功能的实现代码(从数据库获取到对应的状态进行判断是否为选中状态)
2017/07/11 Javascript
babel之配置文件.babelrc入门详解
2018/02/22 Javascript
在vue里面设置全局变量或数据的方法
2018/03/09 Javascript
vue左右侧联动滚动的实现代码
2018/06/06 Javascript
在element-ui的el-tree组件中用render函数生成el-button的实例代码
2018/11/05 Javascript
Vuepress 搭建带评论功能的静态博客的实现
2019/02/17 Javascript
理理Vue细节(推荐)
2019/04/16 Javascript
详解Vue-Router源码分析路由实现原理
2019/05/15 Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
2019/08/02 Javascript
CountUp.js实现数字滚动增值效果
2019/10/17 Javascript
详解Angular Karma测试的持续集成实践
2019/11/15 Javascript
稍微学一下Vue的数据响应式(Vue2及Vue3区别)
2019/11/21 Javascript
Python实现的简单万年历例子分享
2014/04/25 Python
用python代码做configure文件
2014/07/20 Python
python利用beautifulSoup实现爬虫
2014/09/29 Python
基于Python 的进程管理工具supervisor使用指南
2016/09/18 Python
python将每个单词按空格分开并保存到文件中
2018/03/19 Python
Python逐行读取文件中内容的简单方法
2019/02/26 Python
Python3.5面向对象程序设计之类的继承和多态详解
2019/04/24 Python
简单了解python关系(比较)运算符
2019/07/08 Python
python如何更新包
2020/06/11 Python
安装python3.7编译器后如何正确安装opnecv的方法详解
2020/06/16 Python
20佳惊艳的HTML5应用程序示例分享
2011/05/03 HTML / CSS
群众路线批评与自我批评发言稿
2014/10/16 职场文书
个人查摆问题自查报告
2014/10/16 职场文书
2014年旅游局法制宣传日活动总结
2014/11/01 职场文书
全陪导游词开场白
2015/05/29 职场文书