按照 miikkas 的建议 remodel.Manager,我想出了以下方法,它适用于通过查询 uuid 来检索 id 字段的更简单的情况。该数据库是使用 ID 为用于十六进制字符串的 varchar 字段创建的,并且我正在改进一个顺序整数 ID 字段,因此我可以使用需要它的 Django 的身份验证模块。我想分步执行此操作,因此是 hack。
if DEVELOPMENT['merging_to_sequential_ids_incomplete']:
class ModelManager(models.Manager):
def get(self, *args, **kwargs):
if 'uuid' in kwargs:
kwargs['id'] = kwargs.pop('uuid')
return super(ModelManager, self).get(*args, **kwargs)
class Model(models.Model):
if DEVELOPMENT['merging_to_sequential_ids_incomplete']:
print >>sys.stderr, 'WARNING: uuid now a synonym to id'
id = models.CharField(max_length = 32,
primary_key = True, default = uuid_string)
objects = ModelManager() # for Client.objects.get(uuid=...)
uuid = property(lambda self: self.id) # for client.uuid
else:
id = models.AutoField(primary_key = True)
uuid = models.CharField(max_length = 32, ...
现在我可以了:
cd myapp && ../djangopython manage.py shell
WARNING: uuid now a synonym to id
setting up special admin settings
Python 2.7.8 (default, Nov 18 2014, 16:29:10)
[GCC 4.9.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> from myapp.models import *
>>> Client.objects.get(uuid=u'18b86bd7b58e4c0186f7654045ce81d9')
<Client: jc@example.net>
>>> _.uuid
u'18b86bd7b58e4c0186f7654045ce81d9'
filter 可以用同样的方式完成。
也许这可以帮助指导其他人寻找一种方法来为 Django 模型字段使用“别名”或“同义词”。我不相信它会帮助OP。自定义字段类型可能是更好的通用方法。