数据库在高并发的场景下使用外键约束会有锁问题并且使用外键会增加运维成本,所以很多公司都规定生产环境的数据库禁止使用外键。那么不使用外键约束的情况下使用 Django ORM 如何实现关联查询两个表呢?这曾是困扰我很久的一个问题,今天终于找到了答案,写出来分享一下。Django 的 ForeignKey 和数据库的 FOREIGN KEY 并不一样。Django 的 ForeignKey 是一种逻辑上的两个表的关联关系,可以指定是否使用数据库的 FOREIGN KEY 约束。在开头提到的场景下,我们可以这样创建两个表对应的 Model,以省和市的关联举例:以上的 models.py 在执行 migrate 时生成的 SQL 如下:如果 ForeignKey 不添加db_constraint=False 参数,会在数据库中使用外键约束,生成以下SQL:。django的orm关于更新数据库的方法有update和save两种方法。auto_now=True自动更新,有一个条件,就是要通过django的model层。

Django ForeignKey与数据库的FOREIGN KEY约束详解

Django ForeignKey与数据库的FOREIGN KEY约束详解