Django的AutoField字段

本文探讨了Django框架中ORM默认为表添加自增ID作为主键的行为,解释了这种做法如何避免主从复制时因缺乏主键而导致的问题,并通过示例展示了如何在模型中实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Django是一个机智的框架

  默认情况下Djang会为ORM中定义的每一张表加上一个自增ID列,并且用这个列来做主键;出于一个MySQL-DBA的工作经历我觉得

  Djanog还真是机智;这样么说主要是因为我遇到过许多主从延时的问题,有些比较过分的会延时好几周,通常这些都是因为binlog格式

  为“ROW”但是表上不存在主键引起的。

  

  如果当前网站用的是Django开发的,我想就不会有这种事情发生了吧。

 

AutoField

  Django默认的行为就像这样

class TestModel(models.Model):
    id = models.AutoField(primary_key=True)

  数据库层面对应的SQL如下

CREATE TABLE `myapp_testmodel` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

 

注意

  如果你想的工增加AutoField列,但是又不指定这个列做为主键的话,是会报错的

class TestModel(models.Model):
    tid = models.AutoField()

  不显示指定主键,但是又给表增加AutoField列的话就会报错

assert not cls._meta.auto_field, "Model %s can't have more than one AutoField." % cls._meta.label
AssertionError: Model myapp.TestModel can't have more than one AutoField.

 

----

转载于:https://www.cnblogs.com/JiangLe/p/9626470.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值