• django数据模型中关于on_delete, db_constraint的使用


    一、外键的删除

    关于on_delete的总结

    • 1、常见的使用方式(设置为null)

      class BookModel(models.Model):
          """
          书籍表
          """
          book_name = models.CharField(max_length=100, verbose_name='书名')
          # 表示外键关联到作者表,当作者表删除了该条数据,图书表中不删除,仅仅是把外键置空
          author = models.ForeignKey(AuthModel, null=True, blank=True, on_delete=models.SET_NULL)
          price = models.FloatField(verbose_name='价格')
          create_time = models.DateTimeField(auto_now_add=True, verbose_name='添加时间')
    • 2、关于别的属性的介绍

      • CASCADE:这就是默认的选项,级联删除,你无需显性指定它。
      • PROTECT: 保护模式,如果采用该选项,删除的时候,会抛出ProtectedError错误。
      • SET_NULL: 置空模式,删除的时候,外键字段被设置为空,前提就是blank=True, null=True,定义该字段的时候,允许为空。
      • SET_DEFAULT: 置默认值,删除的时候,外键字段设置为默认值,所以定义外键的时候注意加上一个默认值。
      • SET(): 自定义一个值,该值当然只能是对应的实体了
    • 3、补充说明:关于SET()的使用

      **官方案例**
      def get_sentinel_user():
          return get_user_model().objects.get_or_create(username='deleted')[0]
      
      class MyModel(models.Model):
          user = models.ForeignKey(
              settings.AUTH_USER_MODEL,
              on_delete=models.SET(get_sentinel_user),
          )

    ManyToMany参数(through,db_constraint)

     

    through : 指定自己写好的第三张表,我们可以给第三张表添加字段了(告诉Django不用建第三张表了,我们都给他配好了)

    复制代码
    class Book(models.Model):
        name=models.CharField(max_length=20)
        authors=models.ManyToMany('Author',through='Score')
    
    
    class Author(models.Model):
        name=models.CharField(max_length=20)
    
    
    class Score(models.Model):
        book=models.ForeignKey('Book')
        author=models.ForeignKey('Author')
        socre=models.IntegerField()
    复制代码

    如果只写manytomany,那么第三张是Django替我们建的,可以通过book.authors字段进行一系列操作(add(增),all(查),set(重置),remove(删除)),但是此时没法给第三张表加其他我们需要的字段,

    而如果不写,ManyToMany字段,那么我们可以通过Score来执行一些操作,但是此时book和author表已经没有直接的联系了,查询起来很繁琐

    有了authors=models.ManyToMany('Author',through='Score'),那么就既可以方便查,也方便业务,添加需要的字段

    db_constraint : 

    db_constraint=False,这个就是保留跨表查询的便利(双下划线跨表查询```),但是不用约束字段了,一半公司都用false,这样就省的报错,因为没有了约束(Field字段对象,既约束,又建立表与表之间的关系)


    limit_choices_to
    限制关联字段的对象范围


    related_name
    反向查询字段可以不用 表名小写,可以改名了

    db_table
    第三张表的名字
  • 相关阅读:
    【华为云技术分享】浅谈服务化和微服务化(上)
    STM32 GPIO的原理、特性、选型和配置
    【华为云技术分享】如何设计高质量软件-领域驱动设计DDD(Domain-Driven Design)学习心得
    【华为云技术分享】如何做一个优秀软件-可扩展的架构,良好的编码,可信的过程
    【华为云技术分享】华为云MySQL新增MDL锁视图特性,快速定位元数据锁问题
    如何使网站支持https
    如何说孩子才会听,怎么听孩子才肯说
    box-sizing布局学习笔记
    vertical-align属性笔记
    Github上整理的日常发现的好资源【转】
  • 原文地址:https://www.cnblogs.com/longfeiwang/p/10915939.html
Copyright © 2020-2023  润新知