flask数据库操作

这篇具有很好参考价值的文章主要介绍了flask数据库操作。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

flask数据库操作,flask,python,flask,数据库,python

本文将详细介绍在Flask Web应用中如何设计数据库模型,并使用Flask-SQLAlchemy等扩展进行数据库操作的最佳实践。内容涵盖数据模型设计,ORM使用,关系映射,查询方法,事务处理等方面。通过本文,您可以掌握Flask数据库应用的基本知识。

Flask作为一个流行的Python Web框架,提供了高度的灵活性来构建Web应用程序。但是Flask本身不包含数据库抽象层,所以我们需要选择合适的数据库工具来辅助开发。

1. 数据库工具选择

要在Flask中集成数据库操作,我们通常有以下几种选择:

  • 原生SQL:直接使用Python中的DBAPI,如MySQL-Python等,编写SQL语句操作数据库。但这需要自行处理许多细节。

  • SQLAlchemy:这是一个非常强大的ORM框架,可以映射Python对象到数据库表,简化数据库操作。推荐用于复杂项目。

  • Flask-SQLAlchemy:这是在Flask中整合SQLAlchemy的扩展,可以便捷地将其与Flask应用结合使用。

  • 其他扩展:如Flask-MongoEngine for MongoDB,Flask-Pony for PonyORM等。

考虑到SQLAlchemy提供的便利性,我们这里选择使用Flask-SQLAlchemy来示例Flask的数据库用法。

2. 安装Flask-SQLAlchemy

使用pip安装Flask-SQLAlchemy:

pip install flask-sqlalchemy

然后在Flask应用中进行初始化:

from flask import Flask 
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)

app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///test.db' 
db = SQLAlchemy(app)

3. 定义模型

使用Flask-SQLAlchemy时,数据库使用ORM映射模型表示。我们可以定义代表表的Model类:

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(80), unique=True)
    email = db.Column(db.String(120), unique=True)

    def __repr__(self):
        return '<User %r>' % self.username

User类表示users表,类的属性映射到表的列。有PrimaryKey,Unique等约束。

4. 创建表

有了Model类定义,我们可以通过migrate命令创建对应的数据库表:

flask db init
flask db migrate
flask db upgrade 

这将根据Model类创建数据库表。

5. CRUD操作

有了映射表,我们就可以进行常规的CRUD操作:

创建

user = User(username='greyli', email='greyli@example.com')
db.session.add(user) 
db.session.commit() 

查询

User.query.get(1) # 主键查询
User.query.filter_by(username='greyli').first() # 条件查询

更新

user = User.query.get(1)
user.username = 'new username'
db.session.commit() # 提交更新

删除

user = User.query.get(1)
db.session.delete(user)
db.session.commit() # 提交删除

可以看到Flask-SQLAlchemy为这些常见操作提供了简单的API。

6. 关系映射

关系映射也是ORM的重要功能之一。例如一篇文章可对应多个标签,我们可以定义:

class Article(db.Model):
  id = db.Column(db.Integer, primary_key=True)
  title = db.Column(db.String(100), unique=True)
  tags = db.relationship('Tag', backref='article', lazy='dynamic')

class Tag(db.Model):
  id = db.Column(db.Integer, primary_key=True)
  name = db.Column(db.String(20), unique=True)

这样Article和Tag之间就建立了一对多的关系,可以方便地查询:

article = Article.query.get(1)
tags = article.tags

7. 事务处理

事务处理可以保证数据库操作的完整性:

try:
  article = Article(title='my article')
  db.session.add(article)
  db.session.commit() 
except:
  db.session.rollback()
  raise

这样可以回滚错误的修改,保证事务的原子性。

补充

在Flask应用中,这几条命令是用于数据库迁移的:

  1. flask db init

这个命令会初始化一个迁移仓库,在migrations文件夹下创建必要的文件。这个迁移仓库用于追踪数据库模式的变更。

  1. flask db migrate

这个命令会自动比对模型定义和现有数据库的差异,然后生成一个迁移脚本,放在migrations/versions文件夹下。

这个迁移脚本包含了使数据库模式达到我们模型定义的状态所需要的操作指令(如创建新表,添加字段等)。

  1. flask db upgrade

这个命令则会执行迁移仓库中所有的迁移脚本,实际更新数据库模式,使数据库与模型一致。

所以这三步命令的作用是:

  1. 初始化迁移仓库

  2. 生成迁移脚本

  3. 执行迁移操作

当我们修改了模型类的时候,只需要再次运行:

flask db migrate
flask db upgrade

就可以自动更新数据库,非常方便。

这样做的好处是可以很好地追踪数据库模式的变迁,同时可以通过downgrade回滚变更。总体上可以更轻松地管理数据库模式。

所以Flask强烈建议使用这套迁移机制来维护数据库,而不是直接修改数据库模式。文章来源地址https://www.toymoban.com/news/detail-624945.html

到了这里,关于flask数据库操作的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • flask中的操作数据库的插件Flask-SQLAlchemy

    Web 开发中,一个重要的组成部分便是数据库了。Web 程序中最常用的莫过于关系型数据库了,也称 SQL 数据库。另外,文档数据库(如 mongodb)、键值对数据库(如 redis)近几年也逐渐在 web 开发中流行起来,我们习惯把这两种数据库称为 NoSQL 数据库。 大多数的关系型数据库引

    2024年02月09日
    浏览(61)
  • 如何使用Flask-SQLAlchemy来管理数据库连接和操作数据?

    首先,我们需要安装Flask-SQLAlchemy。你可以使用pip来安装它,就像这样: 好了,现在我们已经有了一个可以操作数据库的工具,接下来让我们来看看如何使用它吧! 首先,我们需要创建一个Flask应用对象,并配置数据库的连接字符串和师: 现在,我们已经创建了一个数据库,

    2024年02月15日
    浏览(50)
  • Python Flask Web开发二:数据库创建和使用

    数据库在 Web 开发中起着至关重要的作用。它不仅提供了数据的持久化存储和管理功能,还支持数据的关联和连接,保证数据的一致性和安全性。通过合理地设计和使用数据库,开发人员可以构建强大、可靠的 Web 应用程序,满足用户的需求。这里介绍:SQLAlchemy 安装pymysql和

    2024年02月10日
    浏览(65)
  • 将网页数据读入数据库+将数据库数据读出到网页——基于python flask实现网页与数据库的交互连接【全网最全】

    【全网最全!保姆级教学!!】 本篇博客基于flask技术,实现数据库和网页端的交互。 实现效果:在网页端输入数据,能够将数据存入数据库。反向操作时,能将数据库的数据取出,显示在网页端。不仅如此,还支持数据的查询和修改。  读取网页数据存入数据库,效果如下

    2024年02月13日
    浏览(48)
  • python使用flask实现前后端分离&通过前端修改数据库数据【全栈开发基础】

    完整代码放到了最后,时间紧张的话直接拉到最后或点击目录【🥩 完整代码】看完整代码 这里先提一下,我们运行后端代码之前需要先建立一个名字为 python 的数据库,而后在该数据库下创建表 userinfo ,因为看到有的朋友后端代码拿过去后会运行不起来或者就是直接报错了

    2023年04月09日
    浏览(43)
  • python:使用Flask-SQLAlchemy对数据库增删改查的简单示例

    以下将介绍Flask-SQLAlchemy对数据库增删改查的简单示例。 一、安装所需的库 pip install flask flask-sqlalchemy flask-mysql 二、创建数据表 本示例使用mysql创建数据库和表 CREATE TABLE `user` (   `id` int(11) NOT NULL AUTO_INCREMENT,   `name` varchar(255) DEFAULT NULL,   `age` int(11) DEFAULT NULL,   PRIMARY KEY (`id

    2024年02月07日
    浏览(68)
  • 基于python淘宝商品数据爬虫分析可视化系统 网络爬虫+Flask框架+MySQL数据库 大数据 毕业设计

    python语言、Flask框架、淘宝商品数据、selenium网络爬虫、MySQL数据库、数据分析、Echarts可视化大数据毕业设计、爬取 Selenium网络爬虫淘宝商品数据可视化系统是一个基于Python和Selenium的Web爬虫应用程序,可以实现对淘宝上特定商品的价格、销量、评价等数据进行自动化抓

    2024年02月16日
    浏览(54)
  • 毕业设计:python人脸识别考勤系统 签到系统 深度学习 Flask框架 Dlib库 MySQL数据库 大数据(源码+论文)✅

    🍅 大家好,今天给大家分享一个Python项目,感兴趣的可以先收藏起来,点赞、关注不迷路! 🍅 大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助同学们顺利毕业 。 技术栈: Python语言、MySQL数据库、Flask框架、Echarts可视化、Dlib库、刷脸签到、多

    2024年03月22日
    浏览(74)
  • 毕业设计:基于python人脸识别考勤系统 签到系统 深度学习 Flask框架 Dlib库 MySQL数据库 大数据(源码+论文)✅

    毕业设计:2023-2024年计算机专业毕业设计选题汇总(建议收藏) 毕业设计:2023-2024年最新最全计算机专业毕设选题推荐汇总 🍅 感兴趣的可以先收藏起来,点赞、关注不迷路,大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助同学们顺利毕业 。

    2024年02月20日
    浏览(76)
  • Python之数据库操作(连接数据库,增删改查操作,易错点理解)

    文章目录 前言 一、Python之数据库操作 二、 pymysql 安装 三、pymysql 包引入  连接数据库 创建游标 执行sql数据 - 增删改查 要获取查询结果数据 关闭游标,关闭数据库连接 总结 记录:Python操作数据库的步骤,不容易理解的地方。 学习地址: python与各大数据库的连接: http:/

    2023年04月16日
    浏览(57)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包