如何在 Python 模型迁移中生成基于函数的索引?

Dav*_*ave 2 migration django postgresql indexing python-3.x

我正在使用 Django、Python 3.7 和 PostGres 9.5。为了加快特定查询的速度,我想创建这个功能索引,我通常会在 PostGres 中这样做......

CREATE INDEX my_article_idx ON article (regexp_replace(url, '\?.*$', ''))
Run Code Online (Sandbox Code Playgroud)

然而,在 Django 和自动生成的迁移的世界中,我不确定如何在 models.py 文件中注释我的类,以便自动生成这个基于函数的索引。我的模型中的相关字段看起来像这样......

class Article(models.Model):
    ...
    url = models.TextField(default='', null=False)
Run Code Online (Sandbox Code Playgroud)

joz*_*ozo 5

您必须创建数据迁移。在文档中阅读有关它们的更多信息

步骤 1 - 创建一个空的数据迁移文件

python manage.py makemigrations --empty yourappname
Run Code Online (Sandbox Code Playgroud)

步骤 2 - 将自定义 sql 添加到迁移中:

# -*- coding: utf-8 -*-
# Generated by Django 1.11.14 on 2018-09-20 08:01
from __future__ import unicode_literals

from django.db import migrations


class Migration(migrations.Migration):

    dependencies = [
        ('yourapp', '0001_name_of_depending_migration'),
    ]

    operations = [
        migrations.RunSQL(
            sql="CREATE INDEX my_article_idx ON article (regexp_replace(url, '\?.*$', ''))",
            reverse_sql='DROP INDEX my_article_idx ON article'
        )
    ]
Run Code Online (Sandbox Code Playgroud)