python - tutorial - Seleziona valori NULL in SQLAlchemy




sqlalchemy tutorial (2)

Ecco la mia tabella (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);

Voglio selezionare tutte le persone che non sono conosciute per essere sposate, cioè, comprese quelle con NULL_stato_stato.

Questo non funziona -

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

Certo che questo -

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

Il problema è che sto accedendo da SQLAlchemy con -

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

che viene tradotto in -

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

E non funziona -

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

né lo fa -

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

Come dovrei selezionare i valori NULL tramite SQLAlchemy?

https://code.i-harness.com


(come indicato da @augurar ): Poiché sqlalchemy utilizza metodi magici (overloading dell'operatore) per creare costrutti SQL , può gestire solo operatori come != o == , ma non è in grado di lavorare con is (che è un Python molto valido costruire).

Pertanto, per farlo funzionare con sqlalchemy, è necessario utilizzare:

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

, in pratica sostituisce il valore is None con == None . In questo caso la tua query verrà tradotta correttamente nel seguente 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 != ?

Vedi IS NULL nella documentation .


Poiché SQLAlchemy 0.7.9 è possibile utilizzare il metodo is_ della colonna.

Un'espressione di filtro come:

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

genererà l'SQL parametrizzato:

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







sqlalchemy