2
18. Using SQL reserved names
4
Need to use a reserved SQL name as a column name or table name? Need to include
5
a hyphen in a column or table name? No problem. Django quotes names
6
appropriately behind the scenes, so your database won't complain about
10
from django.db import models
12
class Thing(models.Model):
13
when = models.CharField(max_length=1, primary_key=True)
14
join = models.CharField(max_length=1)
15
like = models.CharField(max_length=1)
16
drop = models.CharField(max_length=1)
17
alter = models.CharField(max_length=1)
18
having = models.CharField(max_length=1)
19
where = models.DateField(max_length=1)
20
has_hyphen = models.CharField(max_length=1, db_column='has-hyphen')
24
def __unicode__(self):
27
__test__ = {'API_TESTS':"""
29
>>> day1 = datetime.date(2005, 1, 1)
30
>>> day2 = datetime.date(2006, 2, 2)
31
>>> t = Thing(when='a', join='b', like='c', drop='d', alter='e', having='f', where=day1, has_hyphen='h')
36
>>> u = Thing(when='h', join='i', like='j', drop='k', alter='l', having='m', where=day2)
41
>>> Thing.objects.order_by('when')
42
[<Thing: a>, <Thing: h>]
43
>>> v = Thing.objects.get(pk='a')
49
>>> Thing.objects.dates('where', 'year')
50
[datetime.datetime(2005, 1, 1, 0, 0), datetime.datetime(2006, 1, 1, 0, 0)]
52
>>> Thing.objects.filter(where__month=1)