PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Składnia dla row_to_json z sqlalchemy

Twoje zapytanie generuje niepoprawny kod SQL

SELECT row_to_json(SELECT ... FROM foo) AS details
FROM (SELECT ... FROM foo) AS details_foo_row_q

Powinno być

SELECT row_to_json(details_foo_row_q) AS details
FROM (SELECT ... FROM foo) AS details_foo_row_q

Musisz użyć select jako literal_column

from sqlalchemy.sql.expression import literal_column

details_foo_q = select([
    func.row_to_json(literal_column(details_foo_row_q.name)).label('details')
]).select_from(details_foo_row_q).where(
    details_foo_row_q.c.bar_id == Bar.id
).alias('details_foo_q')


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Buforowanie w PostgreSQL

  2. Jak utworzyć indeks na polu JSON w Postgresie?

  3. Oracle do PostgreSQL:składnia złączenia zewnętrznego ANSI w PostgreSQL

  4. Zaznaczanie wszystkich rekordów, jeśli rekord ma którykolwiek z identyfikatorów z tablicy

  5. Powolne zapytanie z lewym sprzężeniem zewnętrznym i warunkiem zerowym