使用PostgreSQL trigram扩展进行模糊搜索
项目描述
PostgreSQL Trigram Search
此插件提供了创建字符和文本字段的 GIN 或 GiST 索引的能力,并可以在搜索域中使用搜索运算符 %。目前此模块不会更改后端搜索或其他任何内容。它仅提供对外部插件进行模糊搜索的可能性。
安装
PostgreSQL 扩展 pg_trgm 应该可用。在基于 Debian 的发行版中,您必须安装 postgresql-contrib 模块。
将 pg_trgm 扩展安装到您的数据库或给您的 postgresql 用户授予 SUPERUSER 权限(这允许 odoo 模块将扩展安装到数据库中)。
配置
如果已安装 odoo 模块
您可以通过 设置 -> 数据库结构 -> Trigram 索引 定义 char 和 text 的 GIN 和 GiST 索引。索引名称将自动为新条目创建。
使用方法
您可以为 res.partner 的 name 字段创建索引。
在搜索中,您可以使用
self.env['res.partner'].search([('name', '%', 'Jon Miller)])
在此示例中,函数将返回 John Miller 或 John Mill 的阳性结果。
您可以通过调整设置限制(默认:0.3)来调整返回的字符串数量。注意:目前您必须通过执行以下 SQL 语句来设置限制
self.env.cr.execute("SELECT set_limit(0.2);")
另一个有趣的功能是在 order 参数中使用 similarity(column, 'text') 函数来按相似度排序。此模块只包含一个基本实现,不执行验证,必须从该函数开始。例如,您可以定义函数如下
similarity(%s.name, 'John Mil') DESC" % self.env['res.partner']._table
有关更多问题,请参阅 pg_trgm 模块的文档。
已知问题/路线图
修改通用搜索部分(例如,在树视图或many2one字段中)
添加更好的 order by 处理
错误跟踪器
错误在 GitHub Issues 上跟踪。如果在那里遇到问题,请检查您的问题是否已被报告。如果您是第一个发现它的人,请通过提供详细且受欢迎的反馈来帮助我们解决这个问题。
致谢
图片
Odoo 社区协会:图标。
贡献者
Christoph Giesel <https://github.com/christophlsa>
Jordi Ballester <jordi.ballester@eficent.com>
Serpent Consulting Services Pvt. Ltd. <support@serpentcs.com>
维护者
此模块由 OCA 维护。
OCA,或 Odoo 社区协会,是一个非营利组织,其使命是支持 Odoo 功能的协作开发并促进其广泛应用。
要为此模块做出贡献,请访问 https://odoo-community.org。
项目详情
哈希值 for odoo9_addon_base_search_fuzzy-9.0.1.0.0.99.dev18-py2-none-any.whl
算法 | 哈希摘要 | |
---|---|---|
SHA256 | e63fa3e406d20a8264d06e3c13ec58c3467cf39cb73504b1b2a0a6422b80abae |
|
MD5 | 60eaf6f968593b4a5deeb7a38ca53cd0 |
|
BLAKE2b-256 | deada98026771c2d1b9ae8c26e8fcabde94d6bd1c9a1ef987a52d44e60fb4a40 |