gpt4 book ai didi

python - 如何在 Django 1.10 中使用 `unaccent` 进行全文搜索?

转载 作者:太空狗 更新时间:2023-10-30 00:54:27 37 4
gpt4 key购买 nike

我们正在做一个项目,我们正在使用 Django 1.10a1,我们正在使用带有 PostgreSQL 的 Django 全文搜索,但我们需要使用 unaccent。

所以,我有这段代码:

        search = 'Car'
query_set = Article.objects.annotate(
search=SearchVector(
'content',
'name'
)
).filter(
search__unaccent=search
)

当我们尝试在 search 之后添加 unaccent 词时,查询不起作用。我们怎样才能让 django 全文搜索与 postgress unaccent 一起工作?

最佳答案

unaccent 扩展安装到您的数据库中:

mydb=# CREATE EXTENSION unaccent;

基于另一个配置创建一个新的搜索配置:

mydb=# CREATE TEXT SEARCH CONFIGURATION french_unaccent( COPY = french );

unaccent 词典插入到您的新搜索配置中:

mydb=# ALTER TEXT SEARCH CONFIGURATION french_unaccent
ALTER MAPPING FOR hword, hword_part, word
WITH unaccent, french_stem;

在您的 Django 查询中使用此配置:

search = 'Car'
query_set = Article.objects.annotate(
search=SearchVector('content','name', config='french_unaccent')
).filter(search=SearchQuery(search, config='french_unaccent')))

关于python - 如何在 Django 1.10 中使用 `unaccent` 进行全文搜索?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37818492/

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