Heim >Datenbank >MySQL-Tutorial >Warum markiert „flake8' boolesche Vergleiche in SQLAlchemy-Filterklauseln?
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>< ;/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!