4

使用models.varchar(...)字段創建模型時,正在創建varchar_pattern_ops索引。如何在django(1.8)遷移中刪除index varchar_pattern_ops?

這是我想刪除varchar_pattern_ops指數在遷移,並且在該領域中添加散列索引PostgreSQL中

   Table "public.logger_btilog" 
     Column  |   Type   | Modifiers 
------------------+--------------------------+----------- 
md5hash   | text      | 
id    | integer     | not null 
Indexes: 
    "logger_btilog_pkey" PRIMARY KEY, btree (id) 
    "logger_btilog_md5hash_6454d7bb20588b61_like" btree (md5hash varchar_pattern_ops) 

生成的表。

我試着這樣做:

# models.py 
class Btilog(models.Model): 
    md5hash = models.TextField(db_index=False) 
    [...] 

而且在遷移也迫使加db_field=False

# 0013_migration.py 
# -*- coding: utf-8 -*- 
from __future__ import unicode_literals 

from django.db import models, migrations 


class Migration(migrations.Migration): 

    dependencies = [ 
     ('logger', '0014_btilog_id'), 
    ] 

    operations = [ 
     # this should remove all indexes for md5hash, but it does not work 
     migrations.AlterField(
      model_name='btilog', 
      name='md5hash', 
      field=models.TextField(null=True, blank=True, db_index=False), 
     ), 
     migrations.RunSQL(
      "create index logger_btilog_md5hash_hashindex on logger_btilog using hash(md5hash);", 
      "drop index logger_btilog_md5hash_hashindex;" 
     ), 
] 

運行遷移後,這是在數據庫

       relation        | size 
--------------------------------------------------------------------+--------- 
public.logger_btilog            | 7185 MB 
public.logger_btilog_md5hash_6454d7bb20588b61_like     | 1442 MB 
public.logger_btilog_md5hash_hashindex        | 1024 MB 
public.logger_btilog_pkey           | 548 MB 

注意索引public.logger_btilog_md5hash_6454d7bb20588b61_like是我想要刪除的索引。正在Django的自動添加該指數,看this

更多信息對指數

vtfx=# \d logger_btilog_md5hash_6454d7bb20588b61_like 
Index "public.logger_btilog_md5hash_6454d7bb20588b61_like" 
Column | Type | Definition 
---------+------+------------ 
md5hash | text | md5hash 
btree, for table "public.logger_btilog" 

腳註:我不會混亂哈希索引的使用,我只希望做=(strictrly相等)where搜索在md5hash字段,然後(隨便)一hash指數將是最快,將佔據超過btree指數更少的空間(Django默認)

+0

你知道散列索引不會崩潰,安全,不會被複制,對不對? –

+0

不,我沒有......謝謝你指出,我會更多地閱讀。不過,問題在於其他索引刪除。 – jperelli

回答

7

好吧,我發現這裏的一些信息https://docs.djangoproject.com/en/1.8/_modules/django/db/backends/base/schema/#BaseDatabaseSchemaEditor.alter_field

並採用人工RunPython遷移刪除varchar_pattern_ops指數使用SchemaEditor

# -*- coding: utf-8 -*- 
from __future__ import unicode_literals 

from django.db import models, migrations 


import re 
def drop_md5hash_varchar_pattern_ops_index(apps, schemaEditor): 
    # code based on https://docs.djangoproject.com/en/1.8/_modules/django/db/backends/base/schema/#BaseDatabaseSchemaEditor.alter_field 
    model = apps.get_model("logger", "Btilog") 
    index_names = schemaEditor._constraint_names(model, index=True) 
    for index_name in index_names: 
     if re.search('logger_btilog_md5hash_.+_like', index_name): 
      print 'dropping index {}'.format(index_name) 
      schemaEditor.execute(schemaEditor._delete_constraint_sql(schemaEditor.sql_delete_index, model, index_name)) 


class Migration(migrations.Migration): 
    dependencies = [ 
     ('logger', '0012_auto_20150529_1745'), 
    ] 

    operations = [ 
     # Remove the annoying index using a hack 
     migrations.RunPython(
      drop_md5hash_varchar_pattern_ops_index 
     ), 
    ]