使用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默認)
你知道散列索引不會崩潰,安全,不會被複制,對不對? –
不,我沒有......謝謝你指出,我會更多地閱讀。不過,問題在於其他索引刪除。 – jperelli