Python数据库反向生成Model最优方案示例
作者:编程学习网 发布时间:2023-11-02 18:37:36
标签:Python,数据库,反向生成,Model
1. 前言
熟悉 Django 的朋友应该知道,我们可以通过「 inspectdb 」命令将数据库表反向生成 Model 并写入到文件中去
比如,Django 项目映射数据库中有一张 student 表,我们希望反向生成 Model 并写入到本地文件 models.py 文件中
只需要输入下面命令:
# 反向生成Model
# 进入到项目根目录,输入下面的命令
# 其中
# student:映射数据库的student数据表
# 写入到index App 下的models.py文件内
python3 manage.py inspectdb student > index/models.py
但如果是一个普通 Python 项目,如何反向生成 Model 呢?
2. 普通项目反向生成 Model
假设项目使用「 sqlalchemy 」连接操作数据库
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
engine = create_engine('mysql+pymysql://{}:{}@{}:{}/{}'.format(user, password, host, port, database), echo = True)
session = sessionmaker(bind=self.engine)()
...
接着,我们安装依赖「 sqlacodegen 」
# 安装依赖
pip3 install sqlacodegen
这样,我们就可以使用 sqlacodegen 命令关联数据库表,在本地一键生成 Model 了
def generate_orm_table(db_ip, db_name, table_name, output, username='root', pwd='root', port=3306):
"""
生成orm数据表
:return:
"""
exec_cmd(
'sqlacodegen --tables {} --outfile {} mysql+pymysql://{}:{}@{}:{}/{}?charset=utf8'.format(
table_name, output, username, pwd, db_ip, port, db_name))
if __name__ == '__main__':
# 生成orm数据库表
table_name = 'zlb_users'
# 生成Model
generate_orm_table("192.168.*.*", "db_name", "table_name", "./../model/{}.py".format(table_name))
3. 最后
虽然可以通过命令行一键生成 Model,但是生成的部分字段可能存在误差,需要手动进行调整一下
比如,数据库如果某个字段为时间 datetime,反向生成 Model 中的 DateTimeField 字段参数值需要略微调整
来源:https://juejin.cn/post/7125293030168330270


猜你喜欢
- 安装源pip install django2.2pip install mysqlclient1.4.6使用pyharm 创建django
- 本文实例为大家分享了js实现放大镜效果的具体代码,供大家参考,具体内容如下该放大区域用背景图片放大<!DOCTYPE html>
- Facebook的网站速度做为最关键的公司任务之一。在2009年,我们成功地实现了Facebook网站速度提升两倍 。而正是我们的工程师团队
- PHP simplexml_load_file() 函数实例转换 XML 文件为 SimpleXMLElement 对象,然后输出对象的键和
- innodb这种引擎,与MYISAM引擎的区别很大。特别是它的数据存储格式等.对于innodb的数据结构,首先要解决两个概念性的问题: 共享
- 关于阻塞主线程join的错误用法Thread.join() 作用为阻塞主线程,即在子线程未返回的时候,主线程等待其返回然后再继续执行.joi
- 前段时间因为忙一些其它的事情,分享的有些少,最近学习一下redis在Go语言开发中的应用。一、理论知识Redis是一个开源的、使用C语言编写
- 简介有兴趣可以看看: 解释性语言+动态类型语言+强类型语言交互模式:(主要拿来试验,可以试试 ipython)$python>>
- <html> <head> <script type="text/javascript"&
- 先介绍下什么是协程:协程,又称微线程,纤程,英文名Coroutine。协程的作用,是在执行函数A时,可以随时中断,去执行函数B,然后中断继续
- 最近开始学习数据库知识,从mysql下手,下面详细介绍一下安装过程,给小伙伴们一个参考。一、安装 首先,从mysql的中文社区下载,我尝试过
- 一、前言mysql5.7版本开始支持JSON类型字段,本文详细介绍json_extract函数如何获取mysql中的JSON类型数据json
- 有时候需要一次性将SQL Server中的数据导出给其他部门的也许进行关联或分析,这种需求对于SSIS
- #! -*- coding:utf-8 -*- import string s = 'Ye
- (一)深入浅出理解索引结构实际上,您可以把索引理解为一种特殊的目录。微软的SQL SERVER提供了两种索引:聚集索引(clustered
- window.onload=function(){ pd(11);} function pd(number) { if(number>
- 我就废话不多说了,直接上代码吧!from numpy import *import numpy as npimport cv2, os, m
- 这篇文章主要介绍了python manage.py runserver流程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定
- 环境Django 2.0 + Win 10 + Pycharm + 360浏览器报错项目结构(报异常)解决方法看了好多大佬的解决方法,基本上
- python中迭代器和iter()函数迭代器为类序列对象提供了一个类序列的接口。python的迭代无缝地支持序列对象,而且它还允许程序员迭代