【发布时间】:2011-08-01 22:54:50
【问题描述】:
这是我的 (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);
我想选择所有不已知已婚的人,即包括婚姻状态为 NULL 的人。
这不工作--
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'}
而且不有效--
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 值?
【问题讨论】:
标签: python sql database sqlalchemy