- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 PostgreSQL 中的 ltree
扩展来构建全文地址搜索引擎。
我的模型看起来像这样(略有简化):
from django.db import models
class Addresses(models.Model):
name = models.CharField(max_length=255)
path = models.CharField(max_length=255)
因此,此表中的数据将如下所示:
id | name | path
----------------------------
1 | USA | 1
2 | California | 1.2
3 | Los Angeles | 1.2.3
我想对每个实体的聚合名称进行全文搜索。基本上我需要将表中的每一行转换为下一种格式来进行搜索:
id | full_name | path
-------------------------------------------------
1 | USA | 1
2 | California USA | 1.2
3 | Los Angeles California USA | 1.2.3
我这样做是为了让用户可以执行类似“los ang cali”或类似的查询。使用 raw PostgreSQL 查询我没有问题:
SELECT *, ts_rank_cd(to_tsvector('english', full_address), query) AS rank
FROM (SELECT s.id, s.path, array_to_string(array_agg(a.name ORDER BY a.path DESC), ' ') AS full_address
FROM "Addresses" AS s INNER JOIN "Addresses" AS a
ON (a.path @> s.path) GROUP BY s.id, s.path, s.name
) AS subquery, to_tsquery('english', %s) as query WHERE to_tsvector('english', full_address) @@ query
ORDER BY rank DESC;
这很好用,但是在使用 RawQuerySet 时,我不能使用像 .filter()
、.group_by()
这样的东西,分页等
在 Django 中复制它的主要约束是这个JOIN:
JOIN "Addresses" AS a ON (a.path @> s.path)
它用于连接每个元素的所有祖先,然后使用array_agg()
、array_to_string
函数聚合它们,所以这些函数的输出可以在< strong>全文搜索。
如果有人对如何使用 Django ORM 实现此类事情有更好的想法,请提出建议。
最佳答案
您需要一个由 VIEW 支持的非托管模型。
创建非托管模型是通过设置 managed 来实现的模型的元选项为 false。
If False, no database table creation or deletion operations will be performed for this model. This is useful if the model represents an existing table or a database view that has been created by some other means. This is the only difference when managed=False. All other aspects of model handling are exactly the same as normal. This includes
强调我的。
因此,如果您创建一个非托管模型,它可以由数据库上的 View 表示,并且您可以访问其上的 .filter()
、.group_by()
.
View 就是您的查询。
CREATE OR REPLACE view full_address_tree AS
SELECT a.*, s.id, s.path, array_to_string(array_agg(a.name ORDER BY a.path DESC), ' ') AS full_address
FROM "Addresses" AS s INNER JOIN "Addresses" AS a
ON (a.path @> s.path) GROUP BY s.id, s.path, s.name
class FullAddressTree(models.Model):
# copy paste the fields from your Addresses model here
sid = models.IntegerField()
sid = models.CharField()
class Meta:
# this is the most important part
managed = False
db_table = 'full_address_tree' # the name of the view
因此,现在您拥有了一个可用于进行全文搜索而无需求助于原始查询的模型。因此,您可以随意使用 Django ORM 的全部功能。
如果您想要迁移,您会发现 ./manage.py makemigrations 会导致虚拟迁移。 ./manage.py sqlmigrate 将显示没有为此迁移执行任何 sql 查询。
要修复它并自动创建 View ,请将 RunSQL 调用添加到该迁移中的 operations
列表。
migrations.RunSQL(''' COPY PASTE SQL QUERY FROM ABOVE ''')
您创建的非托管模型是只读的。尝试创建、替换、更新或删除将失败。如果您需要此功能,您将需要一个 INSTEAD 触发器。
关于 python Django : Join on the same table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34533492/
这个问题在这里已经有了答案: What is the best way to parse html in C#? [closed] (15 个答案) 关闭 3 年前。 string input =
为什么 wrapper #4 没有继承其父表容器的高度?表格嵌套在一个显示 block 包装器中,每个嵌套的div是显示表格,每个表格继承到最里面的一个。是什么原因造成的,我该如何解决? jsfidd
我正在使用带有 Bootstrap 的自定义 css 作为外边框。但顶部边框不可见,除非我将其大小设置为 2 px。 我该如何解决这个问题? HTML #name 1.one 2.two 3.thr
我正在逻辑层面上设计一个数据库,以便稍后将其传递给程序员来交付。我只是粗略地了解它们的工作原理,所以我很难简洁地表达我的问题。这是我的问题: 我有一个名为 MEANINGS 的表。 我有一个名为 WO
在 Laravel 上,我们可以使用 DB::table('table')->get(); 或使用 model::('table')->all() 进行访问;我的问题是它们之间有什么区别? 谢谢。 最
我试图从以下内容中抓取 URL从 WorldOMeter 获取 CoVid 数据,在此页面上存在一个表,id 为:main_table_countries_today其中包含我希望收集的 15x225
这是我的图表数据库:/image/CGAwh.png 我用 SEQUELIZE 制作了我的数据库模型: 型号:级别 module.exports = (sequelize, DataTypes) =>
我真的不明白为什么我的代码不能按预期工作。当我将鼠标悬停在表格的每一行上时,我想显示一个图像(来 self 之前加载的 JSON)。每个图像根据行的不同而不同,我想将它们显示在表格之外的另一个元素中。
假设我的数据库中有一张地铁 map ,其中每条线路的每个站点都是一行。如果我想知道我的线路在哪里互连: mysql> SELECT LineA.stop_id FROM LineA, LineB WH
我最近经常使用这些属性,尤其是 display: table-cell。它在现代浏览器中得到了很好的支持,并且它对某些网格有很多好处,并且可以非常轻松地对齐内容,而无需棘手的标记。但在过去的几天里,我
在 CSS 中,我可以这样做: http://s1.ipicture.ru/uploads/20120612/Uk1Z8iZ1.png http://s1.ipicture.ru/uploads/20
问题作为标题,我正在学习sparkSQL,但我无法很好地理解它们之间的区别。谢谢。 最佳答案 spark.table之间没有区别& spark.read.table功能。 内部 spark.read.
我正在尝试根据 this answer 删除表上的非空约束.但是,它似乎没有在 sqlite_sequence 中创建条目。这样做之后,即使我可以在使用测试表时让它正常工作。 有趣的是,如果我备份我的
var otable = new sap.m.Table();//here table is created //here multiple header I'm trying to create t
下面两种方法有什么区别: 内存 性能 答: select table.id from table B: select a.id from table a 谢谢(抱歉,如果我的问题重复)。 最佳答案 完
我尝试在表格后添加点,方法是使用 table::after 选择器创建一个点元素并使用 margin: 5px auto 5px auto; 将其居中。它有效,但似乎在第一个表格列之后添加了点,而不是
我正在设计一个可以标记任何内容的数据库,我可能希望能够选择带有特定标记的所有内容。 我正在为以下两个选项而苦苦挣扎,希望得到一些建议。如果有更好的方法请告诉我。 选项A 多个“多对多”连接表。 tag
"center" div 中的下表元素导致 "left" div 中的内容从顶部偏移几个像素(在我的浏览器中为 8 ).在表格之前添加一些文本可消除此偏移量。 为什么?如何在不要求在我的表格前添加“虚
我是一名优秀的程序员,十分优秀!