位置: 编程技术 - 正文

Python的Flask框架中使用Flask-Migrate扩展迁移数据库的教程(flask框架下使用scrapy框架)

编辑:rootadmin

推荐整理分享Python的Flask框架中使用Flask-Migrate扩展迁移数据库的教程(flask框架下使用scrapy框架),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:flask框架菜鸟教程,flask框架菜鸟教程,pycharm flask框架,pycharm flask框架,pycharm flask框架,pycharm flask框架,flask 框架,Python的flask框架教程,内容如对您有帮助,希望把文章链接给更多的朋友!

我们在升级系统的时候,经常碰到需要更新服务器端数据结构等操作,之前的方式是通过手工编写alter sql脚本处理,经常会发现遗漏,导致程序发布到服务器上后无法正常使用。

现在我们可以使用Flask-Migrate插件来解决之,Flask-Migrate插件是基于Alembic,Alembic是由大名鼎鼎的SQLAlchemy作者开发数据迁移工具。

具体操作如下:

1. 安装Flask-Migrate插件

2. 修改Flask App部分的代码,以增加Migrate相关的Command

3. 初始化

使用Flask-Migrate迁移数据库随着开发进度不断向前,你会发现你的数据库模型需要更改,而当这种情况发生时需要更新数据库。

Flask-SQLAlchemy只有当数据库表不存在了才从模型创建它们,所以更新表的唯一途径就是销毁旧的表,当然这将导致所有数据库中的数据丢失。

有个更好的解决方案就是使用数据库迁移框架。和源码版本控制工具跟踪更改源码文件一样,数据库迁移框架跟踪更改数据库模型,然后将增量变化应用到数据库中。

SQLAlchemy的主要开发人员写了一个Alembic迁移框架,但我们不直接使用Alembic,Flask应用可以使用Flask-Migrate扩展,一个集成了Flask-Script来提供所有操作命令的轻量级Alembic包。

4. 创建迁移仓库

首先,Flask-Migrate必须已经安装到虚拟环境中:

Python的Flask框架中使用Flask-Migrate扩展迁移数据库的教程(flask框架下使用scrapy框架)

下面展示扩展如何初始化:

为了可以使用数据库迁移命令,Flask-Migrate提供MigrateCommand类来连接Flask-Script的manager对象。在这个示例中使用db来连接到命令。

在数据库迁移可以维护之前,必须通过init子命令来创建一个迁移库:

这个命令创建一个migrations文件夹,里面存放了所有迁移脚本。

建议:如果你有克隆在GitHub上的应用程序,你现在可以运行git checkout 5c来切换到这个版本的应用程序。

5. 创建迁移脚本

在Alembic,数据库迁移工作由迁移脚本完成。这个脚本有两个函数,分别叫做upgrade()和downgrade()。upgrade()函数实施数据库更改,是迁移的一部分,downgrade()函数则删除它们。通过添加和删除数据库变化的能力,Alembic可以重新配置数据库从历史记录中的任何时间点。

Alembic迁移可以分别使用revision和migrate命令手动或自动创建。手动迁移通过由开发人员使用Alembic的Operations对象指令实现的空upgrade()和downgrade()函数创建迁移框架脚本。另一方面,自动迁移通过寻找模型定义和数据库当前状态间的不同为upgrade()和downgrade()生成代码。

警告:自动迁移并不总是准确的,可以忽略一些细节。所以应该经常审查一下自动生成的迁移脚本。migrate子命令创建自动迁移脚本:

建议:如果你有克隆在GitHub上的应用程序,你现在可以运行git checkout 5c来切换到这个版本的应用程序。注意,你不需要为这个应用生成migrations,所有的迁移脚本都包含在版本库中。6. 更新数据库

一旦迁移脚本被审查且接受,就可以使用db upgrade命令更新到数据库中:

第一次迁移实际上相当于调用db.create_all(),但在后续迁移中,upgrade命令对表实施更新操作但不影响表中的内容。

Python使用dis模块把Python反编译为字节码的用法详解 dis—DisassemblerforPythonbytecode,即把python代码反汇编为字节码指令.使用超级简单:python-mdisxxx.pyPython代码是先被编译为字节码后,再由Python虚拟机来执行字节

实例探究Python以并发方式编写高性能端口扫描器的方法 关于端口扫描器端口扫描工具(PortScanner)指用于探测服务器或主机开放端口情况的工具。常被计算机管理员用于确认安全策略,同时被攻击者用于识别

Python中死锁的形成示例及死锁情况的防止 死锁示例搞多线程的经常会遇到死锁的问题,学习操作系统的时候会讲到死锁相关的东西,我们用Python直观的演示一下。死锁的一个原因是互斥锁。假

标签: flask框架下使用scrapy框架

本文链接地址:https://www.jiuchutong.com/biancheng/387634.html 转载请保留说明!

上一篇:Python的Flask框架中使用Flask-SQLAlchemy管理数据库的教程(pycharm flask框架)

下一篇:Python使用dis模块把Python反编译为字节码的用法详解

  • 银行回单电子退库是什么意思
  • 汇兑损益现金流量表列示
  • 小微企业税务服务站
  • 机票抵税申报表咋填
  • 火车票抵扣进项税怎么计算
  • 私募合伙企业收到投资款后退回,支付利息的会计处理
  • 结转完工产品生产成本会计科目
  • 所得税汇算清缴分录怎么做
  • 开房屋租金发票需要带什么资料
  • 扫微信送礼品是诈骗吗
  • 公司转让注册资金怎么弄
  • 本月采购下月付款怎么记账
  • 企业盈利后又亏损怎么算
  • 税收分类编码选错了怎么办
  • 印花税按主营业务成本计算吗
  • 其他货币资金包括存出保证金吗
  • 项目结束,财务应该怎么做
  • 罗马尼亚卫生部长
  • Win11 Dev Build 22000.65开发预览版推送(附更新修复已知问题汇总)
  • 冲账备用金的记账凭证怎么填
  • 收到的进项发票要在多久前认证
  • 外贸公司收汇可以收运费吗
  • 车辆购置税会计账务处理
  • 企业清算有哪些类型
  • linux字体不清晰
  • 企业受赠业务的法律规定
  • 通过mac地址查找ip的协议
  • 股票公允价值变动怎么算
  • 小米路由器2代改8t
  • 一般纳税人转让不动产预缴
  • 印花税怎么计提和结转
  • 如何用ai写代码
  • 资产提前报废需要什么资料
  • 基于网页的客服系统
  • 为什么很多银行卡会被异地警方冻结
  • 纯HTML+CSS小兔鲜儿网站首页(静态网页)
  • 建厂购买材料的会计科目
  • 用简易计税办法开发票
  • 红字发票是可以抵扣吗
  • 企业研发费用资本化相关公司
  • 所有者投入的资本属于什么会计要素
  • mysql@变量
  • 财务报表审计的定义
  • 业务招待费税务风险
  • 税费损失
  • 改变记帐方式的原因
  • 认缴制的注册资金怎么算
  • 以长期股权投资换入存货
  • 企业银行贷款保证金多少
  • 外购材料用于建筑工程会计分录
  • 4月确认收入5月支出
  • 销售收入确认后怎么处理
  • 公账直接转给个人,对公司有什么影响吗
  • 技术咨询服务开票代码
  • 会计做账的凭据怎么写
  • 会计账簿的含义及其作用
  • 计算机二级考试时间2024
  • u盘装win7系统步骤
  • 设置自动清理缓存电脑
  • linux lsof命令详解
  • KbdTray.exe - KbdTray是什么进程 有什么作用
  • win7右下角点击没反应
  • xp磁盘空间不足怎么办
  • 新闻客户端app
  • android开发地图应用
  • 天天数链是做什么的
  • android常用命令
  • windows下dos命令
  • 3种不同的播种方法
  • android binary xml
  • nodejs eventloop
  • 利用python中的scikit-learn对疫情数据挖掘
  • jqueryui draggable
  • python中元祖的用法
  • 国家税务电子发票查验入口
  • 电子税务局申请开票额度增加
  • 山东省国家税务局官网
  • 德清社保局固定电话多少
  • 契税纳税申报表在哪里拿
  • 企业营商环境包括哪些内容
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设