これが私の(PostgreSQL)テーブルです-
test=> create table people (name varchar primary key,
marriage_status varchar) ;
test=> insert into people values ('Ken', 'married');
test=> insert into people values ('May', 'single');
test=> insert into people values ('Joe', NULL);
not結婚していることがわかっているすべての人を選択したい。
これはnot work-
test=> select * from people where marriage_status != 'married' ;
name | marriage_status
------+-----------------
May | single
(1 row)
もちろんこれはそうです-
test=> select * from people where marriage_status != 'married'
or marriage_status is NULL ;
name | marriage_status
------+-----------------
May | single
Joe |
問題は、SQLAlchemyからアクセスしていることです-
...filter(or_(people.marriage_status!='married',
people.marriage_status is None))
翻訳されます-
SELECT people.name as name,
people.marriage_status as marriage_status
FROM people
WHERE people.marriage_status != %(status_1)s OR False
sqlalchemy.engine.base.Engine.... {'status_1': 'married'}
そしてnot work-
test=> select * from people where marriage_status != 'married'
or False;
name | marriage_status
------+-----------------
May | single
(1 row)
どちらも-
test=> select * from people where marriage_status != 'married'
or NULL;
name | marriage_status
------+-----------------
May | single
(1 row)
SQLAlchemyでNULL値を選択するにはどうすればよいですか?
( @ augurar で示されるように):sqlalchemyはマジックメソッド(演算子のオーバーロード)SQL
コンストラクトを作成するには、!=
や==
などの演算子のみを処理できますが、is
(これは非常に有効なPythonコンストラクト)です。
したがって、sqlalchemyで動作させるには、次を使用する必要があります。
...filter(or_(people.marriage_status!='married', people.marriage_status == None))
、基本的にis None
を== None
に置き換えます。この場合、クエリは次のSQLに適切に変換されます。
SELECT people.name AS people_name, people.marriage_status AS people_marriage_status
FROM people
WHERE people.marriage_status IS NULL OR people.marriage_status != ?
ドキュメント のIS NULL
を参照してください。
SQLAlchemy 0.7.9以降では、列の_is_
_メソッドを使用できます。
次のようなフィルター式
filter(or_(people.marriage_status!='married', people.marriage_status.is_(None)))
パラメーター化されたSQLを生成します。
WHERE people.marriage_status != %(status_1)s OR people.marriage_status IS NULL
私は同様の問題に遭遇しました
https://groups.google.com/forum/?fromgroups#!topic/sqlalchemy/EVpxsNp5Ifg%5B1-25%5D
短い答え:-IS(NOT)NULLの列演算子は現在ありませんが、
それまでの間、次のいずれかを使用できます。
filter(tablename.is_deleted.op( "IS NOT")(True))
filter(coalesce(tablename.is_deleted、False)!= True)