【星海出品】flask 数据库问题

flask 和数据库的问题

bash 复制代码
pip install pymysql
pip install flask-sqlalchemy

1.Flask连接Mysql

新建flask项目,在app.py中编写

导入模块SQLAlchemy

创建SQLAlchemy实例对象,命名为db,将flask的实例对象app作为参数传给SQLAlchemy,将db和app联系起来,可以调用其相关功能

python 复制代码
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy(app)

配置数据库相关参数

bash 复制代码
# MySQL所在主机名,默认127.0.0.1
HOSTNAME = "127.0.0.1"
# MySQL监听的端口号,默认3306
PORT = 3306
# 连接MySQL的用户名,自己设置
USERNAME = "root"
# 连接MySQL的密码,自己设置
PASSWORD = "root"
# MySQL上创建的数据库名称
DATABASE = "database_learn"
# 通过修改以下代码来操作不同的SQL比写原生SQL简单很多 --》通过ORM可以实现从底层更改使用的SQL
app.config['SQLALCHEMY_DATABASE_URI'] = f"mysql+pymysql://{USERNAME}:{PASSWORD}@{HOSTNAME}:{PORT}/{DATABASE}?charset=utf8mb4"

使用数据库工具创建数据库并测试连接

python 复制代码
with app.app_context():
    with db.engine.connect() as conn:
        result = conn.execute("select 1")
        print(result.fetchone())
python 复制代码
from flask import Flask
import pymysql

app = Flask(__name__)

# 配置数据库连接信息
app.config['MYSQL_HOST'] = 'localhost'
app.config['MYSQL_USER'] = 'username'
app.config['MYSQL_PASSWORD'] = 'password'
app.config['MYSQL_DB'] = 'database_name'

# 创建数据库连接
db = pymysql.connect(
    host=app.config['MYSQL_HOST'],
    user=app.config['MYSQL_USER'],
    password=app.config['MYSQL_PASSWORD'],
    db=app.config['MYSQL_DB']
)

# 创建数据库游标
cursor = db.cursor()

@app.route('/')
def index():
    # 执行查询语句
    cursor.execute("SELECT * FROM users")
    result = cursor.fetchall()
    
    # 处理查询结果
    users = []
    for row in result:
        user = {
            'id': row[0],
            'name': row[1],
            'email': row[2]
        }
        users.append(user)
    
    # 返回结果
    return str(users)

if __name__ == '__main__':
    app.run()

插入语句

bash 复制代码
@app.route('/create_user')
def create_user():
    name = 'John'
    email = '[email protected]'
    
    # 执行插入语句
    cursor.execute("INSERT INTO users (name, email) VALUES (%s, %s)", (name, email))
    
    # 提交事务
    db.commit()
    
    return 'User created successfully'

更新数据

python 复制代码
@app.route('/update_user')
def update_user():
    id = 1
    email = '[email protected]'
    
    # 执行更新语句
    cursor.execute("UPDATE users SET email = %s WHERE id = %s", (email, id))
    
    # 提交事务
    db.commit()
    
    return 'User updated successfully'

删除数据

python 复制代码
@app.route('/delete_user')
def delete_user():
    id = 1
    
    # 执行删除语句
    cursor.execute("DELETE FROM users WHERE id = %s", (id,))
    
    # 提交事务
    db.commit()
    
    return 'User deleted successfully'

在上述示例代码中,我们使用了不同的SQL语句来执行插入、更新和删除操作。在执行这些操作后,我们需要调用db.commit()方法来提交事务,以确保数据的一致性。

相关推荐
呵呵哒( ̄▽ ̄)"6 分钟前
线性代数:同解(1)
python·线性代数·机器学习
dleei10 分钟前
MySql安装及SQL语句
数据库·后端·mysql
SweetCode12 分钟前
裴蜀定理:整数解的奥秘
数据结构·python·线性代数·算法·机器学习
CryptoPP25 分钟前
springboot 对接马来西亚数据源API等多个国家的数据源
spring boot·后端·python·金融·区块链
xcLeigh32 分钟前
OpenCV从零开始:30天掌握图像处理基础
图像处理·人工智能·python·opencv
大乔乔布斯33 分钟前
AttributeError: module ‘smtplib‘ has no attribute ‘SMTP_SSL‘ 解决方法
python·bash·ssl
信徒_41 分钟前
Mysql 在什么样的情况下会产生死锁?
android·数据库·mysql
明灯L1 小时前
《函数基础与内存机制深度剖析:从 return 语句到各类经典编程题详解》
经验分享·python·算法·链表·经典例题
databook1 小时前
不平衡样本数据的救星:数据再分配策略
python·机器学习·scikit-learn
碳基学AI1 小时前
哈尔滨工业大学DeepSeek公开课:探索大模型原理、技术与应用从GPT到DeepSeek|附视频与讲义免费下载方法
大数据·人工智能·python·gpt·算法·语言模型·集成学习