source: asadb/groups/migrations/0024_add_indices.py

space-accessstablestage
Last change on this file was a03cb61, checked in by ASA Group Database <asa-db@…>, 14 years ago

Add indices to database tables

Fixes ASA Trac #38. Also, makes space-related scripts quick instead of
stupidly slow...

  • Property mode set to 100644
File size: 15.6 KB
Line 
1# encoding: utf-8
2import datetime
3from south.db import db
4from south.v2 import SchemaMigration
5from django.db import models
6
7class Migration(SchemaMigration):
8
9    def forwards(self, orm):
10       
11        # Adding index on 'OfficeHolder', fields ['start_time']
12        db.create_index('groups_officeholder', ['start_time'])
13
14        # Adding index on 'OfficeHolder', fields ['person']
15        db.create_index('groups_officeholder', ['person'])
16
17        # Adding index on 'OfficeHolder', fields ['end_time']
18        db.create_index('groups_officeholder', ['end_time'])
19
20        # Adding unique constraint on 'AthenaMoiraAccount', fields ['username']
21        db.create_unique('groups_athenamoiraaccount', ['username'])
22
23        # Adding index on 'GroupNote', fields ['author']
24        db.create_index('groups_groupnote', ['author'])
25
26        # Adding unique constraint on 'OfficerRole', fields ['slug']
27        db.create_unique('groups_officerrole', ['slug'])
28
29        # Adding index on 'Group', fields ['abbreviation']
30        db.create_index('groups_group', ['abbreviation'])
31
32        # Adding index on 'Group', fields ['name']
33        db.create_index('groups_group', ['name'])
34
35        # Adding unique constraint on 'GroupStartup', fields ['group']
36        db.create_unique('groups_groupstartup', ['group_id'])
37
38
39    def backwards(self, orm):
40       
41        # Removing unique constraint on 'GroupStartup', fields ['group']
42        db.delete_unique('groups_groupstartup', ['group_id'])
43
44        # Removing index on 'Group', fields ['name']
45        db.delete_index('groups_group', ['name'])
46
47        # Removing index on 'Group', fields ['abbreviation']
48        db.delete_index('groups_group', ['abbreviation'])
49
50        # Removing unique constraint on 'OfficerRole', fields ['slug']
51        db.delete_unique('groups_officerrole', ['slug'])
52
53        # Removing index on 'GroupNote', fields ['author']
54        db.delete_index('groups_groupnote', ['author'])
55
56        # Removing unique constraint on 'AthenaMoiraAccount', fields ['username']
57        db.delete_unique('groups_athenamoiraaccount', ['username'])
58
59        # Removing index on 'OfficeHolder', fields ['end_time']
60        db.delete_index('groups_officeholder', ['end_time'])
61
62        # Removing index on 'OfficeHolder', fields ['person']
63        db.delete_index('groups_officeholder', ['person'])
64
65        # Removing index on 'OfficeHolder', fields ['start_time']
66        db.delete_index('groups_officeholder', ['start_time'])
67
68
69    models = {
70        'auth.group': {
71            'Meta': {'object_name': 'Group'},
72            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
73            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
74            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
75        },
76        'auth.permission': {
77            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
78            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
79            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
80            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
81            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
82        },
83        'auth.user': {
84            'Meta': {'object_name': 'User'},
85            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
86            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
87            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
88            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
89            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
90            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
91            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
92            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
93            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
94            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
95            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
96            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
97            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
98        },
99        'contenttypes.contenttype': {
100            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
101            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
102            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
103            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
104            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
105        },
106        'groups.activitycategory': {
107            'Meta': {'object_name': 'ActivityCategory'},
108            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
109            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
110        },
111        'groups.athenamoiraaccount': {
112            'Meta': {'object_name': 'AthenaMoiraAccount'},
113            'account_class': ('django.db.models.fields.CharField', [], {'max_length': '10'}),
114            'add_date': ('django.db.models.fields.DateField', [], {}),
115            'del_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
116            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '45'}),
117            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
118            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '45'}),
119            'mit_id': ('django.db.models.fields.CharField', [], {'max_length': '15'}),
120            'mod_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
121            'mutable': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
122            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '8'})
123        },
124        'groups.group': {
125            'Meta': {'ordering': "('name',)", 'object_name': 'Group'},
126            'abbreviation': ('django.db.models.fields.CharField', [], {'db_index': 'True', 'max_length': '10', 'blank': 'True'}),
127            'activity_category': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.ActivityCategory']", 'null': 'True', 'blank': 'True'}),
128            'advisor_name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
129            'athena_locker': ('django.db.models.fields.CharField', [], {'max_length': '20', 'blank': 'True'}),
130            'constitution_url': ('django.db.models.fields.CharField', [], {'max_length': '200', 'blank': 'True'}),
131            'description': ('django.db.models.fields.TextField', [], {}),
132            'funding_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
133            'group_class': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupClass']"}),
134            'group_email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
135            'group_funding': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupFunding']", 'null': 'True', 'blank': 'True'}),
136            'group_status': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupStatus']"}),
137            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
138            'main_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
139            'meeting_times': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
140            'name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'db_index': 'True'}),
141            'num_community': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
142            'num_grads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
143            'num_other': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
144            'num_undergrads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
145            'officer_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
146            'recognition_date': ('django.db.models.fields.DateTimeField', [], {}),
147            'update_date': ('django.db.models.fields.DateTimeField', [], {}),
148            'updater': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
149            'website_url': ('django.db.models.fields.URLField', [], {'max_length': '200'})
150        },
151        'groups.groupclass': {
152            'Meta': {'object_name': 'GroupClass'},
153            'description': ('django.db.models.fields.TextField', [], {}),
154            'gets_publicity': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
155            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
156            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
157            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
158        },
159        'groups.groupconstitution': {
160            'Meta': {'object_name': 'GroupConstitution'},
161            'dest_file': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
162            'failure_date': ('django.db.models.fields.DateTimeField', [], {'default': 'None', 'null': 'True', 'blank': 'True'}),
163            'failure_reason': ('django.db.models.fields.CharField', [], {'default': "''", 'max_length': '100', 'blank': 'True'}),
164            'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']", 'unique': 'True'}),
165            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
166            'last_download': ('django.db.models.fields.DateTimeField', [], {}),
167            'last_update': ('django.db.models.fields.DateTimeField', [], {}),
168            'source_url': ('django.db.models.fields.URLField', [], {'max_length': '200'}),
169            'status_msg': ('django.db.models.fields.CharField', [], {'max_length': '20'})
170        },
171        'groups.groupfunding': {
172            'Meta': {'object_name': 'GroupFunding'},
173            'contact_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
174            'funding_list': ('django.db.models.fields.CharField', [], {'max_length': '32', 'blank': 'True'}),
175            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
176            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
177            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
178        },
179        'groups.groupnote': {
180            'Meta': {'object_name': 'GroupNote'},
181            'acl_read_group': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
182            'acl_read_offices': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
183            'author': ('django.db.models.fields.CharField', [], {'max_length': '30', 'db_index': 'True'}),
184            'body': ('django.db.models.fields.TextField', [], {}),
185            'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']"}),
186            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
187            'timestamp': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'})
188        },
189        'groups.groupstartup': {
190            'Meta': {'object_name': 'GroupStartup'},
191            'create_athena_locker': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
192            'create_group_list': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
193            'create_officer_list': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
194            'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']", 'unique': 'True'}),
195            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
196            'president_kerberos': ('django.db.models.fields.CharField', [], {'max_length': '8'}),
197            'president_name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
198            'stage': ('django.db.models.fields.IntegerField', [], {}),
199            'submitter': ('django.db.models.fields.CharField', [], {'max_length': '30'}),
200            'treasurer_kerberos': ('django.db.models.fields.CharField', [], {'max_length': '8'}),
201            'treasurer_name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
202        },
203        'groups.groupstatus': {
204            'Meta': {'object_name': 'GroupStatus'},
205            'description': ('django.db.models.fields.TextField', [], {}),
206            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
207            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
208            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
209            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
210        },
211        'groups.officeholder': {
212            'Meta': {'object_name': 'OfficeHolder'},
213            'end_time': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(9999, 12, 31, 23, 59, 59, 999999)', 'db_index': 'True'}),
214            'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']"}),
215            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
216            'person': ('django.db.models.fields.CharField', [], {'max_length': '30', 'db_index': 'True'}),
217            'role': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.OfficerRole']"}),
218            'start_time': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now', 'db_index': 'True'})
219        },
220        'groups.officerrole': {
221            'Meta': {'object_name': 'OfficerRole'},
222            'description': ('django.db.models.fields.TextField', [], {}),
223            'display_name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
224            'grant_user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['auth.User']", 'null': 'True', 'blank': 'True'}),
225            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
226            'max_count': ('django.db.models.fields.IntegerField', [], {'default': '10000'}),
227            'publicly_visible': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
228            'require_student': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
229            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
230        }
231    }
232
233    complete_apps = ['groups']
Note: See TracBrowser for help on using the repository browser.