Wie erhalte ich die tatsächliche SQL-Abfrage, die in SQLAlchemy ausgeführt wird?

Mary-Kate Olsen
Freigeben: 2024-10-18 13:15:03
Original
954 Leute haben es durchsucht

How to Obtain the Actual SQL Query Executed in SQLAlchemy?

Drucken tatsächlicher SQL-Abfragen in SQLAlchemy

Das Ausführen von SQL-Abfragen in SQLAlchemy erfordert das Binden von Parametern, um SQL-Injection-Angriffe zu verhindern. Allerdings kann es eine Herausforderung sein, die eigentliche SQL-Abfrage einschließlich der Werte zu erhalten.

Allgemeine Lösung

Die einfachste Methode zum Abrufen der SQL-Abfrage als Zeichenfolge ist die Verwendung von die str()-Funktion:

<code class="python">print(str(statement))  # for both ORM Query and SQL statements</code>
Nach dem Login kopieren

Implementierung gebundener Parameter

Standardmäßig bindet SQLAlchemy Parameter aus Sicherheitsgründen. Sie können dieses Verhalten unterdrücken, indem Sie das Flag „literal_binds“ in „compile_kwargs“ verwenden:

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

print(
    statement.compile(compile_kwargs={"literal_binds": True})
)</code>
Nach dem Login kopieren

Beachten Sie, dass die Literalbindung nur für Basistypen wie Ganzzahlen und Zeichenfolgen unterstützt wird.

Parameterkonvertierung anpassen

Wenn Sie komplexere Typen konvertieren müssen, können Sie einen benutzerdefinierten TypeDecorator mit einer Methode „process_literal_param“ erstellen:

<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>
Nach dem Login kopieren

Dies erzeugt eine Abfrage wie:

<code class="sql">SELECT mytable.x
FROM mytable
WHERE mytable.x > my_fancy_formatting(5)</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie erhalte ich die tatsächliche SQL-Abfrage, die in SQLAlchemy ausgeführt wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!