在我的Django应用程序中,我需要创建一个带有一些额外字段的用户模型。对于数据库性能,我想避免每次我想访问这些字段时进行连接。在DB级别,我想在用户表上生成一个ALTER TABLE来添加这些字段,甚至是一个CREATE TABLE,其中包含我在app初始化时需要的所有字段都没问题,因为我还在开发中。
我找到了两个扩展用户模型的解决方案(下面报告),但两者都与我选择避免JOIN不一致。
models.py (Solution 1)
from django.db import models
class Person(models.Model):
# Aggregate using a OneToOneField on User
user = models.OneToOneField(User)
age = models.PositiveSmallIntegerField()
models.py (Solution 2)
from django.contrib.auth.models import User
class Person(User):
# Inheriting from User
age = models.PositiveSmallIntegerField()
SQL (Solution 1)
/* Aggregate using a OneToOneField on User */
BEGIN;
CREATE TABLE "people_person" (
"id" integer NOT NULL PRIMARY KEY,
"user_id" integer NOT NULL UNIQUE REFERENCES "auth_user" ("id"),
"age" smallint unsigned NOT NULL
);
COMMIT;
SQL (Solution 2)
/* Inheriting from User */
BEGIN;
CREATE TABLE "people_person" (
"user_ptr_id" integer NOT NULL PRIMARY KEY REFERENCES "auth_user" ("id"),
"age" smallint unsigned NOT NULL
);
COMMIT;
答案 0 :(得分:1)
从django 1.5开始,可以替换用户模型而不是扩展它。
https://docs.djangoproject.com/en/dev/releases/1.5/#configurable-user-model
在django 1.4或更早版本中,用户的“profile”属性会获得一些特殊的缓存,这可能会或可能不会满足您的要求。