首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Flask-SQLAlchemy学习笔记

Flask-SQLAlchemy是一个Flask扩展,简化了Flask应用中使用SQLAlchemy的操作,SQLAlchemy是一个强大的关系型数据库框架,支持多种数据库后台。..., "data.sqlite") 知识点笔记 笔记与下面的实列是对应的 # Windowsflask启动: # set FLASK_APP=sql_test.py # flask run # windows...,当数据库模型变更,使用app_db.create_all()不会更新当前已存在的数据库,可以通过这中暴力方式3直接删除该文件,重新生成 # 插入行,数据,同样进入flask shell模式进行操作..., primary_key=True) name = app_db.Column(app_db.String(64), unique=True) # unique:该列不允许出现重复的值...migrate = Migrate(app,db) # 初始化命令:该命令会在当前目录下创建migrations目录,所以的迁移脚本都会存放在这里 flask db init # 自动创建迁移脚本,有时候自动创建迁移脚本是不一定能准确生成的

1.7K20

python开发部署时新增数据库中表的方法

项目版本让运维部署,涉及到数据库表的增加问题,想了一下,可以有四种方法 1.使用SQLAlchemy的db.create_all()方法 # -*- coding:utf-8 -*- from flask...() db.close() 3.使用Flask-Migrate扩展迁移数据库 安装相关插件 $ pip install Flask-Migrate 文件名:migrate_create_table.py...first:通过init命令来创建一个迁移库,执行后会在文件同级目录创建一个migrations文件夹,里面存放了所有迁移脚本。...already exists python migrate_create_table.py db init secound:通过migrate命令创建自动迁移脚本,此时会在数据库增加一张表(alembic_version...db upgrade 这时候打开数据库,便可看到新增的表,以及alembic_version表中新增的版本号 注意点:1.以后数据库迁移更新中,不再需要初始化,所以跳过init命令

89110
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Flask 中的数据库迁移

    我之前使用 Flask 实现简单接口,为了方便,我每次都会将数据表删除掉,然后重新创建表和添加数据。...初始化迁移仓库 python flask_migrate_db.py db init 项目目录下执行 init 初始化命令,会自动项目目录下创建一个 migrations 目录。...添加下面的代码,然后 python flask_migrate_db.py 运行代码,两张表里面各添加一条数据。...先注释掉添加数据的代码(有唯一字段不能重复运行和添加),然后 Computer 类中添加一个字段。 price = db.Column(db.Integer) 5....前面提到, Linux 系统中可以顺利执行数据库迁移 Windows 中会失败,是因为 Alembic 生成迁移脚本的机制,现在就简单解释一下原因。

    1.7K30

    Flask 开发个人博客简单示例

    步骤3:激活虚拟环境 根据您使用的操作系统,命令行中运行适当的命令来激活虚拟环境: Windows: venv\Scripts\activate Mac和Linux: source venv.../bin/activate 步骤4:安装Flask和其他依赖 激活的虚拟环境中,运行以下命令来安装Flask和其他所需的依赖: pip install Flask pip install flask_sqlalchemy...命令行中运行以下命令,创建数据库迁移所需的文件: flask db init 然后,运行以下命令来生成初始迁移flask db migrate -m "Initial migration" 最后...,应用迁移并创建数据库表: flask db upgrade 步骤8:创建表单 app.py文件中,定义一个表单类来处理博客文章的创建。...步骤11:运行应用 命令行中运行以下命令,启动Flask应用: flask run 现在,您可以通过访问http://localhost:5000来查看您的个人博客网站。

    26610

    flask 数据库迁移_数据库迁移方案

    flask中可以使用Flask-Migrate扩展,来实现数据迁移。并且集成到flask-Script中,所有的操作通过命令就能完成。...Flask-Migrate提供了一个MigrateCommand类,可以附加到flask-script的manage对象。...会创建migrations文件夹,所有的迁移文件都放在里面。 python manage.py db init 创建自动迁移脚本: upgrade():函数把迁移中的改动应用到数据库中。...python manage.py db migrade -m 'initial migration' 注意:这里有可能出现着个错误 只需要把-m给删掉就可以了,参数太多没办法 发现有不同,...此时更新数据库 python manage.py db upgrade 更新完之后,在数据库会出现一个表 versions每迁移一次里面都会生成一个文件。

    3.8K20

    Python Flask 轻量 web 框架

    【前置条件:你已经windows下搭建好了Pycharm集成开发工具+python3.6的版本及相关的第三方包】 Step1:直接上框架全图 ---- Step2:框架的结构说明 ---- 项目结构...__ 初始化文件 初始化整个Flask对象,以及Flask所用的各种插件,并返回一个app应用 - app/settings 项目配置文件 配置整个项目运行环境 - app/ext 项目的扩展库...迁移目录 ---- 数据迁移 - 将模型映射到数据库 - 使用flask-migrate库 - 安装与使用 pip install flask-migrate 初始化,需要使用app和db...python manage.py db init init 初始化指令,仅可调用一次 python manage.py db migrate migrate指令用于生成迁移文件...内部迁移文件使用了链表来关联关系 --message MSG 对迁移添加日志说明 python manage.py db upgrade upgrade指令用于执行迁移文件

    16530

    带你认识 flask 错误处理

    我将解决所有的这些问题,但首先,让我们来谈谈Flask的调试模式。 02 调试模式 你在上面看到的处理错误的方式对在生产服务器运行的系统非常有用。...如果出现错误,用户将得到一个隐晦的错误页面(尽管我打算使这个错误页面更友好),错误的重要细节服务器进程输出或存储到日志文件中。...但是当你正在开发应用时,可以启用调试模式,它是Flask浏览器直接运行一个友好调试器的模式。...开发,这是非常好的,但是一旦将应用部署在生产服务器,没有人会关心输出,因此需要采用更强大的解决方案。 我认为对错误发现采取积极主动的态度是非常重要的。如果生产环境的应用发生错误,我想立刻知道。...日志文件的第一个有趣用途是,服务器每次启动都会在日志中写入一行。当此应用在生产服务器运行时,这些日志数据将告诉你服务器何时重新启动过。

    2.1K30

    Python Flask 轻量web框架

    前置条件: 你已经Windows下搭建好了Pycharm集成开发工具+Python3.6的版本及相关的第三方包 Step1:框架全图 Step2:框架的结构说明 项目结构 - manage.py 用来控制程序的...初始化整个Flask对象,以及Flask所用的各种插件,并返回一个app应用 - app/settings 项目配置文件 配置整个项目运行环境 - app/ext 项目的扩展库 第三方扩展库打包处理...迁移目录 数据迁移 - 将模型映射到数据库 - 使用flask-migrate库 - 安装与使用 pip install flask-migrate 初始化,需要使用app和db进行初始化,migrate...=Migrate(app,db) 配置flask-script 的命令 manager.add_command('db',MigrateCommand) - 指令使用 python...manage.py db init init 初始化指令,仅可调用一次 python manage.py db migrate migrate指令用于生成迁移文件 内部迁移文件使用了链表来关联关系

    71800

    Flask 轻量web框架

    【前置条件:你已经windows下搭建好了Pycharm集成开发工具+python3.6的版本及相关的第三方包】 Step1:直接上框架全图 ---- Step2:框架的结构说明 ---- 项目结构...__ 初始化文件 初始化整个Flask对象,以及Flask所用的各种插件,并返回一个app应用 - app/settings 项目配置文件 配置整个项目运行环境 - app/ext 项目的扩展库...迁移目录 ---- 数据迁移 - 将模型映射到数据库 - 使用flask-migrate库 - 安装与使用 pip install flask-migrate 初始化,需要使用app和db...python manage.py db init init 初始化指令,仅可调用一次 python manage.py db migrate migrate指令用于生成迁移文件...内部迁移文件使用了链表来关联关系 --message MSG 对迁移添加日志说明 python manage.py db upgrade upgrade指令用于执行迁移文件

    83620

    Flask 系列之 Migration

    说明 操作系统:Windows 10 Python 版本:3.7x 虚拟环境管理器:virtualenv 代码编辑器:VS Code 实验目标 通过使用 flask-migrate 实现数据库的迁移操作...=True) name = db.Column(db.String(128)) 然后,打开当前项目的虚拟环境窗口,尝试执行下图操作: set flask_app=manage.py # 初始化...migration flask db init #执行 migration flask db migrate -m "initialize" # 更新 migration(注:如果不执行此步,那么我们的变动则无法同步到数据库...以后,当我们的数据模型发生修改的话,我们只需要重复上述的 flask db migrate 和 flask db upgrade 操作即可。...总结 关于 Flask-Migrate 的更多操作,我们可以通过执行 flask db 查看。如下图所示,这里不做过多的解释了。 相关参考 Flask-Migrate

    63020

    Python 数据库迁移工具 Alembic

    创建 Alembic 迁移环境 使用 Alembic 之前需要先建立一个 Alembic 脚本环境,通过工程目录下输入 alembic init alembic 命令可以快速应用程序中建立 Alembic...env.py 文件:一个 python 文件,调用 Alembic 命令该脚本文件运行。 script.py.mako 文件:是一个 mako 模板文件,用于生成新的迁移脚本文件。...出现错误的原因是没有使用 Alembic 更新数据库,如果你没有手动创建数据表可以使用 alembic upgrade head 命令消除该错误,如果你已经通过命令行或其他方式创建了数据表,可以使用...其内置了 Click 命令行程序, Flask 可直接使用命令行工具进行数据库的迁移。关于 Click 的使用请参考 Python 命令行神器 Click。...Flask-Migrate 支持使用 pip 进行安装: pip install flask-migrate Flask-Migrate 安装完成后,会在 Flask 应用程序的命令下自动生成一个 db

    3.4K10

    带你认识 flask 中的数据库

    简直是太强大了,你可以开发的时候使用简单易用且无需另起服务的SQLite,需要部署应用到生产服务器,则选用更健壮的MySQL或PostgreSQL服务,并且不需要修改应用代码(译者注:只需修改应用配置...那么让我们通过运行flask db init来创建microblog的迁移存储库: (venv) $ flask db init Creating directory /home/miguel/microblog...使用类似MySQL和PostgreSQL的数据库服务,必须在运行upgrade之前在数据库服务器创建数据库。...测试无误后,将迁移脚本添加到源代码管理并提交。 当准备将新版本的应用发布到生产服务器,你只需要获取包含新增迁移脚本的更新版本的应用,然后运行flask db upgrade即可。...如果在会话执行的任何时候出现错误,调用db.session.rollback()会中止会话并删除存储在其中的所有更改。

    2.3K20

    Flask 数据创建出错

    当我们使用 Flask 创建数据遇到错误,可能有多种原因,包括代码错误、数据库配置问题或依赖项错误。...进行到创建数据的步骤错误地删除了数据库,于是重新创建了数据库并进行了迁移。但是,当尝试添加几行数据,却遇到了错误。.../flask/lib/python2.7/site-packages/sqlalchemy/orm/interfaces.py", line 144, in init self.do_init()...因此,可以尝试 Post 模型中查找 tablename 属性,然后 User 模型中定义与 Post 的关系,使用 Post.tablename 作为字符串。这种方法应该可以解决问题。...__tablename__)执行该操作之后,就可以成功添加数据了。通过这些步骤,相信大家应该能够解决大多数 Flask 数据创建的常见问题。

    9010

    「源码分享」用flask创建一个完整的工程结构

    在此介绍 PyCharm 下flask如何创建有一个完整的工程结构。 以用户登录模型为例,介绍流程: 注意:若在pycharm中运行的话。...,pymysql:用Flask对象初始化SQLAlchemy,可以flask项目中使用MTV模 式进行各种对数据库的操作 flask_migrate,flask_script:用于数据库的迁移操作...def __init__(self, username, password): self.username = username self.password = password 8、flask文件下创建...(app,db) # 添加数据库迁移指令,该操作保证数据库的迁移可以使用指令操作 manage.add_command('db',MigrateCommand) #以下为当指令操作runserver,...① python manage.py db init  (只运行一次,为生成migrations文件夹,以便之后数据改变,版本 迁移) ② python manage.py db migrate  (完成迁移

    3.3K40

    4.alembic数据迁移工具

    5,6步骤即可 1.2.alembic常用命令和经典错误解决办法 常用命令和参数解释: init:创建一个alembic仓库 rebision:创建一个新的版本文件 --autogenerate:自动将当前模型的修改...downgrade函数 heads:展示当前可用的heads脚本文件 history:列出所有的迁移版本及其信息 current:展示当前数据库中的版本号 经典错误 1.FAILED:Target databases...current落后于heads的版本    解决办法:将current移动到head。...cmd终端也可以通过current命令查看 alembic current 1.4.Flask-SQLAlchemy下使用alembic (1)config.py DB_URI = "mysql+pymysql...#用的是db.Model target_metadata = flask_alembic_demo.db.Model.metadata (6)生成迁移脚本 alembic revision --autogenerate

    1.6K30

    Flask基础入门学习笔记-1

    =1 Flask 命令: # 运行开发服务器(启动参数指定) flask run --port 8000 --extra-files file1:dirA/file2:dirB/ # 运行开发服务器...(从环境变量中读取启动端口) flask shell ---- 0x02 基础尝试 描述:一个简单Flask项目创建流程如下: 1.导入flask包中的Flask模块 2.创建Flask对象 3.使用对象实例进行路由注册.../App/ ├── __init__.py ├── __pycache__ # Flask 运行时候缓存 │ ├── __init__.cpython-37.pyc │ └──...= Migrate() # 后初始化化懒加载 def init_ext(app): db.init_app(app) migrate.init_app(app, db) Day2\SQLAlchemy...; ---- 会话保持 描述: 我们知道学习WEB后端语言它是我们都绕不开的话题 , 网页中采用会话保持技术进行跨请求共享数据,实际它就是存储访问者的访问票据; 其出现原因: 1) Web 开发中HTTP

    1.7K10
    领券