Выберите значения NULL в SQLAlchemy - PullRequest
40 голосов
/ 09 апреля 2011

Вот моя таблица (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 wedding_status.*

Это работает не работает -

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)

Как выбрать значения NULL с помощью SQLAlchemy?

Ответы [ 3 ]

88 голосов
/ 12 апреля 2011

(как указано @ 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 в документации .

29 голосов
/ 21 июня 2017

Начиная с 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

0 голосов
/ 18 августа 2012

я столкнулся с подобной проблемой

https://groups.google.com/forum/?fromgroups#!topic/sqlalchemy/EVpxsNp5Ifg%5B1-25%5D

краткий ответ: - в настоящее время нет оператора столбца для IS (NOT) NULL, но будет

тем временем вы можете использовать либо:

filter (tablename.is_deleted.op ("IS NOT") (True))

фильтр (coalesce (tablename.is_deleted, False)! = True)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...