sql >> Database teknologi >  >> RDS >> PostgreSQL

Sådan samles to underforespørgsler i SQLAlchemy og postgresql

jeg brugte en lidt anden tilgang:

# the first subquery, select all ids from SOME_TABLE where some_field is not NULL
s1 = select([SOME_TABLE.c.id]).where(SOME_TABLE.c.some_field != None)

# the second subquery, select all ids from SOME_TABLE where some_field is NULL
s2 = select([SOME_TABLE.c.id]).where(SOME_TABLE.c.some_field != None)

# union s1 and s2 subqueries together and alias the result as "alias_name"
q = s1.union(s2).alias('alias_name')

# run the query and limit the aliased result to 10
session.query(q).limit(10)

Her er den producerede sql:

SELECT alias_name.id AS alias_name_id 
FROM (SELECT some_table.id AS id 
FROM some_table 
WHERE some_table.some_field IS NOT NULL UNION SELECT some_table.id AS id 
FROM some_table 
WHERE some_table.some_field IS NULL) AS alias_name 
LIMIT 10

Jeg tror, ​​det er det resultat, du ønskede.




  1. mysql workbench records limit

  2. SQL Server-forespørgselsmeddelelser i JAVA

  3. Sådan konverteres en streng til en dato/tid i SQL Server ved hjælp af CAST()

  4. MySQL-serveren er gået væk - på præcis 60 sekunder