解决逆向生成数据库表的模型

场景:有个非本项目(python项目)的数据库,现需要直连这个数据库获取一些数据,后端是通过ORM的方式来开发的,并非直接写SQl语句(也不会符合本需求),用ORM就需要建对应表的models

python manage.py inspectdb > models.py

django提供了一个 inspectdb 命令,可以将DATABASES里配置的‘default’里的db_name1库中的所有表都逆向生成对应的models.py,真是一个强大的功能

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',	# 要连接的 数据库类型
        'HOST': '192.168.1.1',	# 要连接的远程数据库的 ip地址
        'PORT': '3306',	# 数据库连接端口,mysql默认3306
        'USER': 'root',		# 数据库已有用户名
        'PASSWORD': 'root',	# 数据库已有用户密码
        'NAME': 'db_name1',	# 要连接的 数据库名
    },
        'database2': {
        'ENGINE': 'django.db.backends.mysql',	# 要连接的 数据库类型
        'HOST': '192.168.1.1',	# 要连接的远程数据库的 ip地址
        'PORT': '3306',	# 数据库连接端口,mysql默认3306
        'USER': 'root',		# 数据库已有用户名
        'PASSWORD': 'root',	# 数据库已有用户密码
        'NAME': 'db_name1',	# 要连接的 数据库名
    },
}

大家可以测试一下吧

如果你的项目里,有多个数据库的配置信息,可以使用如下的命令来生成其他库(database2)的表的model

python manage.py inspectdb --database database2

结果直接打印在窗口上

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值