Flask中使用Flask-Migrate扩展迁移数据库
安装Flask-Migrate插件
(venv) $ pip install flask-migrate
注意到虚拟环境中(因为Flask环境就安装在虚拟环境中)
安装flask-script使python支持命令行操作
pip install flask-script
创建manage.py文件
#!/usr/bin/env python from flask_script import Manager
from flask_migrate import Migrate,MigrateCommand
#主文件中导入app初始化manage
from zhihu import app
#db = SQLAlchemy()
from exts import db
#导入需要迁移的数据库模型
from models import User,Questions,Answer #让python支持命令行工作
manager = Manager(app) #使用migrate绑定app和db
migrate = Migrate(app,db) #添加迁移脚本的命令到manager中
manager.add_command('db',MigrateCommand) if __name__ == '__main__':
manager.run()
初始化
(venv) $ python manage.py db init
创建迁移脚本
(venv) $ python manage.py db migrate
更新数据库
(venv) $ python hello.py db upgrade
第一次迁移实际上相当于调用db.create_all(),但在后续迁移中,upgrade命令对表实施更新操作但不影响表中的内容。
最后到数据库中查看数据表是否迁移成功。
Flask中使用Flask-Migrate扩展迁移数据库的更多相关文章
- 将 flask 中的 session 存储到 SQLite 数据库中
		
将 flask 中的 session 存储到 SQLite 数据库中 使用 flask 构建服务器后端时,常需要在浏览器端存储 cookie 用于识别不同用户,根据不同的 cookie 判断出当前请求 ...
 - flask中的Flask、request、render_temple、redirect和url_for
		
学flask也有一个多星期了,对这个web框架也有了一点的了解,梳理一些基础的知识点,还是小白一只,代码写得比较low,若文章有错误的地方欢迎大佬随时指正,代码中被注释掉的代码是关于预防csrf,无视 ...
 - laravel中使用mgirations创建和迁移数据库
		
使用php artisan make:migration create_links_table命令 编辑2016_04_11_095342_create_links_table public func ...
 - Python框架学习之Flask中的常用扩展包
		
Flask框架是一个扩展性非常强的框架,所以导致它有非常多的扩展包.这些扩展包的功能都很强大.本节主要汇总一些常用的扩展包. 一. Flask-Script pip install flask-scr ...
 - flask 使用Flask-Migrate迁移数据库(创建迁移环境、生成迁移脚本、更新数据库)
		
使用Flask-Migrate迁移数据库 在开发时,以删除表再重建的方式更新数据库简单直接,但明显的缺陷是会丢掉数据库中的所有数据.在生产环境下,没有人想把数据都删除掉,这时需要使用数据库迁移工具来完 ...
 - flask中如何生成迁移文件
		
在flask网站开发中,如果直接对数据库进行修改的话,风险比较高,最好的是由迁移文件生成,这样确保了数据的误操作. 在Flask中可以使用Flask-Migrate扩展,来实现数据迁移.并且集成到Fl ...
 - 在flask中使用flask-migrate管理数据库
		
Flask-Migrate是一个为Flask应用处理SQLAlchemy数据库迁移的扩展,使得可以通过Flask的命令行接口或者Flask-Scripts对数据库进行操作. 安装 pip3 insta ...
 - flask迁移数据库时报错:Target database is not up的解决方案
		
在flask中进行数据库迁移时报错,报错信息为"Target database is not up",解决方案如下 找到alembic的最新版本号,找到文件夹migrate下的最新 ...
 - Python框架学习之Flask中的数据库操作
		
数据库操作在web开发中扮演着一个很重要的角色,网站中很多重要的信息都需要保存到数据库中.如用户名.密码等等其他信息.Django框架是一个基于MVT思想的框架,也就是说他本身就已经封装了Model类 ...
 
随机推荐
- [Hdu1342] Lotto
			
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1342 题目大意:输出6--13从小到大个数,然后按顺序输出6个数,输出所有种可能. 解题思路:这题难度 ...
 - Apache常用配置
			
Apache配置文件:conf/httpd.conf.(注意:表示路径时使用‘/’而不使用‘\’,注释使用‘#’) 1. ServerRoot:服务器根目录,也就是Apache的安装目录,其他的目录配 ...
 - CentOS 7 校对时间  修改时区
			
在 CentOS 7 中, 引入了一个叫 timedatectl 的设置设置程序. 用法很简单: timedatectl # 查看系统时间方面的各种状态 Local time: 四 2014-12-2 ...
 - SEO诊断之关于网站收录(转)
			
如何让网站被搜索引擎收录?我的网站有收录无排名怎么办?这些网站收录问题估计是seo最应关心的根本问题之一,网站收录都没有何来排名?我整理了每天咨询最多最具代表性的 8 个关于网站收录的问题及其答案统一 ...
 - hdu 1011 Starship Troopers(树形DP入门)
			
Starship Troopers Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
 - Azure ARM虚拟机部署反恶意软件-安全扩展
			
Azure虚拟机,默认情况下没有安装杀毒软件.如果您有此需求可以通过Azure 扩展进行安装,有关Azure反恶意软件的官方说明请参考:https://docs.azure.cn/zh-cn/secu ...
 - html2cavans
			
简介:http://www.jianshu.com/p/6a07e974a7e8 下载:https://github.com/niklasvh/html2canvas/releases C#代理git ...
 - Java面试题解构
			
有次一个同事让我一同去面试一个候选人,没仔细看简历,所以在问了设计模式之后就让他谈一谈对内存泄漏和垃圾回收的理解,当时候选人一下子就懵了.后来才知道,他面的是初.中级开发职位,想来估计候选人心里也在骂 ...
 - Python 解LeetCode:680. Valid Palindrome II
			
题目:给定一个字符串,在最多删除一个字符的情况下,判断这个字符串是不是回文字符串. 思路:回文字符串,第一想到的就是使用两个指针,前后各一个,当遇到前后字符不一致的时候,有两种情况,删除前面字符或者删 ...
 - oracle数据库表实现主键自增功能
			
有关oracle中自增序列sequence+触发器trigger:实现数据表TABDATA_LIVE_CYCLE中的主键id的自增. CREATE SEQUENCE TABDATA_LIVE_CYCL ...