极简SQLAlchemy

本文详细介绍了SQLAlchemy的各个组成部分,包括核心架构(Engine,Connection,Session,Metadata等)、ORM架构(DeclarativeBase,Model,Attributes等)以及SQL表达式语言(SELECT,INSERT,UPDATE,DELETE等),并通过代码示例展示了其在数据库操作中的应用。
摘要由CSDN通过智能技术生成

SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)框架,它为开发者提供了一种高效和灵活的方式来与数据库进行交互。SQLAlchemy 的架构可以分为几个主要部分:核心架构(Core)、ORM 架构和 SQL 表达式语言。

核心架构(Core)

SQLAlchemy Core 提供了数据库和 SQL 表达式的底层接口。它包括以下几个关键组件:

  1. 引擎(Engine):负责与数据库的通信,管理连接池和事务。
  2. 连接(Connection):代表与数据库的单个连接会话。
  3. 会话(Session):在 ORM 中使用,代表与数据库的持久化会话。
  4. 元数据(Metadata):用于定义和存储关于数据库结构的信息,如表和列的定义。
  5. 表(Table):表示数据库中的一个表。
  6. 列(Column):表示表中的一个列。
  7. 类型(Types):用于定义列的数据类型。
  8. 表达式构造器(Expression Language):用于构建 SQL 表达式,如 select(), insert(), update(), delete() 等。

ORM 架构

SQLAlchemy ORM 提供了对象关系映射的功能,它允许开发者使用 Python 类来表示数据库表,并使用对象来操作数据库记录。ORM 架构包括以下几个关键组件:

  1. 声明基类(Declarative Base):用于定义 ORM 模型。
  2. 模型(Model):表示数据库中的一个表,由 Python 类定义。
  3. 属性(Attributes):表示模型的属性,与数据库表的列相对应。
  4. 关系(Relationships):表示模型之间的关系,如一对多、多对多等。
  5. 会话(Session):用于管理对象的持久化,包括添加、修改、删除和查询对象。

SQL 表达式语言

SQLAlchemy SQL 表达式语言是一种强大的、Python 风格的方式来构建 SQL 查询。它允许用户以非常灵活和直观的方式构造 SQL 语句,而无需直接编写 SQL 字符串。表达式语言包括以下几个关键组件:

  1. 选择(SELECT):使用 select() 构造器来构建查询语句。
  2. 插入(INSERT):使用 insert() 构造器来构建插入语句。
  3. 更新(UPDATE):使用 update() 构造器来构建更新语句。
  4. 删除(DELETE):使用 delete() 构造器来构建删除语句。
  5. 连接(JOIN):使用 join()outerjoin() 构造器来构建连接语句。
  6. 子查询:使用 select() 构造器来构建子查询。

Code案例

下面是一个简单的例子,展示了如何使用 SQLAlchemy ORM 架构和 SQL 表达式语言来操作数据库。

from sqlalchemy import create_engine, Column, Integer, String, ForeignKey
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship, sessionmaker
# 定义声明基类
Base = declarative_base()
# 定义 User 模型
class User(Base):
    __tablename__ = 'users'
    
    id = Column(Integer, primary_key=True)
    name = Column(String)
# 定义 Address 模型
class Address(Base):
    __tablename__ = 'addresses'
    
    id = Column(Integer, primary_key=True)
    email = Column(String)
    user_id = Column(Integer, ForeignKey('users.id'))
    user = relationship(User, back_populates='addresses')
User.addresses = relationship(Address, order_by=Address.id, back_populates='user')
# 创建数据库引擎
engine = create_engine('sqlite:///example.db')
# 创建所有表
Base.metadata.create_all(engine)
# 创建会话
Session = sessionmaker(bind=engine)
session = Session()
# 添加和提交用户
new_user = User(name='Alice')
session.add(new_user)
session.commit()
# 查询用户
user = session.query(User).filter_by(name='Alice').first()
print(user.name)
# 关闭会话
session.close()

在这个例子中,我们首先定义了两个 ORM 模型 UserAddress,并创建了对应的数据库表。然后,我们使用会话(Session)来添加和查询用户。最后,我们关闭了会话。
希望这个解释能帮助你更好地理解 SQLAlchemy 的架构、组件和用法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

吉小雨

你的激励是我创作最大的动力

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

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

打赏作者

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

抵扣说明:

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

余额充值