PHP前端开发

巧用 Python SQLAlchemy,轻松征服关系数据库世界

百变鹏仔 2天前 #Python
文章标签 巧用

python sqlAlchemy 是一个功能强大的对象关系映射工具库,它允许开发人员使用 Python 对象来操作关系数据库。这使得开发人员可以轻松地创建、查询和更新数据库中的数据,而无需编写复杂的 SQL 代码。

安装 SQLAlchemy

要使用 SQLAlchemy,首先需要安装它。可以使用 pip 命令来安装:

from sqlalchemy import Column, Integer, Stringclass User(Base):__tablename__ = "users"id = Column(Integer, primary_key=True)name = Column(String(50), unique=True)email = Column(String(120), unique=True)

在这个类中,__tablename__ 属性指定了数据库中表的名称。id、name 和 email 属性分别是数据库中的列。id 是主键,并且是自动递增的。name 和 email 是字符串类型的列,并且是唯一的。

创建数据库引擎

要将 ORM 模型映射到数据库,需要创建一个数据库引擎。数据库引擎是一个对象,它负责与数据库进行交互。

立即学习“Python免费学习笔记(深入)”;

例如,要创建一个连接到 SQLite 数据库的数据库引擎,可以编写以下代码:

from sqlalchemy import create_engineengine = create_engine("sqlite:///database.sqlite")

在这个代码中,"sqlite:///database.sqlite" 是数据库的连接字符串。

创建会话

要操作数据库中的数据,需要创建一个会话。会话是一个对象,它代表了数据库的一次交互。

例如,要创建一个会话,可以编写以下代码:

from sqlalchemy.orm import sessionmakerSession = sessionmaker(bind=engine)session = Session()

在这个代码中,Session 是一个会话类,它与 engine 绑定。session 是一个会话对象,它可以使用 add()、delete() 和 commit() 等方法来操作数据库中的数据。

添加数据

要向数据库中添加数据,可以使用 add() 方法。例如,要向 users 表中添加一条数据,可以编写以下代码:

user = User(name="John Doe", email="johndoe@example.com")session.add(user)

在这个代码中,user 是一个 User 对象,它包含了要添加的数据。session.add(user) 将 user 对象添加到会话中。

提交数据

要将数据提交到数据库,可以使用 commit() 方法。例如,要提交数据,可以编写以下代码:

session.commit()

在这个代码中,session.commit() 将会话中的数据提交到数据库。

查询数据

要查询数据库中的数据,可以使用 query() 方法。例如,要查询所有 User 对象,可以编写以下代码:

users = session.query(User).all()

在这个代码中,session.query(User).all() 查询所有 User 对象,并将它们存储在 users 变量中。

更新数据

要更新数据库中的数据,可以使用 update() 方法。例如,要更新 John Doe 的电子邮件地址,可以编写以下代码:

session.query(User).filter_by(name="John Doe").update({User.email: "johndoe@example.com"})

在这个代码中,session.query(User).filter_by(name="John Doe") 查询名为 John Doe 的用户,并将电子邮件地址更新为 johndoe@example.com。

删除数据

要删除数据库中的数据,可以使用 delete() 方法。例如,要删除名为 John Doe 的用户,可以编写以下代码:

session.query(User).filter_by(name="John Doe").delete()

在这个代码中,session.query(User).filter_by(name="John Doe") 查询名为 John Doe 的用户,并将它们删除。

总结

SQLAlchemy 是一个功能强大的 ORM 工具库,它可以帮助开发人员轻松地操作关系数据库。使用 SQLAlchemy,开发人员可以快速地创建、查询和更新数据库中的数据,而无需编写复杂的 SQL 代码。