Python ORM 处理复杂查询的艺术

王林
发布: 2024-03-18 09:19:02
转载
1266人浏览过

python orm 处理复杂查询的艺术

python 对象关系映射 (ORM) 框架可将关系数据库中的数据无缝映射到 Python 对象,从而简化与数据库的交互。即使是最复杂的查询,也能通过 ORM 轻松有效地执行。

1. 嵌套查询:

嵌套查询允许将一个查询的结果作为另一个查询的输入。在 ORM 中,这可以通过使用嵌套过滤器来实现。例如,可以使用 filter() 方法嵌套一个子查询,以查找与特定条件匹配的记录。

示例:

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

from sqlalchemy import and_, Column
from sqlalchemy.orm import sessionmaker, relationship

# 创建一个 ORM Session
Session = sessionmaker()
session = Session()

# Book 表和 Author 表
class Book(Base):
id = Column(Integer, primary_key=True)
title = Column(String)
author_id = Column(Integer, ForeignKey("authors.id"))

# Author 表
class Author(Base):
id = Column(Integer, primary_key=True)
name = Column(String)

# 使用嵌套查询查找所有作者姓名为 "John" 的书籍标题
query = session.query(Book.title).filter(Book.author_id.in_(
session.query(Author.id).filter(Author.name == "John")
))
登录后复制

2. 联接查询:

联接查询将多个表中的记录组合在一起。在 ORM 中,这可以通过使用 join() 方法来实现。例如,可以通过使用 join() 方法连接两个表,以查找具有特定作者的书籍。

示例:

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

from sqlalchemy import and_, Column
from sqlalchemy.orm import sessionmaker, relationship

# 创建一个 ORM Session
Session = sessionmaker()
session = Session()

# Book 表和 Author 表
class Book(Base):
id = Column(Integer, primary_key=True)
title = Column(String)
author_id = Column(Integer, ForeignKey("authors.id"))

# Author 表
class Author(Base):
id = Column(Integer, primary_key=True)
name = Column(String)

# 使用联接查询查找所有作者姓名为 "John" 的书籍标题
query = session.query(Book.title).join(Book.author).filter(Author.name == "John")
登录后复制

3. 聚合函数

聚合函数可将多个值组合成单个值,例如求和、求平均值或查找最大值。在 ORM 中,这可以通过使用诸如 sum()、avg() 和 max() 等聚合函数来实现。例如,可以使用 sum() 函数来计算特定作者的书籍总数。

示例:

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

from sqlalchemy import and_, Column
from sqlalchemy.orm import sessionmaker, relationship

# 创建一个 ORM Session
Session = sessionmaker()
session = Session()

# Book 表和 Author 表
class Book(Base):
id = Column(Integer, primary_key=True)
title = Column(String)
author_id = Column(Integer, ForeignKey("authors.id"))

# Author 表
class Author(Base):
id = Column(Integer, primary_key=True)
name = Column(String)

# 使用聚合函数计算特定作者的书籍总数
query = session.query(Author.name).group_by(Author).having(func.count(Book.id) > 1)
登录后复制

4. 动态查询:

动态查询允许在运行时构建查询。在 ORM 中,这可以通过使用 dynamic() 函数来实现。例如,可以使用 dynamic() 函数来构建一个包含特定过滤条件的查询。

示例:

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

from sqlalchemy import and_, Column, literal
from sqlalchemy.orm import sessionmaker, relationship

# 创建一个 ORM Session
Session = sessionmaker()
session = Session()

# Book 表和 Author 表
class Book(Base):
id = Column(Integer, primary_key=True)
title = Column(String)
author_id = Column(Integer, ForeignKey("authors.id"))

# Author 表
class Author(Base):
id = Column(Integer, primary_key=True)
name = Column(String)

# 使用动态查询构建一个包含特定过滤条件的查询
query = session.query(Book).filter(literal(True).in_(
session.query(1).filter(Book.title == "Book Title")
))
登录后复制

通过有效利用 ORM 的这些特性,开发人员可以构建复杂的高效查询,而无需直接编写 SQL 语句。这简化了数据库交互,提高了可读性和可维护性。

以上就是Python ORM 处理复杂查询的艺术的详细内容,更多请关注php中文网其它相关文章!

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:编程网网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号