flask的查询mysql数据库数据库_Flask之数据库操作

4.2 数据库基本操作

在Flask-SQLAlchemy中,插入、修改、删除操作,均由数据库会话管理。会话用db.session表示。在准备把数据写入数据库前,要先将数据添加到会话中然后调用commit()方法提交会话。

数据库会话是为了保证数据的一致性,避免因部分更新导致数据不一致。提交操作把会话对象全部写入数据库,如果写入过程发生错误,整个会话都会失效。

数据库会话也可以回滚,通过db.session.rollback()方法,实现会话提交数据前的状态。

在Flask-SQLAlchemy中,查询操作是通过query对象操作数据。最基本的查询是返回表中所有数据,可以通过过滤器进行更精确的数据库查询。

将数据添加到会话中示例:

user = User(name='python')

db.session.add(user)

db.session.commit()

在视图函数中定义模型类

from flask import Flask

from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)

#设置连接数据库的URL

app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:mysql@127.0.0.1:3306/Flask_test'

#设置每次请求结束后会自动提交数据库中的改动

app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True

app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True

#查询时会显示原始SQL语句

app.config['SQLALCHEMY_ECHO'] = True

db = SQLAlchemy(app)

class Role(db.Model):

# 定义表名

__tablename__ = 'roles'

# 定义列对象

id = db.Column(db.Integer, primary_key=True)

name = db.Column(db.String(64), unique=True)

us = db.relationship('User', backref='role')

#repr()方法显示一个可读字符串

def __repr__(self):

return 'Role:%s'% self.name

class User(db.Model):

__tablename__ = 'users'

id =

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在Python中,如果数据库密码中包含特殊字符,可以使用`urllib.parse.quote`方法对密码进行URL编码来解决连接失败的问题。具体做法是将数据库密码中的特殊字符进行编码,例如@符号可以编码为%40。123 #### 引用[.reference_title] - *1* [flask使用SQLAlchemy数据库连接密码带有特殊符号](https://blog.csdn.net/weixin_37591442/article/details/124842906)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *2* [〖Python 数据库开发实战 - MySQL篇㉓〗- 单行子查询与多行子查询语法规则](https://blog.csdn.net/weixin_42250835/article/details/126187536)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *3* [python3 插入 mysql 时内容带有特殊字符处理](https://blog.csdn.net/shykevin/article/details/110257499)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值