2005-11-14 09:44:35 +08:00
|
|
|
"""
|
|
|
|
18. Using SQL reserved names
|
|
|
|
|
|
|
|
Need to use a reserved SQL name as a column name or table name? Need to include
|
|
|
|
a hyphen in a column or table name? No problem. Django quotes names
|
|
|
|
appropriately behind the scenes, so your database won't complain about
|
|
|
|
reserved-name usage.
|
|
|
|
"""
|
|
|
|
|
2005-12-14 13:02:51 +08:00
|
|
|
from django.db import models
|
2005-11-14 09:44:35 +08:00
|
|
|
|
2005-12-14 13:02:51 +08:00
|
|
|
class Thing(models.Model):
|
|
|
|
when = models.CharField(maxlength=1, primary_key=True)
|
|
|
|
join = models.CharField(maxlength=1)
|
|
|
|
like = models.CharField(maxlength=1)
|
|
|
|
drop = models.CharField(maxlength=1)
|
|
|
|
alter = models.CharField(maxlength=1)
|
|
|
|
having = models.CharField(maxlength=1)
|
|
|
|
where = models.CharField(maxlength=1)
|
|
|
|
has_hyphen = models.CharField(maxlength=1, db_column='has-hyphen')
|
2005-11-14 09:44:35 +08:00
|
|
|
class META:
|
|
|
|
db_table = 'select'
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
return self.when
|
|
|
|
|
|
|
|
API_TESTS = """
|
2005-12-12 06:10:02 +08:00
|
|
|
>>> t = Thing(when='a', join='b', like='c', drop='d', alter='e', having='f', where='g', has_hyphen='h')
|
2005-11-14 09:44:35 +08:00
|
|
|
>>> t.save()
|
|
|
|
>>> print t.when
|
|
|
|
a
|
|
|
|
|
2005-12-12 06:10:02 +08:00
|
|
|
>>> u = Thing(when='h', join='i', like='j', drop='k', alter='l', having='m', where='n')
|
2005-11-14 09:44:35 +08:00
|
|
|
>>> u.save()
|
|
|
|
>>> print u.when
|
|
|
|
h
|
|
|
|
|
2005-12-12 06:10:02 +08:00
|
|
|
>>> Thing.objects.get_list(order_by=['when'])
|
2005-11-14 09:44:35 +08:00
|
|
|
[a, h]
|
2005-12-12 06:10:02 +08:00
|
|
|
>>> v = Thing.objects.get_object(pk='a')
|
2005-11-14 09:44:35 +08:00
|
|
|
>>> print v.join
|
|
|
|
b
|
|
|
|
>>> print v.where
|
|
|
|
g
|
2005-12-12 06:10:02 +08:00
|
|
|
>>> Thing.objects.get_list(order_by=['select.when'])
|
2005-11-14 09:44:35 +08:00
|
|
|
[a, h]
|
|
|
|
"""
|