- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试解决在使用 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/
我是 Vaadin 的新手,但有一些 Java Swing 经验。 我正在尝试使用 table.setCellStyleGenerator 设置列标题为“名称”的特定单元格的颜色。 我正在研究 vaa
我是一名优秀的程序员,十分优秀!