Sélectionnez les Valeurs NULL dans SQLAlchemy

Voici mon (PostgreSQL) table --

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);

Je veux sélectionner toutes les personnes qui sont pas connu pour être marié, c'est à dire, y compris ceux avec NULL marriage_status.

Cela ne pas travail --

test=> select * from people where marriage_status != 'married' ; 
 name | marriage_status 
------+-----------------
 May  | single
(1 row)

Bien sûr, cela ne --

test=> select * from people where marriage_status != 'married'
       or marriage_status is NULL ; 
 name | marriage_status 
------+-----------------
 May  | single
 Joe  | 

Le problème c'est que je suis accéder à partir de SQLAlchemy avec --

...filter(or_(people.marriage_status!='married',
              people.marriage_status is None))

qui se traduit à --

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'}

Et ne pas travail --

test=> select * from people where marriage_status != 'married'
       or False; 
 name | marriage_status 
------+-----------------
 May  | single
(1 row)

n' --

test=> select * from people where marriage_status != 'married'
       or NULL; 
 name | marriage_status 
------+-----------------
 May  | single
(1 row)

Comment choisir les valeurs NULL par le biais de SQLAlchemy?

InformationsquelleAutor Jerry | 2011-04-09