当前位置:首页 > 技术 > 正文内容

Python中SQLAlchemy ORM应用实践

访客 技术 2026年6月8日 1

环境配置

安装SQLAlchemy核心库及数据库驱动:

# 基础安装
pip install sqlalchemy

# 可选数据库驱动
pip install psycopg2-binary  # PostgreSQL
pip install pymysql          # MySQL

核心组件

  • 引擎(Engine):数据库连接枢纽
  • 会话(Session):持久化操作管理器
  • 数据模型(Model):表结构映射类
  • 查询(Query):数据库检索构造器

数据库连接

from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker

# 配置数据库连接
db_engine = create_engine('postgresql://user:pass@localhost:5432/mydb')

# 创建会话工厂
SessionFactory = sessionmaker(bind=db_engine, autoflush=False)

# 实例化会话
db_session = SessionFactory()

模型定义

from sqlalchemy import Column, Integer, String, ForeignKey
from sqlalchemy.orm import relationship, declarative_base

ModelBase = declarative_base()

class Customer(ModelBase):
    __tablename__ = 'customers'
    customer_id = Column(Integer, primary_key=True)
    full_name = Column(String(50))
    contact_email = Column(String(100), unique=True)
    orders = relationship("PurchaseOrder", back_populates="buyer")

class PurchaseOrder(ModelBase):
    __tablename__ = 'orders'
    order_id = Column(Integer, primary_key=True)
    product_name = Column(String(100))
    customer_ref = Column(Integer, ForeignKey('customers.customer_id'))
    buyer = relationship("Customer", back_populates="orders")

# 初始化表结构
ModelBase.metadata.create_all(bind=db_engine)

数据操作

创建记录

new_customer = Customer(full_name="李明", contact_email="liming@example.com")
db_session.add(new_customer)
db_session.commit()

查询记录

# 条件查询
customers = db_session.query(Customer).filter(
    Customer.full_name.like("李%")
).all()

更新记录

customer = db_session.query(Customer).get(101)
customer.contact_email = "new_email@example.com"
db_session.commit()

删除记录

db_session.query(Customer).filter_by(customer_id=102).delete()
db_session.commit()

高级查询

from sqlalchemy import func

# 聚合查询
order_counts = db_session.query(
    Customer.full_name,
    func.count(PurchaseOrder.order_id)
).join(PurchaseOrder).group_by(Customer.customer_id).all()

关系管理

# 添加关联对象
customer = Customer(full_name="张华")
new_order = PurchaseOrder(product_name="笔记本电脑", buyer=customer)
db_session.add(new_order)
db_session.commit()

# 遍历关系
for order in customer.orders:
    print(f"订单: {order.product_name}")

事务控制

try:
    db_session.begin_nested()
    # 执行数据库操作
    db_session.commit()
except Exception:
    db_session.rollback()

优化实践

  • 使用上下文管理器管理会话生命周期
  • 批量操作代替逐条提交
  • 预加载关联数据避免N+1查询
from contextlib import contextmanager

@contextmanager
def session_scope():
    session = SessionFactory()
    try:
        yield session
        session.commit()
    except:
        session.rollback()
        raise
    finally:
        session.close()

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。