- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在 Django 模板中显示 {{ user }}
时,默认行为是显示用户名,即 user.username
。
我正在更改此设置以显示用户的姓名首字母缩写,这些缩写存储在单独的 (OneToOneField
) UserProfile
模型中。
因此,在 customsignup/models.py
中,我已成功覆盖 __unicode__
函数,并获得了所需的结果:
# __unicode__-function overridden.
def show_userprofile_initials(self):
return self.userprofile.initials
User.__unicode__ = show_userprofile_initials
但是,当然,数据库会再次受到攻击,因为每次要求 user
对象将其自身显示为字符串时,数据库都需要独立选择 UserProfile
模型。因此,即使这有效,它也会大大增加数据库命中的数量。
所以我想做的是,每当从数据库调用 User
模型时,自动使用 select_lated('userprofile')
,因为我会在与用户打交道时,本质上始终需要配置文件。
用更专业的术语来说,我正在尝试覆盖现有模型的模型管理器。因此,我无法控制 User
模型定义本身,因为它位于导入的库中。
因此,我尝试以与覆盖 __unicode__
函数相同的方式覆盖 User
模型的 objects
成员,如下所示:
# A model manager for automatically selecting the related userprofile-table
# when selecting from user-table.
class UserManager(models.Manager):
def get_queryset(self):
# Testing indicates that code here will NOT run.
return super(UserManager, self).get_queryset().select_related('userprofile')
User.objects = UserManager()
这应该有效吗?如果是这样,我错了什么?
(如果答案可以表明这本来就不应该起作用,我会将其标记为正确答案。)
我发现了一个类似的问题在这里,但它是从另一端解决的: Automatically select related for OneToOne field
最佳答案
不,User.objects = MyManger()
不应该工作。 According to the docs ,只有两种受支持的方法来扩展提供的身份验证用户模型,要么是 profile 模型,就像您正在做的那样,要么是 proxy 模型,这可能不适合你的情况。来自文档(添加了重点):
There are two ways to extend the default User model without substituting your own model. If the changes you need are purely behavioral, and don’t require any change to what is stored in the database, you can create a proxy model based on User. This allows for any of the features offered by proxy models including default ordering, custom managers, or custom model methods.
If you wish to store information related to User, you can use a OneToOneField to a model containing the fields for additional information. This one-to-one model is often called a profile model, as it might store non-auth related information about a site user.
作为扩展所提供的身份验证用户模型的替代方法,您可以 provide your own custom User model 。然后您将完全控制其管理人员。
相反,请考虑简单地将 {{ user }}
替换为 {{ user.profile.initials }}
。在配置文件模型上创建 OneToOne 字段还会为相关模型的实例创建反向访问器。您可以通过配置文件模型字段上的 related_name 关键字参数指定反向访问器名称。例如...
from django.db import models
from django.contrib.auth.models import User
class UserProfile(models.Model)
user = models.OneToOneField('auth.User', related_name='profile')
initials = models.CharField(max_length=6)
some_user = User.objects.first()
# assuming there is already a profile related to this user
some_user.profile.initials = 'S.P.Y.'
您还可以为您的配置文件模型创建一个 __str__
方法,例如
def __str__(self):
return self.initials
然后,当您在模板中执行 {{ user.profile }}
时,将显示缩写。
关于python - Django:检索用户模型时自动选择相关模型UserProfile,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49134786/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!