source: asadb/space/migrations/0002_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: 8.1 KB
RevLine 
[a03cb61]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 'SpaceAssignment', fields ['end']
12        db.create_index('space_spaceassignment', ['end'])
13
14        # Adding index on 'SpaceAssignment', fields ['start']
15        db.create_index('space_spaceassignment', ['start'])
16
17        # Adding index on 'SpaceAccessListEntry', fields ['end']
18        db.create_index('space_spaceaccesslistentry', ['end'])
19
20        # Adding index on 'SpaceAccessListEntry', fields ['start']
21        db.create_index('space_spaceaccesslistentry', ['start'])
22
23
24    def backwards(self, orm):
25       
26        # Removing index on 'SpaceAccessListEntry', fields ['start']
27        db.delete_index('space_spaceaccesslistentry', ['start'])
28
29        # Removing index on 'SpaceAccessListEntry', fields ['end']
30        db.delete_index('space_spaceaccesslistentry', ['end'])
31
32        # Removing index on 'SpaceAssignment', fields ['start']
33        db.delete_index('space_spaceassignment', ['start'])
34
35        # Removing index on 'SpaceAssignment', fields ['end']
36        db.delete_index('space_spaceassignment', ['end'])
37
38
39    models = {
40        'groups.activitycategory': {
41            'Meta': {'object_name': 'ActivityCategory'},
42            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
43            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
44        },
45        'groups.group': {
46            'Meta': {'ordering': "('name',)", 'object_name': 'Group'},
47            'abbreviation': ('django.db.models.fields.CharField', [], {'db_index': 'True', 'max_length': '10', 'blank': 'True'}),
48            'activity_category': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.ActivityCategory']", 'null': 'True', 'blank': 'True'}),
49            'advisor_name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
50            'athena_locker': ('django.db.models.fields.CharField', [], {'max_length': '20', 'blank': 'True'}),
51            'constitution_url': ('django.db.models.fields.CharField', [], {'max_length': '200', 'blank': 'True'}),
52            'description': ('django.db.models.fields.TextField', [], {}),
53            'funding_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
54            'group_class': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupClass']"}),
55            'group_email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
56            'group_funding': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupFunding']", 'null': 'True', 'blank': 'True'}),
57            'group_status': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.GroupStatus']"}),
58            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
59            'main_account_id': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
60            'meeting_times': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
61            'name': ('django.db.models.fields.CharField', [], {'max_length': '100', 'db_index': 'True'}),
62            'num_community': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
63            'num_grads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
64            'num_other': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
65            'num_undergrads': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
66            'officer_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
67            'recognition_date': ('django.db.models.fields.DateTimeField', [], {}),
68            'update_date': ('django.db.models.fields.DateTimeField', [], {}),
69            'updater': ('django.db.models.fields.CharField', [], {'max_length': '30', 'null': 'True'}),
70            'website_url': ('django.db.models.fields.URLField', [], {'max_length': '200'})
71        },
72        'groups.groupclass': {
73            'Meta': {'object_name': 'GroupClass'},
74            'description': ('django.db.models.fields.TextField', [], {}),
75            'gets_publicity': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
76            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
77            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
78            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
79        },
80        'groups.groupfunding': {
81            'Meta': {'object_name': 'GroupFunding'},
82            'contact_email': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
83            'funding_list': ('django.db.models.fields.CharField', [], {'max_length': '32', 'blank': 'True'}),
84            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
85            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
86            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
87        },
88        'groups.groupstatus': {
89            'Meta': {'object_name': 'GroupStatus'},
90            'description': ('django.db.models.fields.TextField', [], {}),
91            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
92            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
93            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
94            'slug': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'db_index': 'True'})
95        },
96        'space.space': {
97            'Meta': {'object_name': 'Space'},
98            'asa_owned': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
99            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
100            'merged_acl': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
101            'notes': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
102            'number': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '20'})
103        },
104        'space.spaceaccesslistentry': {
105            'Meta': {'object_name': 'SpaceAccessListEntry'},
106            'card_number': ('django.db.models.fields.CharField', [], {'max_length': '20'}),
107            'end': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(9999, 12, 31, 23, 59, 59, 999999)', 'db_index': 'True'}),
108            'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']"}),
109            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
110            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'}),
111            'space': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['space.Space']"}),
112            'start': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime(2012, 4, 6, 1, 27, 8, 319969)', 'db_index': 'True'})
113        },
114        'space.spaceassignment': {
115            'Meta': {'object_name': 'SpaceAssignment'},
116            'end': ('django.db.models.fields.DateField', [], {'default': 'datetime.datetime(9999, 12, 31, 23, 59, 59, 999999)', 'db_index': 'True'}),
117            'group': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['groups.Group']"}),
118            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
119            'locker_num': ('django.db.models.fields.CharField', [], {'max_length': '10', 'blank': 'True'}),
120            'notes': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
121            'space': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['space.Space']"}),
122            'start': ('django.db.models.fields.DateField', [], {'default': 'datetime.datetime.now', 'db_index': 'True'})
123        }
124    }
125
126    complete_apps = ['space']
Note: See TracBrowser for help on using the repository browser.