(编辑:jimmy 日期: 2024/11/17 浏览:2)
model:
class Profile(models.Model): user = models.OneToOneField(User, on_delete=models.CASCADE, verbose_name='昵称') nickname = models.CharField(max_length=20) def __str__(self): return '<Profile: %s for %s>' % (self.nickname, self.user.username)
admin.py
from django.contrib import admin from django.contrib.auth.models import User from .models import Profile class ProfileInline(admin.StackedInline): #将Profile加入到Admin的user表中,内联 model = Profile can_delete = False class UserAdmin(admin.ModelAdmin): inlines = [ProfileInline] list_display = ('username', 'nickname', 'email', 'is_staff', 'is_active', 'is_superuser') def nickname(self, obj): return obj.profile.nickname #自定义字段显示信息 nickname.short_description = '昵称' # Re-register UserAdmin admin.site.unregister(User) #去掉在admin中的注册 admin.site.register(User, UserAdmin) #用UserAdmin注册user
补充知识:Django model onetoonefield的工作模式
onetonoefield,就是一对一机制,每一条信息对应其他关联表的一条信息,记录标识为信息的id,且该键为主键
用法:
1、取值
例:User为Django自带User表,需要关联详细信息表,类为UserBaseMsg(表名为user_base_msg)和另外一张表的员工状态信息,类为UserWorkMsg(表名为user_work_msg),且在关联表中的值为user
如果取详细信息表重的a字段的值和工作信息表中的b字段
user = User.objects.get(***)
a = user.userbasemsg.a
b = user.userworkmsg.b
筛选a = c的User信息
user = User.objects.get(UserBaseMsg__a=c)
此处get还可以换成filter、exclude等条件
在UserBaseMsg__a后可加各种条件查询
常用的有
__in = # 所筛选的条件在给的范围内
__gt = # 筛选的大于指定的值
__gte = # 筛选的大于等于指定的值
__lt = # 筛选的值小于指定的值
__lte = # 筛选的值小于等于指定的值
以上这篇django 扩展user用户字段inlines方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。