gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 13:33:46 28 4
gpt4 key购买 nike

我正在尝试解决在使用 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/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com