首页 > 其他分享 >Django --根据已有表生成ORM模型

Django --根据已有表生成ORM模型

时间:2022-11-03 10:12:40浏览次数:76  
标签:manage 映射 -- 模型 py Django ORM 数据库

在实际开发中,有些时候可能数据库已经存在了。如果我们用Django来开发一个网站 ,读职的是之前已经存在的数据库中的数据。
那么该如何将模型与数据库中的表映射呢?根据旧的数据库生成对应的ORM模型,需要以下几个步骤:


1、Django 给我们提供了一个inspectdb的命令,可以非常方便的将已经存在的表,自动的生成模型。想要使用inspectab自动将
表生成模型。首先需要在settings.py 中配置好数据库相关信息不然就找不到数据库。示例代码如下:

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'database_name',
'HOST': '127.0.0.1',
'PORT': '3306',
'USER': 'your_database_name',
'PASSWORD': 'your_database_password',
}
}

再通过 python manage.py inspectdb 就会将表转换为模型后的代码显示在终端。

不过以上代码只是显示在终端,如果想要保存到文件,可以指定重定向文件,比如输出到 models.py 文件中,需要执行:

python manage.py inspectdb > models.py

以上命令只能在终端中执行,不能在pycharm->Tools->Run manage.py Task...中使用

如果只想要转换一个表生成模型,可以执行以下语句:python manage.py inspectdb table_name > models.py

 

 

2、修正模型:新生成的ORM模型有些地方可能不太适合使用。比如模型的名字,表之间的关系等等。那么以下选项还需要重新配置:
(1)、模型名:自动生成的模型,是根据表的名字生成的,可能不是你想要的。这时候模型的名字你可以改成任何你想要的。
模型所属app:根据自己的需要,将相应的模型放在对应的app中。放在同个app中也是没有任何问题的。只是不方便管
理。

(2)、模型外键引用:将所有使用Foreignkey 的地方,模型引用都改成字符串。这样不会产生模型顺序的问题。另外,如果引用
的模型已经移动到其他的app中了,那么还要加上这个app的前缀。
(3)、让Django管理模型:将Meta下的managed=False 删掉,如果保留这个,那么以后这个模型有任何的修改,使用migrate都不会映射到数据库中。
(4)、表名:切记不要修改表的名字(这里的表名不是模型类名,而是class Meta: 中的db_table)。不然映射到数据库中,会发生找不到对应表的错误。

 

 

3、执行命令python manage.py makemigrations生成初始化的迁移脚本。方便后面通过ORM来管理表。在这时候还需要执行命令python manage.py migrate --fake-initial,因为如果不使用--fake-initial,那么会将迁移脚本会映射到数据库中。这时候迁移脚本会新到建表,而这个表之前是已经存在了的,所以肯定会报错。此时我们只要将这个0001-initial 的状态修改为已经映射,而不真正执行映射,下次再migrate的时候,就会忽略他。

 


4、将Django的核心表映射到数据库中: Django中还有那些核心的表也是需要创建的。不然有些功能是用不了的。比如auth相关
表。如果过个数据库之前就是使用Django开发的,那么这些表就已经存在了,可以不用管了。如果之前这个数据库不是使用Django开发的,那么应该使用python manage.py migrate命令将Django中的核心模型映射到数据库中。

————————————————
版权声明:本文为CSDN博主「Timplan」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_42128241/article/details/101847121

标签:manage,映射,--,模型,py,Django,ORM,数据库
From: https://www.cnblogs.com/zhangxingcomeon/p/16853493.html

相关文章

  • 常用CSS样式属性
    01、常用样式1.1、background背景设置元素背景的样式background,更好的衬托内容。属性描述值background背景属性简写。支持多组背景设置,逗号,隔开backgrou......
  • 喜马拉雅x2m文件解密工具 ximalaya downloader & x2m decoder
    以前有一款ximalayadownloader&x2mdecoder文件解码工具,但是比较遗憾的是x2mdecoder这款软件已经不维护了,现在用不了了。 而且新版喜马拉雅客户端下载的音频格式是x......
  • win11右键菜单选项恢复,右键菜单变成win10样式
    win11右键菜单选项恢复,右键菜单变成win10样式总结以下搜到的一个有用的方法先用Windows终端(管理员)执行这段代码:regadd"HKCU\Software\Classes\CLSID{86ca1aa0-34aa-4e......
  • 力扣1668(java&python)-最大重复子字符串(简单)
    题目:给你一个字符串 sequence ,如果字符串word 连续重复 k 次形成的字符串是 sequence 的一个子字符串,那么单词 word的重复值为k。单词word 的最大重复值......
  • gin-解决跨域问题
    1.在middlewares中创建cors.go文件packagemiddlewaresimport( "github.com/gin-gonic/gin" "net/http")funcCors()gin.HandlerFunc{ returnfunc(c*gin.Co......
  • net core实现分布式session,单点登录
    原文网址:http://m.tnblog.net/aojiancc2/article/details/2436要想在netcore中实现分布式session,实现单点登录,我们可以把session保存到redis中,这样就可以多个项目共享s......
  • 设计模式之结构型模式
    目录一、适配器模式二、装饰器模式三、代理模式四、外观模式五、享元模式六、桥接模式七、组合模式创建型模式(5个)工厂方法模式、抽象工厂模式、单例模式、建造者模式、原......
  • IDEA研究院
    粤港澳大湾区数字经济研究院(InternationalDigitalEconomyAcademy,简称“IDEA研究院”),https://idea.edu.cn/论文阅读平台ReadPaper,https://idea.edu.cn/readpaper.html......
  • 异常处理及程序设计
    1.模拟幼儿园分苹果defdivision():print("==========分苹果了==========")apple=int(input("请输入苹果的个数:"))children=int(input("请输入来了几个......
  • 软件设计__ 数据库逻辑结构设计
    难度:★★☆案例引入YourTour系统(旅游线路预定系统)YourTour是一个为旅行社和其目标顾客提供服务的系统。它能够将多个景点组成一条旅游线路,而且能够为所有参加线路的游......