Django:将有存量数据的自定义的用户表无痛继承自带的AbsUser

2023-10-21 02:18

本文主要是介绍Django:将有存量数据的自定义的用户表无痛继承自带的AbsUser,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

1、实测成功
2、只描述思路和方法,不提供具体有关代码和文档链接

背景

项目长期维护了一个自定义的Person表,有关用户表的边缘操作都是自己造的轮子,终于有一天大家终于受不了了,而这个任务就落在了我的身上。。

方案及流程

1、将person表直接继承django自带的AbsUser。
2、配置setting中有关默认用户表的变量为:'cur_app.Person'
3、生成一个迁移文件
4、再生成两个空的迁移文件
5、删掉第一个迁移文件有关 username 字段的唯一约束。(请提前将该字段的相关操作复制下来,此时是 add 操作)
6、编写第一个生成的空的迁移文件(使用RunPython),将其 username 字段赋值以满足唯一约束
7、将第五步复制的代码编写到第二个空的迁移文件中,并将 add 操作改为 alter操作,将唯一约束更新。
8、migrate 迁移
9、要保证原有的 Person 表的创建操作是在其 cur_app 中的第一个迁移文件中,如果不能保证,请自行修改这个app的迁移文件们,以达到这个目的。(这不会影响你上面的三个迁移表的运行,但是你项目中所有的迁移表不能在一个新的数据库中迁移成功,所以你一定要保证好这一点
10、回滚并再次迁移admin app 下的 migrate,以保证LogEntry表正确的关联到新的用户表上 。参考:./manager.py migrate admin zero./manager.py migrate admin(此时会丢掉所有的日志,如果日志很重要,建议先备份)
11、因为此时创建超级管理员的命令可能已经无效了,所以请使用ORM或者sql语句,完成超级管理员的创建。
12、结束

补充
  • 你需要看的文档有三个部分(百度不到,我也不提供具体位置,请自己找):
    a、如何在既有数据表中增加一个唯一字段?
    b、如何自己编写迁移文件?
    c、如果正确的迁移用户系统?
  • 我真心得希望你所维护的项目里不会有这么傻的操作,如果真的有,那么你需要好好的研究一下迁移文件了。

这篇关于Django:将有存量数据的自定义的用户表无痛继承自带的AbsUser的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/251255

相关文章

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

通过ibd文件恢复MySql数据的操作方法

《通过ibd文件恢复MySql数据的操作方法》文章介绍通过.ibd文件恢复MySQL数据的过程,包括知道表结构和不知道表结构两种情况,对于知道表结构的情况,可以直接将.ibd文件复制到新的数据库目录并... 目录第一种情况:知道表结构第二种情况:不知道表结构总结今天干了一件大事,安装1Panel导致原来服务

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete

SpringBoot自定义注解如何解决公共字段填充问题

《SpringBoot自定义注解如何解决公共字段填充问题》本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间... 目录1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3

dubbo3 filter(过滤器)如何自定义过滤器

《dubbo3filter(过滤器)如何自定义过滤器》dubbo3filter(过滤器)类似于javaweb中的filter和springmvc中的intercaptor,用于在请求发送前或到达前进... 目录dubbo3 filter(过滤器)简介dubbo 过滤器运行时机自定义 filter第一种 @A

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据

《mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据》文章主要介绍了如何从.frm和.ibd文件恢复MySQLInnoDB表结构和数据,需要的朋友可以参... 目录一、恢复表结构二、恢复表数据补充方法一、恢复表结构(从 .frm 文件)方法 1:使用 mysq

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值