如何使用Flask-SQLAlchemy来管理数据库连接和操作数据?

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

首先,我们需要安装Flask-SQLAlchemy。你可以使用pip来安装它,就像这样:

pip install Flask-SQLAlchemy

好了,现在我们已经有了一个可以操作数据库的工具,接下来让我们来看看如何使用它吧!

首先,我们需要创建一个Flask应用对象,并配置数据库的连接字符串和师:

from flask import Flask  
from flask_sqlalchemy import SQLAlchemy  
  
app = Flask(__name__)  
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+pymysql://username:password@localhost/mydatabase'  
app.config['SQLALCHEMY_TRACK_MODIFICATIONs'] = False  
db = SQLAlchemy(app)

现在,我们已经创建了一个数据库,接下来让我们来创建一些模型吧!

假设我们想要创建一个用户模型,可以像这样:

class User(db.Model):  
    id = db.Column(db.Integer, primary_key=True)  
    username = db.Column(db.String(80), unique=True, nullable=False)  
    email = db.Column(db.String(120), unique=True, nullable=False)  
  
    def __repr__(self):  
        return f'<User {self.username}>'

这个模型定义了一个名为User的表,其中包含id、username和email三个列。注意,我们使用了db.Column来定义每个列,并指定了它们的类型和其他属性。

现在我们已经创建了一个模型,让我们来看看如何操作数据吧!

首先,让我们来看看如何插入数据:

db.create_all()  # 创建所有表  
user1 = User(username='john', email='john@example.com')  
user2 = User(username='mary', email='mary@example.com')  
db.session.add_all([user1, user2])  
db.session.commit()  # 提交更改

这个代码片段创建了两个用户,并将它们添加到数据库中。注意,我们使用db.session来管理所有的更改,并在最后提交更改。

现在我们已经有了一些数据,接下来让我们来看看如何查询数据:

users = User.query.all()  # 查询所有用户  
john = User.query.filter_by(username='john').first()  # 查询名为john的用户

这个代码片段使用User.query来查询所有用户和名为john的用户。注意,我们可以在查询中使用过滤器来筛选数据。

如果我们需要修改或删除数据呢?很简单,让我们来看看:

john.email = 'newemail@example.com'  # 修改用户email地址  
db.session.commit()  # 提交更改  
  
db.session.delete(john)  # 删除用户  
db.session.commit()  # 提交更改

这个代码片段修改了名为john的用户的email地址,并将其从数据库中删除。注意,我们仍然使用db.session来管理所有的更改,并在最后提交更改。

好了,现在你已经知道如何使用Flask-SQLAlchemy来管理数据库连接和操作数据了。如果你还有其他问题,随时向我提问!

假设我们想要创建一个新的模型,名为Post,它包含标题和内容字段。我们可以使用以下代码:

class Post(db.Model):  
    id = db.Column(db.Integer, primary_key=True)  
    title = db.Column(db.String(80), unique=False, nullable=False)  
    content = db.Column(db.Text, unique=False, nullable=True)  
  
    def __repr__(self):  
        return f'<Post {self.title}>'

这个模型定义了一个名为Post的表,其中包含id、title和content三个列。注意,我们使用了db.Column来定义每个列,并指定了它们的类型和其他属性。

现在我们已经创建了一个新的模型,让我们来看看如何将它们关联起来。假设我们想要将用户和帖子关联起来,以便我们能够知道哪些用户发布了哪些帖子。我们可以使用以下代码:

class User(db.Model):  
    id = db.Column(db.Integer, primary_key=True)  
    username = db.Column(db.String(80), unique=True, nullable=False)  
    email = db.Column(db.String(120), unique=True, nullable=False)  
    posts = db.relationship('Post', backref='user', lazy='dynamic')  
  
    def __repr__(self):  
        return f'<User {self.username}>'  
  
  
class Post(db.Model):  
    id = db.Column(db.Integer, primary_key=True)  
    title = db.Column(db.String(80), unique=False, nullable=False)  
    content = db.Column(db.Text, unique=False, nullable=True)  
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'))  
  
    def __repr__(self):  
        return f'<Post {self.title}>'

在这个代码片段中,我们在User模型中添加了一个名为posts的属性,它使用了db.relationship来关联Post模型。我们还添加了一个名为user_id的列,它将与User模型的id列关联起来。

现在我们已经将用户和帖子关联起来了,让我们来看看如何使用这个关联。假设我们想要获取用户john发布的的所有帖子,我们可以使用以下代码:

john = User.query.filter_by(username='john').first()  
posts = john.posts.all()  
for post in posts:  
    print(post.title, post.content)

这个代码片段首先获取名为john的用户,然后获取该用户发布的的所有帖子,并逐个打印每个帖子的标题和内容。

希望这些示例代码能够帮助你更好地理解如何使用Flask-SQLAlchemy来管理数据库连接和操作数据。文章来源地址https://www.toymoban.com/news/detail-612666.html

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

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

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

相关文章

  • 快速上手Flask(三) 在 Flask应用中使用Flask-SQLAlchemy(flask SQLAlchemy模型对象如何json序列化输出)

    常见情况下对于只有一个 Flask 应用,所有您需要做的事情就是创建 Flask 应用,选择加载配置接着创建 SQLAlchemy 对象时候把 Flask 应用传递给它作为参数。 官网:https://www.sqlalchemy.org/ 参考本人 文章:python常用库之数据库orm框架之SQLAlchemy 官方文档: 中文: http://www.pythondoc.co

    2024年01月25日
    浏览(56)
  • flask中的操作数据库的插件Flask-SQLAlchemy

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

    2024年02月09日
    浏览(60)
  • flask-sqlalchemy使用

    # sqlalchemy 集成到flask中 # 第三方: flask-sqlalchemy 封装了用起来,更简洁 安装 使用

    2024年02月13日
    浏览(91)
  • flask---》更多查询方式/连表查询/原生sql(django-orm如何执行原生sql)/flask-sqlalchemy

    sqlalchemy执行原生sql django执行原生sql

    2024年02月13日
    浏览(37)
  • Flask-SQLAlchemy

    认识Flask-SQLAlchemy Flask-SQLAlchemy 是一个为 Flask 应用增加 SQLAlchemy 支持的扩展。它致力于简化在 Flask 中 SQLAlchemy 的使用。 SQLAlchemy 是目前python中最强大的 ORM框架, 功能全面, 使用简单。 ORM优缺点 优点 有语法提示, 省去自己拼写SQL,保证SQL语法的正确性 orm提供方言功能(dialect, 可

    2024年02月12日
    浏览(38)
  • Flask从入门到放弃五(SQLAlchemy介绍与快速使用、创建表插入数据、Scoped_session线程安全、基本增删查改、表模型、Flask-SQLAlchemy、Migrate的使用)

    SQLAlchemy是一个基于Python实现的ORM框架。该框架建立在 DB API之上,使用关系对象映射进行数据库操作,简言之便是:将类和对象转换成SQL,然后使用数据API执行SQL并获取执行结果。 SQLAlchemy的组成部分有: Engine 框架的引擎 Connection Pooling 数据库连接池 Dialect 选择连接数据库的

    2024年02月04日
    浏览(53)
  • Flask-SQLAlchemy事件钩子介绍

    前几天在搜资料的时候无意中看到有介绍SQLAlchemy触发器,当时感觉挺奇怪的,触发器不是数据库层面的概念吗,怎么flask-SQLAlchemy这个ORM框架会有这玩意。 考虑到效率博客表中有两个字段,body用于存储markdown源文本,body_html存储转换成html的内容,这里就可以在保存数据时使用

    2024年02月06日
    浏览(51)
  • 3.flask-sqlalchemy ORM库

    Flask-SQLAlchemy是一个用于Flask的扩展,它提供了一个便捷的方式来处理数据库操作。Flask-SQLAlchemy基于SQLAlchemy,一个功能强大的Python SQL工具包和对象关系映射(ORM)系统 官网文档: http://www.pythondoc.com/flask-sqlalchemy/ 一对多关系是指一个模型与另一个模型之间存在多对一的关系。在

    2024年02月10日
    浏览(44)
  • flask-sqlalchemy结合Blueprint遇到循环引入问题的解决方案

    想要用flask_sqlalchemy结合Blueprint分模块写一下SQL的增删改查接口,结果发现有循环引入问题。 一开始,我在app.py中使用db = SQLAlchemy(app)创建数据库对象;并且使用app.register_blueprint(db_bp, url_prefix=\\\'/db\\\')注册蓝图。 这使得我的依赖关系是这样的。db.py → app,py 中的db对象;app.py →

    2024年02月07日
    浏览(41)
  • 【flask sqlalchmey】一次性将返回的列表对象或者 一行数据对象转成dict---flask-sqlalchemy输出json格式数据

    结果示例: 另外: res = Sysdict.query.all() 这种写法已经不被推荐了, 推荐的是scalar_one() 获取一行,scalars()获取多行 user = db.session.execute(db.select(User).filter_by(username=username)).scalar_one() users = db.session.execute(db.select(User).order_by(User.username)).scalars() 一般的 json.dumps(users) 或者 jsonify(use

    2024年02月13日
    浏览(55)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包