在我的 django 模型中,当在字段定义中通过 db_index=True 创建索引时,不会创建索引。仅当我在 Meta 类中创建时
class Agreement(UUIDPrimaryKey):
job = models.ForeignKey(
'posts.Job',
on_delete=models.CASCADE,
verbose_name=_("job"),
)
class Meta:
indexes = (
models.Index(fields=['job']),
)
Run Code Online (Sandbox Code Playgroud)
如果我运行 makemigrations,就会创建索引。
Create index agreements__job_id_eb7df0_idx on field(s) job of model agreement
Run Code Online (Sandbox Code Playgroud)
但是如果我将模型更改为:
class Agreement(UUIDPrimaryKey):
job = models.ForeignKey(
'posts.Job',
on_delete=models.CASCADE,
verbose_name=_("job"),
db_index=True,
)
Run Code Online (Sandbox Code Playgroud)
我运行 makemigrations,索引被删除。
Remove index agreements__job_id_eb7df0_idx from agreement
Run Code Online (Sandbox Code Playgroud)
两个定义不应该相同吗?
更新
文档说它们是相同的。是的,两者都会创建索引。但是如果您在 Meta 中创建索引,并且在字段定义中未指定 db_index=False,则会创建两个索引。
这是在字段中设置 db_index=False 之前的情况
psql# select indexname from pg_indexes where tablename like 'agreemen%';
indexname
--------------------------------------------
agreements__job_id_eb7df0_idx
agreements_agreement_job_id_id_c26bd828
agreements_agreement_pkey
Run Code Online (Sandbox Code Playgroud)
设置 db_index=False 并运行迁移/迁移后
indexname
-------------------------------
agreements__job_id_eb7df0_idx
agreements_agreement_pkey
Run Code Online (Sandbox Code Playgroud)
数据库索引会自动在ForeignKey 上创建。至少文档是这样说的: https: //docs.djangoproject.com/en/2.1/ref/models/fields/#foreignkey。因此无需db_index=True在模型的ForeignKey 字段中进行设置。如果您不需要索引 ( db_index=False),该选项仍然存在。
| 归档时间: |
|
| 查看次数: |
3733 次 |
| 最近记录: |