Maison  >  Article  >  développement back-end  >  Comment exécuter du SQL brut dans Flask-SQLAlchemy et éviter les erreurs de passerelle ?

Comment exécuter du SQL brut dans Flask-SQLAlchemy et éviter les erreurs de passerelle ?

Linda Hamilton
Linda Hamiltonoriginal
2024-10-27 11:51:01621parcourir

How to Execute Raw SQL in Flask-SQLAlchemy and Avoid Gateway Errors?

Exécution de SQL brut dans Flask-SQLAlchemy : résolution des erreurs de passerelle

Lorsque vous utilisez SQLAlchemy pour interagir avec votre base de données dans une application Web Flask, il des situations peuvent survenir dans lesquelles l'exécution de SQL brut devient nécessaire. Surtout lorsqu'il s'agit de requêtes complexes impliquant des jointures de tables et des vues en ligne.

Pour exécuter du SQL brut dans SQLAlchemy, vous pouvez utiliser les méthodes suivantes :

SQLAlchemy 2.0 :

<code class="python">with engine.connect() as connection:
    result = connection.execute(text('SELECT * FROM your_table'))</code>

SQLAlchemy 1.x :

<code class="python">from sqlalchemy import text

sql = text('select name from penguins')
result = db.engine.execute(sql)</code>

Cependant, il convient de noter que db.engine.execute() dans SQLAlchemy 1.x est classé comme " sans connexion", une fonctionnalité qui a été marquée comme obsolète dans SQLAlchemy 2.0. Par conséquent, l'approche recommandée consiste à utiliser le gestionnaire de contexte with engine.connect(), qui garantit un nettoyage approprié des ressources une fois l'opération terminée.

En implémentant ces techniques, vous pouvez exécuter avec succès des instructions SQL brutes dans votre Flask. -Application SQLAlchemy, traitant efficacement les erreurs de passerelle et vous permettant de gérer des opérations de base de données complexes de manière transparente.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn