Django开发过程中对表(model)的增删改查是最常用的功能之一,本文介绍笔者在使用model update过程中遇到的那些事

[ 运行环境:Django2.0 ]

model update常规用法

假如我们的表结构是这样的

class User(models.Model):username = models.CharField(max_length=255, unique=True, verbose_name='用户名')is_active = models.BooleanField(default=False, verbose_name='激活状态')

那么我们修改用户名和状态可以使用如下两种方法:

方法一:

User.objects.filter(id=1).update(username='nick',is_active=True)

方法二:

_t = User.objects.get(id=1)
_t.username='nick'
_t.is_active=True
_t.save()

方法一适合更新一批数据,类似于mysql语句update user set username='nick' where id = 1

方法二适合更新一条数据,也只能更新一条数据,当只有一条数据更新时推荐使用此方法,另外此方法还有一个好处,我们接着往下看

具有auto_now属性字段的更新

我们通常会给表添加三个默认字段

  • 自增ID,这个django已经默认加了,就像上边的建表语句,虽然只写了username和is_active两个字段,但表建好后也会有一个默认的自增id字段
  • 创建时间,用来标识这条记录的创建时间,具有auto_now_add属性,创建记录时会自动填充当前时间到此字段
  • 修改时间,用来标识这条记录最后一次的修改时间,具有auto_now属性,当记录发生变化时填充当前时间到此字段

就像下边这样的表结构

class User(models.Model):create_time = models.DateTimeField(auto_now_add=True, verbose_name='创建时间')update_time = models.DateTimeField(auto_now=True, verbose_name='更新时间')username = models.CharField(max_length=255, unique=True, verbose_name='用户名')is_active = models.BooleanField(default=False, verbose_name='激活状态')

当表有字段具有auto_now属性且你希望他能自动更新时,必须使用上边方法二的更新,不然auto_now字段不会更新,也就是:

_t = User.objects.get(id=1)
_t.username='nick'
_t.is_active=True
_t.save()

json/dict类型数据更新字段

目前主流的web开放方式都讲究前后端分离,分离之后前后端交互的数据格式大都用通用的jason型,那么如何用最少的代码方便的更新json格式数据到数据库呢?同样可以使用如下两种方法:

方法一:

data = {'username':'nick','is_active':'0'}
User.objects.filter(id=1).update(**data)
  • 同样这种方法不能自动更新具有auto_now属性字段的值
  • 通常我们再变量前加一个星号(*)表示这个变量是元组/列表,加两个星号表示这个参数是字典

方法二:

data = {'username':'nick','is_active':'0'}
_t = User.objects.get(id=1)
_t.__dict__.update(**data)
_t.save()
  • 方法二和方法一同样无法自动更新auto_now字段的值
  • 注意这里使用到了一个__dict__方法

方法三:

_t = User.objects.get(id=1)
_t.role=Role.objects.get(id=3)
_t.save()

ForeignKey字段更新

假如我们的表中有Foreignkey外键时,该如何更新呢?

class User(models.Model):create_time = models.DateTimeField(auto_now_add=True, verbose_name='创建时间')update_time = models.DateTimeField(auto_now=True, verbose_name='更新时间')username = models.CharField(max_length=255, unique=True, verbose_name='用户名')is_active = models.BooleanField(default=False, verbose_name='激活状态')role = models.ForeignKey(Role, on_delete=models.CASCADE, null=True, verbose_name='角色')

方法一:

User.objects.filter(id=1).update(role=2)
  • 最简单的方法,直接让给role字段设置为一个id即可
  • 当然也可以用dict作为参数更新:
User.objects.filter(id=1).update(**{'username':'nick','role':3})

方法二:

_role = Role.objects.get(id=2)
User.objects.filter(id=1).update(role=_role)
  • 也可以赋值一个实例给role
  • 当然也可以用dict作为参数更新:
_role = Role.objects.get(id=1)
User.objects.filter(id=1).update(**{'username':'nick','role':_role})

方法三:

_t = User.objects.get(id=1)
_t.role=Role.objects.get(id=3)
_t.save()
  • 注意:这里的role必须赋值为一个对象,不能写id,不然会报错"User.role" must be a "Role" instance
  • 当使用dict作为参数更新时又有一点不同,如下代码:
_t = User.objects.get(id=1)
_t.__dict__.update(**{'username':'nick','role_id':2})
_t.save()
  • Foreignkey外键必须加上_id,例如:{'role_id':3}
  • role_id后边必须跟一个id(int或str类型都可),不能跟role实例

ManyToManyField字段更新

假如我们的表中有ManyToManyField字段时更新又有什么影响呢?

class User(models.Model):create_time = models.DateTimeField(auto_now_add=True, verbose_name='创建时间')update_time = models.DateTimeField(auto_now=True, verbose_name='更新时间')username = models.CharField(max_length=255, unique=True, verbose_name='用户名')is_active = models.BooleanField(default=False, verbose_name='激活状态')role = models.ForeignKey(Role, on_delete=models.CASCADE, null=True, verbose_name='角色')groups = models.ManyToManyField(Group, null=True, verbose_name='组')

m2m更新:m2m字段没有直接更新的方法,只能通过清空再添加的方法更新了

_t = User.objects.get(id=1)
_t.groups.clear()
_t.groups.add(*[1,3,5])
_t.save()
  • add():m2m字段添加一个值,当有多个值的时候可用列表,参照上边例子

    • _t.groups.add(2)
    • _t.groups.add(Group.objects.get(id=2))
  • remove():m2m字段移除一个值,,当有多个值的时候可用列表,参照上边例子
    • _t.groups.remove(2)
    • _t.groups.remove(Group.objects.get(id=2))
  • clear():清空m2m字段的值

Django model update的各种用法介绍相关推荐

  1. Django model select的各种用法详解

    <Django model update的各种用法介绍>文章介绍了Django model的各种update操作,这篇文章就是她的姊妹篇,详细介绍Django model select的用 ...

  2. php update语句,php中update语句用法介绍

    php中update语句用法介绍 发布时间:2020-06-12 16:40:44 来源:亿速云 阅读:175 作者:小新 本篇文章和大家了解一下php中update语句用法介绍.有一定的参考价值,有 ...

  3. Django Model设计详解

    Django Model 设计 Django Model设计是Django五项基础核心设计之一(Model设计,URL配置,View编写,Template设计,From使用),也是MVC模式中重要的环 ...

  4. Django Model 定义语法

    版本:1.7 主要来源:https://docs.djangoproject.com/en/1.7/topics/db/models/ 简单用法 from django.db import model ...

  5. django model

    本文一篇完全介绍django的最重要的model 6.django model 模型是数据唯一而且准确的信息来源.它包含正在储存的数据的重要字段和行为.一般来说,每一个模型都映射一个数据库表. 这个模 ...

  6. php中使用mysql的视图_MYSQL中视图的用法介绍(代码示例)

    本篇文章给大家带来的内容是关于MYSQL中视图的用法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 1.什么是视图 执行一条SQL,将结果集保存在一张虚拟表中 (相关 ...

  7. pm2常用的命令用法介绍

    pm2 是一个带有负载均衡功能的Node应用的进程管理器.当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载, PM2是完美的,下面我们来看pm2常用的命令用法介绍吧 ...

  8. django model数据 时间格式

    from datetime import datetime dt = datetime.now() print '时间:(%Y-%m-%d %H:%M:%S %f): ' , dt.strftime( ...

  9. 用C#实现MVC(Model View Control)模式介绍

    用C#实现MVC(Model View Control)模式介绍 作者:Matthew Cochran December 12, 2005 原文地址:http://www.c-sharpcorner. ...

最新文章

  1. codefirst数据库迁移
  2. python3入门书籍-Python学习路上不可或缺的3本书籍【经验分享】
  3. map中的erase成员函数用法
  4. WdatePicker获取不超过今天的值
  5. 2020年快手美妆行业数据价值报告
  6. windows无法移动修复此计算机,无法安装Windows 10移动创作者更新[修复] | MOS86
  7. 【UOJ】【34】多项式乘法
  8. python选择语句是什么语句_Python语言中的三种选择语句
  9. .bash_profile和.bashrc的什么区别
  10. socket编程:简单TCP服务器/客户端编程
  11. 数据库知识与技巧日常汇总
  12. 流氓的Lenovo Drivers Management联想驱动管理程序
  13. WiFi技术安全调研报告
  14. 因使用率过低,谷歌翻译退出中国
  15. Asis CTF 2016 b00ks
  16. 在vue中使用高德地图获取坐标与地址信息(包含点击+搜索)
  17. 利用DHT网络原理制作bt采集
  18. SemanticKITTI 数据集(ICCV 2019)
  19. 谷歌研究总监Peter Norvig赴斯坦福任教,著有《人工智能:一种现代方法》
  20. ERP系统里的BOM展开函数

热门文章

  1. git常用的10个命令
  2. html如何获取消息实体的长度,50道js面试题 XXXXX
  3. linux sshd自动登录,SSH自动登录的几种方法
  4. python代码覆盖率工具_Python代码覆盖率分析工具Coverage
  5. android alertdialog view,Android AlertDialog 方法setView(view,0,0,0,0)开发自定义对话框
  6. (补)20200328:两两交换链表中的节点(leetcode24)
  7. 用python如何制作表格步骤_Python中用xlwt制作表格实例讲解
  8. 任正非华为为什么暂不推出鸿蒙,任正非表示,华为的鸿蒙系统已经上网?惊喜吗...
  9. 自动点击器如何设置最快_微视APP如何设置自动播放视频-微视APP设置自动播放视频的方法...
  10. 在java编程中会使用汉字字符_在java程序中将中文字符写入文件中或者是将文件中的中文字符读入程序时会出现乱码或者一串“?”,求...