如何在 SQLAlchemy 调试期间打印带有值的实际 SQL 查询?

Mary-Kate Olsen
发布: 2024-10-18 13:29:03
原创
272 人浏览过

How to Print Actual SQL Queries with Values During Debugging in SQLAlchemy?

调试 SQLAlchemy 查询:使用值打印实际 SQL

调试 SQLAlchemy 表达式时,查看正在执行的实际 SQL 查询非常有价值,包括特定值而不是绑定参数。虽然 SQLAlchemy 没有为此提供显式方法,但有几种方法可以实现它。

一般方法

在大多数情况下,您可以简单地在 SQLAlchemy 语句上调用 str()或查询:

print(str(statement))
登录后复制

这适用于 ORM 查询(查询对象)和纯 SQL 语句(select() 等)。

特定于引擎的编译

如果您需要针对特定​​数据库引擎编译的语句,可以使用compile()方法:

print(statement.compile(some_engine))
登录后复制

或者,如果您没有引擎,您可以指定方言:

from sqlalchemy.dialects import postgresql
print(statement.compile(dialect=postgresql.dialect()))
登录后复制

内联绑定参数

在某些情况下,您可能希望将绑定参数内联到最终的 SQL 字符串中。这可以使用literal_binds标志来实现:

print(statement.compile(compile_kwargs={"literal_binds": True}))
登录后复制

请注意,这仅支持整数和字符串等基本类型。对于更复杂的类型,您可能需要创建自定义类型装饰器。

自定义类型装饰器

要支持不支持类型的内联渲染,您可以使用 process_literal_param 方法创建自定义类型装饰器:

class MyFancyType(TypeDecorator):
    ...
    def process_literal_param(self, value, dialect):
        return f"my_fancy_formatting({value})"
登录后复制

使用此装饰器,您可以内联复杂值:

print(tab.select().where(tab.c.x > 5).compile(compile_kwargs={"literal_binds": True}))
登录后复制

产生如下输出:

SELECT mytable.x
FROM mytable
WHERE mytable.x > my_fancy_formatting(5)
登录后复制

以上是如何在 SQLAlchemy 调试期间打印带有值的实际 SQL 查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!