flake8 Flagging Boolean Comparison in Filter Clause
When attempting to filter query results based on a boolean comparison in SQL, developers may encounter warnings from flake8 regarding the use of "==". While it's generally recommended to use "if cond is False:" or "if not cond:" for boolean comparisons elsewhere, this doesn't apply to filter clauses in SQLAlchemy.
In the example provided, a boolean field (obsoleted) in a database table is used to determine the count of non-obsoleted test cases. The code uses TestCase.obsoleted == False in the filter clause.
<pre>caseNum = session.query(TestCase).filter(TestCase.obsoleted == False).count()
</pre>
However, flake8 reports the warning "E712: Comparison to False should be 'if cond is False:' or 'if not cond:'."
To address this warning, developers may be tempted to change the code to use "is False" or "is not" operators:
<pre>caseNum = session.query(TestCase).filter(TestCase.obsoleted is False).count()
</pre>
or
<pre>caseNum = session.query(TestCase).filter(not TestCase.obsoleted).count()
</pre>
Unfortunately, these modifications result in incorrect results, returning 0 instead of the expected count. This is because filter clauses in SQLAlchemy do not support "is" or "is not" operators.
To resolve this issue without disabling flake8, developers can use a # noqa comment on the offending line:
<pre>caseNum = session.query(TestCase).filter(TestCase.obsoleted == False) # noqa: E712
</pre>
Alternatively, the sqlalchemy.sql.expression.false function can be used:
<pre>from sqlalchemy.sql.expression import false
caseNum = session.query(TestCase).filter(TestCase.obsoleted == false())
</pre>
where false() returns the appropriate value for the SQL dialect in use.
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3