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)
您必须创建数据迁移。在文档中阅读有关它们的更多信息
步骤 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)