web-dev-qa-db-ja.com

SQLAlchemyでNULL値を選択する

これが私の(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値を選択するにはどうすればよいですか?

42
Jerry

@ 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を参照してください。

94
van

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

30
jsnow

私は同様の問題に遭遇しました

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)

0