Aquí está mi (PostgreSQL) tabla -Seleccionar valores nulos en SQLAlchemy
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);
Quiero seleccionar todas las personas que son no conocido para casarse, es decir, incluyendo los que tienen marriage_status NULL.
Esto hace no trabajo -
test=> select * from people where marriage_status != 'married' ;
name | marriage_status
------+-----------------
May | single
(1 row)
Por supuesto, esto hace -
test=> select * from people where marriage_status != 'married'
or marriage_status is NULL ;
name | marriage_status
------+-----------------
May | single
Joe |
El problema es que estoy acceder a él desde SQLAlchemy con -
...filter(or_(people.marriage_status!='married',
people.marriage_status is None))
que se traduce a -
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'}
Y lo hace no trabajo -
test=> select * from people where marriage_status != 'married'
or False;
name | marriage_status
------+-----------------
May | single
(1 row)
Tampoco -
test=> select * from people where marriage_status != 'married'
or NULL;
name | marriage_status
------+-----------------
May | single
(1 row)
¿Cómo debería seleccionar los valores NULL a través SQLAlchemy?
pylint no le gusta la comparación con == Ninguno –
Si desea moverse pylint no Si le gusta comparar Ninguno con ==, puede usar Table.column_name.is_ (None). También Table.column_name.isnot (None) reemplaza a Table.column_name! = None. –