Flask_SQLAlchemy 在配置连接MySQL的路由时出现错误/根据报错信息,应该是密码中包含@字符的原因

首先来看一下原代码

用户名:root

密码:xxxx@lp

                                # 连接MySQL的路由          

SQLALCHEMY_DATABASE_URI = "mysql+pymysql://root:xxxx@lp@127.0.0.1:3306/jiyun"

再来看一下报错信息

MySQL服务器不能在箭头指向的地址连接 而这个连接明显将我 @符号后面的 lp 也给算上了[🤦‍]

然后就根据这点查找资料

解决方法

找到了一个python库中的quote_plus方法,可以用下方方法进行导包

from urllib.parse import quote_plus

修改后的代码

# 导包
from urllib.parse import quote_plus

# 连接MySQL的路由   使用f格式化   

SQLALCHEMY_DATABASE_URI = 
    f"mysql+pymysql://root:{quote_plus('xxxx@lp')}@127.0.0.1:3306/jiyun"

这样解决了 密码中包含 @ 等特殊符号的错误

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Flask-SQLAlchemy是一个轻量级的ORM(对象关系映射)库,用于将Python对象映射到SQL数据库表上,使得在Flask应用操作数据库变得更加简单。在前后端分离的Flask应用,它通常用于处理数据层逻辑,包括模型定义、数据库操作和与后端API的交互。 以下是使用Flask-SQLAlchemy的基本步骤,假设我们有一个简单的用户模型: 1. 安装Flask-SQLAlchemy: ```bash pip install Flask-SQLAlchemy ``` 2. 在Flask应用初始化文件(如`app.py`)设置配置: ```python from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) app.config['SQLALCHEMY_DATABASE_URI'] = 'your_database_connection_string' db = SQLAlchemy(app) ``` 这里你需要替换`your_database_connection_string`为你实际的数据库连接字符串。 3. 定义数据库模型(User模型): ```python 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}>' ``` 4. 创建数据库表(如果表不存在): ```python with app.app_context(): db.create_all() ``` 5. 后端API的路由和CRUD操作: ```python @app.route('/users', methods=['GET']) def get_users(): users = User.query.all() return {'users': [u.to_dict() for u in users]} @app.route('/users/<int:user_id>', methods=['GET']) def get_user(user_id): user = User.query.get_or_404(user_id) return {'user': user.to_dict()} # ...其他增删改查操作 ``` 这里的`to_dict()`方法用于将数据库对象转换为字典以便序列化返回给前端。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

onlooker10086

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值