• 转载:django model orM 用字典作为参数,保存数据


     

    假设有一个字典,里面已经有了所有相关信息,现在想利用这个字典作为参数,跟django model  结合,用很少的代码量保存数据,有什么简便方法,比如有如下定义的model:
    程序代码 程序代码

    from django.db import models

    class MyModel(models.Model):
        title=models.CharField(max_length=250)
        body= models.CharField(max_length=1000)
        ....


    有一个字典:
    程序代码 程序代码

    data_dict = {
        'title' : 'awesome title',
        'body' : 'great body of text',
    }


    如果按照常规的做法,可能采用如下方式去保存数据:
    程序代码 程序代码

    mymodel = MyModel()
    mymodel.title = data_dict['title']
    mymodel.bdy = data_dict['body']
    mymodel.save()

    或者这样
    程序代码 程序代码

    mymodel = MyModel(title=data_dict['title'],body=data_dict['body'])
    mymodel.save()

    其实是一样的,从dict里面去取得数据。

    其实还有更简单的方法,直接传入这个dict数据,但前提是: 字典数据里面的key 字段一定要与model中定义的field 对应,否则就会报错.但事实上在封装dict数据的时候,完全可以对应的。用如下方法保存

    程序代码 程序代码

    mymodel = MyModel(**data_dict)
    mymodel.save()


    如果还有一些其他的扩展字段,也是可以加在里面的,但注意. **data_dict 必须放在最后:
    程序代码 程序代码

    mymodel  =MyModel(extra='hello', extra2='world', **data_dict)
    mymodel .save()


    还可以这样做:
    程序代码 程序代码

    MyModel.objects.create(**data_dict)


    这样就只是实现了django model保存dict ,并且还可以扩展

    2013-01-04日更新:最近在一篇文章中发现,如果要用字典dict作为参数更新一个model的方法如下:
    程序代码 程序代码

    mymodel=MyModel.objects.get(pk=pk)#....找到唯一的一个,自行修改
    mymodel.__dict__.update(data_dict )
    mymodel.save()

    当然也有用如下方式实现更新的:
    程序代码 程序代码

    MyModel.objects.filter(pk=pk).update(**data_dict )
  • 相关阅读:
    Jmeter简单教程
    SpringMVC @RequestBody请求参数在postman中的请求
    maven多环境部署
    idea中项目文件颜色含义
    本地Consumer和Producer无法使用远程Kafka服务器的处理办法
    CentOS7 64位下MySQL5.7安装与配置(YUM)
    git学习笔记
    Nginx的启动、重启、关闭命令
    Mysql update 错误
    spring框架源码编译
  • 原文地址:https://www.cnblogs.com/luyanyan5620/p/5592086.html
Copyright © 2020-2023  润新知