sql - 执行子查询时表别名重新标记

标签 sql django postgresql django-queryset

我正在尝试解决在使用 django 扩展 djorm-ext-pgfulltext 时执行 sql 子查询时生成的错误。

产生的错误是

invalid reference to FROM-clause entry for table "bookmarks_bookmark" LINE 1: ...ECT U0."id" FROM "bookmarks_bookmark" U0 WHERE ( ("bookmarks... ^ HINT: Perhaps you meant to reference the table alias "u0".

产生错误的django queryset过滤器是

shared_bookmarks = SharedBookmark.objects.filter(bookmark__in=Bookmark.objects.search(query))

query='html'时生成的sql是:

SELECT "bookmarks_sharedbookmark"."id", "bookmarks_sharedbookmark"."created", "bookmarks_sharedbookmark"."modified", "bookmarks_sharedbookmark"."bookmark_id", "bookmarks_sharedbookmark"."hot_score" FROM "bookmarks_sharedbookmark" WHERE "bookmarks_sharedbookmark"."bookmark_id" IN (SELECT U0."id" FROM U0 WHERE ( (U0."search_index") @@ (plainto_tsquery('pg_catalog.english', 'html'))))

根据我的研究,问题可能来自于在 djorm-ext-pgfulltext 中使用 extra() 函数,特别是以下行:

qs = qs.extra(select=select_dict, where=[where], order_by=order)

我已经能够通过强制使用列表评估子查询来解决问题。

SharedBookmark.objects.filter(bookmark__in=list(Bookmark.objects.search(query))) 

但是与加载每个元素相关的内存开销在某些时候会令人望而却步。

我想解决不需要太多内存开销的错误。我已经阅读了与使用 extra() 相关的问题的 django 文档及其建议“查看生成的查询并重写你的 where addition 以使用给你的额外表的别名”但我不确定在哪里可以找到正确的别名以及如何着手编写通常(对于任何搜索词)处理问题的正确 sql。

最佳答案

关于你的错误

您的查询中没有 SELECT U0."id"FROM "bookmarks_bookmark"。 一定有某种误解。

关于提出的查询

EXISTS 的另一种情况半连接。

SELECT b.id, b.created, b.modified, b.bookmark_id, b.hot_score
FROM   bookmarks_sharedbookmark b
WHERE  EXISTS (
    SELECT 1
    FROM   u0
    WHERE  u0.id = b.bookmark_id
    AND    u0.search_index @@ plainto_tsquery('pg_catalog.english', 'html')
   )

如果 u0 中有多个匹配 bookmarks_sharedbookmark 中的单行,则执行速度应该会快得多,因为 EXISTS 子查询可以完成扫描一旦找到第一个匹配项。

关于sql - 执行子查询时表别名重新标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18000970/

相关文章:

python - Django 双因素身份验证,在特定 View 上需要 2FA

django - 删除django中的多个对象

python - 测试 PostgreSQL 表是否不存在(使用 psycopg2)

mysql - 按季度对日期范围内的记录进行计数

mysql - 如何使用 join 但只获取第一个表的行?

mysql - 合并并显示查询结果

postgresql - BIRT 报告 postgreSQL DB 上的异常

mysql - 关联多导致查询慢

python - 带有 python 3.4 的 Elastic Beanstalk 仍然使用 python 2.7

ruby-on-rails - Rails 3.1 + postgresql 数据库 - SELECT ... WHERE ... IN 的 sql 语法错误