如何获取SQLAlchemy中实际执行的SQL查询?

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

How to Obtain the Actual SQL Query Executed in SQLAlchemy?

在 SQLAlchemy 中打印实际的 SQL 查询

在 SQLAlchemy 中执行 SQL 查询涉及绑定参数以防止 SQL 注入攻击。然而,获取实际的 SQL 查询(包括值)可能具有挑战性。

一般解决方案

以字符串形式检索 SQL 查询的最简单方法是使用str() 函数:

<code class="python">print(str(statement))  # for both ORM Query and SQL statements</code>
登录后复制

绑定参数实现

默认情况下,出于安全原因,SQLAlchemy 会绑定参数。您可以使用compile_kwargs中的literal_binds标志来抑制此行为:

<code class="python">from sqlalchemy.dialects import postgresql

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

请注意,文字绑定仅支持整数和字符串等基本类型。

自定义参数转换

如果您需要转换更复杂的类型,您可以使用 process_literal_param 方法创建自定义 TypeDecorator:

<code class="python">class MyFancyType(TypeDecorator):
    impl = Integer

    def process_literal_param(self, value, dialect):
        return "my_fancy_formatting(%s)" % value

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

这将生成如下查询:

<code class="sql">SELECT mytable.x
FROM mytable
WHERE mytable.x > my_fancy_formatting(5)</code>
登录后复制

以上是如何获取SQLAlchemy中实际执行的SQL查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板