如何在 django 1.10 中使用“unaccent”进行全文搜索?

2023-12-30

我们正在开发一个项目并且我们正在使用Django 1.10a1,我们使用 Django 全文搜索和 PostgreSQL,但我们需要使用非重音符号。

所以,我有这个代码:

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

当我们尝试添加unaccent之后的话search查询不起作用。 我们怎样才能让 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')))
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在 django 1.10 中使用“unaccent”进行全文搜索? 的相关文章

随机推荐