sql >> Databáze >  >> RDS >> PostgreSQL

Převeďte django RawQuerySet na Queryset

Můžete použít výraz RawSQL:

ModelB.objects.filter(id__in=RawSQL(
    'SELECT unnest(a.pk_values) FROM app_modela a WHERE a.id = %s',
    [index_id]
))

Případně můžete reprodukovat přesný dotaz, který máte ve své otázce, pomocí extra():

ModelB.objects.extra(
    tables=['foo_modela'],
    where=[
        '"app_modelb"."id" = ANY("app_modela"."pk_values")',
        '"app_modela"."id" = %s',
    ],
    params=[index_id],
)


  1. UNPIVOT na neurčitém počtu sloupců

  2. Jak vytvořit rolovatelný a aktualizovatelný objekt ResultSet v JDBC

  3. Jak zpětně vytvořit databázi v MySQL Workbench

  4. SQL Server Náhodné řazení