Python flask怎么连接MySQL?

在Python中连接MySQL并使用模型创建新的表,通常我们会使用ORM(对象关系映射)库,比如SQLAlchemy或者Django ORM,它们允许我们定义Python类来映射到数据库中的表,并通过这些类进行数据库操作。下面是一个使用SQLAlchemy的例子。(flask可以使用)

首先,你需要安装必要的库:

```bash

pip install sqlalchemy pymysql

```

然后,你可以定义一个模型(通常是一个Python类),该类继承自SQLAlchemy的`Base`类,并定义表的结构:

```python

from sqlalchemy import Column, Integer, String, create_engine

from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy.orm import sessionmaker

定义基类

Base = declarative_base()

定义模型类

class User(Base):

tablename = 'users'

id = Column(Integer, primary_key=True)

name = Column(String)

email = Column(String)

def repr(self):

return f"<User(id={self.id}, name={self.name}, email={self.email})>"

创建数据库连接

engine = create_engine('mysql+pymysql://username:password@localhost:3306/dbname')

创建所有表

Base.metadata.create_all(engine)

创建会话

Session = sessionmaker(bind=engine)

session = Session()

示例:添加一个新的用户

new_user = User(name='John Doe', email='johndoe@example.com')

session.add(new_user)

session.commit()

关闭会话

session.close()

```

在上面的代码中:

  • 我们导入了必要的SQLAlchemy模块和`pymysql`,后者是一个Python的MySQL客户端。

  • 我们定义了`User`类,它映射到名为`users`的MySQL表。

  • 我们创建了数据库引擎`engine`,并指定了连接MySQL的URI(用户名、密码、主机和数据库名)。

  • 我们调用了`Base.metadata.create_all(engine)`来创建所有定义的表。

  • 我们创建了一个会话`session`,它用于与数据库进行交互。

  • 示例中,我们添加了一个新用户到数据库中,并提交事务。

  • 最后,我们关闭了会话。

请确保将`username`、`password`、`localhost`、`3306`和`dbname`替换为你自己的MySQL数据库的实际凭证和设置。

此外,如果你使用的是Django框架,Django ORM提供了类似的功能,并且与Django的其他组件(如视图、模板等)紧密集成。使用Django ORM时,你需要遵循Django的项目和应用结构,并在应用的`models.py`文件中定义模型。然后,Django的迁移系统可以为你创建和管理数据库表。

相关推荐
Q_Q196328847525 分钟前
python+springboot+uniapp微信小程序题库系统 在线答题 题目分类 错题本管理 学习记录查询系统
spring boot·python·django·uni-app·node.js·php
Rhys..43 分钟前
.gitignore文件的作用及用法
python·github
IT学长编程1 小时前
计算机毕业设计 基于深度学习的酒店评论文本情感分析研究 Python毕业设计项目 Hadoop毕业设计选题 机器学习选题【附源码+文档报告+安装调试】
hadoop·python·深度学习·机器学习·数据分析·毕业设计·酒店评论文本情感分析
~-~%%2 小时前
Moe机制与pytorch实现
人工智能·pytorch·python
深耕AI2 小时前
【PyTorch训练】为什么要有 loss.backward() 和 optimizer.step()?
人工智能·pytorch·python
0_0梅伊阁诗人2 小时前
Django ORM 模型
开发语言·数据库·笔记·python·oracle·django
Genevieve_xiao3 小时前
【dl】python基础 深度学习中需要用到的python基础
python·深度学习
m0_578267863 小时前
从零开始的python学习(九)P142+P143+P144+P145+P146
笔记·python·学习
is08153 小时前
You Only Look Once
python
zqy02273 小时前
HTTP的Web服务测试在Python中的实现
python·网络协议·http