温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Django object.get_or_create()的使用方法是什么

发布时间:2021-12-08 16:28:36 来源:亿速云 阅读:250 作者:柒染 栏目:大数据

Django object.get_or_create()的使用方法是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

使用get_or_create()

  • 使用方式

    user, b = User.objects.get_or_create(u_id=1, name="张三", defaults={'address':'上海'})
    print(user)
  • 等同于

    users = User.objects.get(u_id=1, name="张三")
    if user:
        print(user)
    else:
        user = User.objects.create(u_id=1, name="张三", address="上海")
        print(user)

关于get_or_create()

说明

  • get_or_create顾名思义,查询或者创建一条数据,首先是执行的时候首先会去查询有没有这个值,如果有就返回,没有就创建。

  • get_or_create会返回一个tuple,第一个值是查到或者创建的数据,第二个值是一个布尔,表示是否执行了创建操作。

  • 在进行查询的时候和使用get查询类似,当查到超过一条数据的时候会触发MultipleObjectsReturned

  • 创建的时候也和使用create创建类似。

  • 如果你正在使用MySQL,请确保使用READ COMMITTED 隔离级别而不是默认的REPEATABLE READ,否则你将会遇到get_or_create 引发IntegrityError 但对象在接下来的get() 调用中并不存在的情况

看完上述内容,你们掌握Django object.get_or_create()的使用方法是什么的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI