踩坑實錄:Django繼承AbstractUser時遇到的related_name沖突及解決方案

一、問題現象分析

咱們在用Django開發時,有時候需要擴展用戶模型,就會去繼承AbstractUser。但這么做的時候,要是沒處理好groups和user_permissions這兩個多對多字段的反向查詢名稱,就會遇到這樣的報錯:
在這里插入圖片描述

主要就是這種錯誤:

ERRORS:
auth.User.groups: (fields.E304) Reverse accessor clashes...
HINT: Add or change a related_name argument...

說白了,問題出在哪呢?就是Django自帶的auth.User模型和咱們自己寫的users.User模型,都有同名的多對多字段,結果導致反向查詢名稱(也就是related_name)打架了。

二、解決方案

1. 顯式聲明沖突字段
咱們得在自定義用戶模型里重新定義一下groups和user_permissions字段,給它們起個獨特的名字(也就是設置related_name參數):

# users/models.py
from django.contrib.auth.models import AbstractUser, Group, Permissionclass User(AbstractUser):# 這些是咱們新增的字段,保持不變就行mobile = models.CharField(...)avatar = models.ImageField(...)# 關鍵修復的地方:重新定義多對多字段groups = models.ManyToManyField(Group,verbose_name='用戶組',blank=True,related_name="custom_user_groups",  # 給它起個獨特的名字related_query_name="user",)user_permissions = models.ManyToManyField(Permission,verbose_name='用戶權限',blank=True,related_name="custom_user_permissions",  # 這個也想起個獨特的名字related_query_name="user",)

2. 配置驗證
別忘了在settings.py里告訴Django咱們用的是自定義模型:

AUTH_USER_MODEL = 'users.User'  # 這里得對應你的app名和模型名

這一步非常關鍵,因為它告訴Django整個框架應該使用你的自定義用戶模型,而不是默認的auth.User模型,確保認證系統、權限管理和其他依賴用戶模型的功能都能正常工作。

3. 執行數據庫遷移

最后,執行這兩條命令讓改動生效:

python manage.py makemigrations
python manage.py migrate

三、原理解讀

1. 沖突機制
Django的權限系統是靠groups和user_permissions這兩個字段來實現多對多關聯的。當咱們自定義的模型繼承AbstractUser時,要是沒重新定義這兩個字段,它們的related_name就會和Django內置的auth.User模型的默認值(通常是user_set)撞車,導致命名沖突。

2. related_name作用
這個參數其實就是給反向查詢起個別名。比如說,通過user.groups可以查到用戶屬于哪些組,反過來,通過Group.custom_user_groups也能查到這個組里有哪些用戶。這個別名必須在整個項目里是唯一的,不然就會打架。

3. 字段重寫必要性
Django比較"耿直",它不會自動為繼承的字段生成新的related_name,所以咱們必須手動重新聲明這兩個字段,并給它們指定一個獨特的related_name參數。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/95954.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/95954.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/95954.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

push pop 和 present dismiss

push/pop 和 present/dismiss 文章目錄push/pop 和 present/dismiss前言push / poppresent普通的present多層present多層present后的父子關系問題多層彈出會遇到的問題showViewController 和 showDetailViewControllershowViewControllershowDetailViewControllerdismiss模態化…

服務器異常負載排查手冊 · 隱蔽進程篇

適用范圍 適用于 Linux 3.10 生產環境,發現 load 高但用戶態 CPU 接近 0 % 的場景。1. 現場凍結目標:在 rootkit 干預前保存易失數據。#!/bin/bash # freeze.sh TS$(date %s) mkdir -p /srv/ir/${TS} cd /srv/ir/${TS}# 1.1 進程樹(busybox 靜…

2024理想算法崗筆試筆記

要理解指令微調(Instruction Tuning),需要先將其置于大語言模型(LLM)的訓練框架中 —— 它并非模型訓練的起點,而是針對 “讓模型更懂人類需求” 的關鍵優化步驟。簡單來說,指令微調是通過讓模型…

Oracle 11g離線安裝依賴包完整解決方案

本文還有配套的精品資源,點擊獲取 簡介:Oracle 11g是一款廣泛使用的關系型數據庫管理系統,在離線環境下安裝時需依賴多個系統庫和工具。本“oracle11g依賴包”壓縮文件包含了在CentOS 7.7上安裝Oracle 11g可能缺失的關鍵依賴RPM包&#xf…

VBA數據結構選型:效率差5倍的生死抉擇

VBA性能生死局:Dictionary與Collection效率差5倍!90%開發者用反血虧“你以為Collection是VBA的‘輕量級選手’?大錯特錯!實測數據顯示:在10萬級數據循環中,Dictionary的查詢速度比Collection快5倍&#xff…

電機控制(四)-級聯PID控制器與參數整定(MATLABSimulink)

PID算法 普通PID(Proportional-Integral-Derivative) 通過比例(P)、積分(I)和微分(D)三項來進行控制 比例項(P):根據當前誤差(目標值…

數據結構深度解析:二叉樹的基本原理

在數據結構體系中,樹是一種重要的非線性層次結構,它通過 “節點” 與 “邊” 的連接關系,模擬了現實世界中樹的分支結構,能夠高效地解決數據的查找、插入、刪除等問題。而二叉樹作為樹結構中最簡單、應用最廣泛的類型,…

【React】Ant Design 5.x 實現tabs圓角及反圓角效果

需要實現的效果實現思路 利用tab頁的before和after屬性&#xff0c;添加tab頁前后的圓弧屬性&#xff0c;同時使用tab頁的shadow陰影填充右下角的圓弧空缺部分。<TabsonChange{onChange}type"card"items{getTabItems()}/>.ant-tabs-nav{margin: 0;.ant-tabs-na…

WordPress過濾文章插入鏈接rel屬性noopener noreferrer值

WordPress過濾文章插入鏈接rel屬性noopener noreferrer值在保存文章的時候&#xff0c;WordPress會自動過濾文章內容中的鏈接&#xff0c;具有target屬性的鏈接會自動添加rel"noopener noreferrer"&#xff0c;該屬性是為了預防跨站攻擊&#xff0c;站內鏈接似乎沒有…

make_shared的使用

目錄 1. make_shared 的基本概念 基本用法 2. 引入 make_shared 的主要原因 2.1 解決傳統構造方式的問題 2.2 標準委員會的動機 3. make_shared 的核心優勢 3.1 性能優勢&#xff08;最重要優點&#xff09; 內存分配優化&#xff1a; 性能提升表現&#xff1a; 3.2 異…

基于 Gemini 的 CI/CD 自動化測評 API 集成實戰教程

在現代軟件開發中&#xff0c;CI/CD 集成 已經成為必不可少的流程。它不僅能幫助團隊快速迭代&#xff0c;還能通過自動化手段提升代碼質量。而在編程培訓和團隊內部學習中&#xff0c;如何引入 自動化測評 API&#xff0c;實現提交即測評、即時反饋呢&#xff1f;本文將以 Gem…

SOME/IP-SD(Service Discovery)協議的核心協議

<摘要> 本解析以AutoSAR AP R22-11版本為基準&#xff0c;全面系統地闡述了SOME/IP-SD&#xff08;Service Discovery&#xff09;協議的核心內容。從車載網絡演進背景切入&#xff0c;詳細剖析了面向服務架構&#xff08;SOA&#xff09;下服務發現的必要性&#xff0c;…

視頻串行解串器(SerDes)介紹

視頻串行解串器&#xff08;SerDes&#xff09;是高速數據通信中的核心接口技術&#xff0c;通過串行化與解串行化實現視頻信號的高效傳輸&#xff0c;廣泛應用于汽車電子、數據中心、高清視頻傳輸等領域。 一、技術原理串行化&#xff08;Serializer&#xff09; 功能&#xf…

哈士奇vs網易高級數倉:數據倉庫的靈魂是模型、數據質量還是計算速度?| 易錯題

面試場景 面試官: (微笑,營造輕松但專業的氛圍)嗨,哈士奇,歡迎來參加網易的二面。我看你簡歷上數據倉庫的項目經驗很豐富,我們今天就深入聊聊。我這里有一個經典的問題想聽聽你的看法:在你看來,數據倉庫的靈魂是模型、數據質量還是計算速度? 哈士奇: (不假思索,…

貪心算法應用:3D打印支撐結構問題詳解

Java中的貪心算法應用&#xff1a;3D打印支撐結構問題詳解 1. 問題背景與概述 1.1 3D打印中的支撐結構問題 在3D打印過程中&#xff0c;當模型存在懸空部分&#xff08;overhang&#xff09;時&#xff0c;通常需要添加支撐結構&#xff08;support structure&#xff09;來防止…

Python爬蟲實戰:研究3D plotting模塊,構建房地產二手房數據采集和分析系統

1. 引言 1.1 研究背景 在大數據與人工智能技術快速發展的背景下,數據已成為驅動決策的核心要素。互聯網作為全球最大的信息載體,蘊含海量結構化與非結構化數據,如何高效提取并分析這些數據成為學術界與產業界的研究熱點。 網絡爬蟲技術通過自動化請求與解析網頁,實現數據…

Gradio全解10——Streaming:流式傳輸的音頻應用(7)——ElevenLabs:高級智能語音技術

Gradio全解10——Streaming&#xff1a;流式傳輸的音頻應用&#xff08;7&#xff09;——ElevenLabs&#xff1a;高級智能語音技術10.7 ElevenLabs&#xff1a;高級智能語音技術10.7.1 核心功能與可用模型1. 核心功能與產品2. 三類語音模型10.7.2 文本轉語音API1. 完整操作步驟…

【桃子同學筆記4】PCIE訓練狀態機(LTSSM)基礎

首先&#xff0c;所謂LTSSM&#xff0c;即&#xff1a;Link Training and Status State Machine&#xff08;鏈路訓練及狀態機&#xff09; 下圖為 LTSSM 的狀態機及訓練過程&#xff1a; LTSSM 包含 11 個頂層狀態&#xff1a;Detect、Polling、Configuration、Recovery、L0、…

STM32傳感器模塊編程實踐(十五)DIY語音對話控制+滿溢檢測智能垃圾桶模型

文章目錄 一.概要二.實驗模型原理1.硬件連接原理框圖2.控制原理 三.實驗模型控制流程四.語音控制垃圾桶模型程序五.實驗效果視頻六.小結 一.概要 以前介紹的智能垃圾桶模型都是通過超聲波模塊感知控制&#xff0c;這次介紹一款新的智能垃圾桶&#xff0c;直接使用語音交互模塊…

[bat-cli] docs | 控制器

鏈接&#xff1a;https://github.com/sharkdp/bat 前文傳送&#xff1a; 【探索Linux命令行】從基礎指令到高級管道操作的介紹與實踐【Linux命令行】從時間管理-&#xff1e;文件查找壓縮的指令詳解【Linux】1w詳解如何實現一個簡單的shell docs&#xff1a;bat bat 是一個*…