it-swarm.com.de

Wählen Sie in SQLAlchemy NULL-Werte aus

Hier ist meine (PostgreSQL) Tabelle -

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

Ich möchte alle Personen auswählen, von denen nicht bekannt ist, dass sie verheiratet sind, d. H. Auch diejenigen mit NULL Marriage_status.

Das macht nicht Arbeit -

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

Natürlich tut dies -

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

Das Problem ist, dass ich über SQLAlchemy darauf zugreife mit -

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

was übersetzt wird -

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

Und funktioniert nicht Arbeit -

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

auch nicht --

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

Wie soll ich NULL-Werte über SQLAlchemy auswählen?

35
Jerry

(wie angegeben durch @ augurar ): Weil sqlalchemy magische Methoden verwendet (Operatorüberladung) ) zum Erstellen von SQL -Konstrukten kann es nur Operatoren wie != oder == verarbeiten, kann jedoch nicht mit is arbeiten (Das ist ein sehr gültiges Python Konstrukt).

Daher sollten Sie Folgendes verwenden, damit es mit sqlalchemy funktioniert:

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

Ersetzen Sie im Grunde genommen den is None durch == None. In diesem Fall wird Ihre Abfrage ordnungsgemäß in die folgende SQL übersetzt:

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 != ?

Siehe IS NULL in Dokumentation .

94
van

Seit SQLAlchemy 0.7.9 können Sie die Methode is_ Der Spalte verwenden.

Ein Filterausdruck wie:

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

generiert das parametrisierte SQL:

WHERE people.marriage_status != %(status_1)s OR people.marriage_status IS NULL

30
jsnow

ich bin auf ein ähnliches Problem gestoßen

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

kurze Antwort: - Es gibt jetzt keinen Spaltenoperator für IS (NOT) NULL, aber es wird einen geben

in der Zwischenzeit können Sie entweder verwenden:

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

filter (coalesce (tabellenname.is_deleted, False)! = True) 

0