Heim >Datenbank >MySQL-Tutorial >Warum markiert „flake8' boolesche Vergleiche in SQLAlchemy-Filterklauseln?

Warum markiert „flake8' boolesche Vergleiche in SQLAlchemy-Filterklauseln?

Barbara Streisand
Barbara StreisandOriginal
2024-10-27 00:55:03242Durchsuche

Why is `flake8` Flagging Boolean Comparisons in SQLAlchemy Filter Clauses?

flake8 meldet booleschen Vergleich in der Filterklausel

Beim Versuch, Abfrageergebnisse basierend auf einem booleschen Vergleich in SQL zu filtern, stoßen Entwickler möglicherweise auf Warnungen von flake8 bezüglich der Verwendung von „==“. Während allgemein empfohlen wird, „if cond is False:“ oder „if not cond:“ für boolesche Vergleiche an anderer Stelle zu verwenden, gilt dies nicht für Filterklauseln in SQLAlchemy.

Im bereitgestellten Beispiel ein boolesches Feld (veraltet) in einer Datenbanktabelle wird verwendet, um die Anzahl der nicht veralteten Testfälle zu bestimmen. Der Code verwendet TestCase.obsoleted == False in der Filterklausel.

caseNum = session.query(TestCase).filter(TestCase.obsoleted == False).count()<br>&lt ;/pre></p>
<p>Flake8 meldet jedoch die Warnung „E712: Vergleich mit False sollte ‚wenn cond falsch ist:‘ oder ‚wenn nicht cond:‘ sein.“</p>
<p>Um diese Warnung zu beheben , könnten Entwickler versucht sein, den Code so zu ändern, dass er die Operatoren „is False“ oder „is not“ verwendet:</p>
<p><pre class="brush:php;toolbar:false">caseNum = session.query(TestCase).filter(TestCase.obsoleted is False). count()<br>

oder

caseNum = session.query(TestCase).filter(not TestCase.obsoleted).count()<br>

Leider führen diese Änderungen zu falschen Ergebnissen und geben 0 anstelle der erwarteten Anzahl zurück. Dies liegt daran, dass Filterklauseln in SQLAlchemy keine „is“- oder „is not“-Operatoren unterstützen.

Um dieses Problem zu beheben, ohne flake8 zu deaktivieren, können Entwickler einen # noqa-Kommentar in der betreffenden Zeile verwenden:

caseNum = session.query(TestCase).filter(TestCase.obsoleted == False) # noqa: E712<br>

Alternativ die sqlalchemy.sql.expression Die Funktion .false kann verwendet werden:

from sqlalchemy.sql.expression import false</p>
<p>caseNum = session.query(TestCase).filter(TestCase.obsoleted == false() )<br>

wobei false() den entsprechenden Wert für den verwendeten SQL-Dialekt zurückgibt.

Das obige ist der detaillierte Inhalt vonWarum markiert „flake8' boolesche Vergleiche in SQLAlchemy-Filterklauseln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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