如何在Mendix中实现全文检索

功能背景

在日常的应用使用过程中,存在大量希望使用全文检索技术的场景,对资料库中的内容进行查询。Mendix默认的结构化查询方式,适合对特定业务实体进行类似数据库单表的基于SQL语句的查询。那如何在Mendix实现全文检索的功能呢?

Mendix提供了Global Search模块(https://marketplace.mendix.com/link/component/115019)来帮助用户实现全文检索功能。本文将通过一个示例,来介绍如何在项目中使用和配置全文检索功能。

操作步骤

本文档基于Studio Pro 9/24.2中进行操作

  1. 创建一个新的项目
  1. 导入Community Commons组件

如遇到Studio Pro中Marketplace连接超时的问题,请可以直接访问网站下载,再手工导入项目工程

https://marketplace.mendix.com/link/component/170

确认组件被正常导入到工程

重复上述步骤,导入Global Search 组件

  1. 修复新模块后的一些页面格式错误。右键点击第一条错误信息

点击"Go to Content for placeholder Main"后,打开以下画面

双击左侧对应的项目条目,然后再右侧属性栏中,修改Layout选项,选择'Atlas_Default'

重复以上步骤,修复所有UI错误

所有UI Layout错误修复后,会看到Mendix Studio报属性需要刷新的错误提示。右键单击任意错误,点击"Update all renamed design properties in project",刷新属性信息

双击打开GlobalSearch->_USE_ME->5. Example Implementation->Pages->Actor_Select页面

在页面属性Layout-Type中,选择"Modal Pop-up"

打开GlobalSearch->_USE_ME->5. Example Implementation->Pages->Genre_Select页面,重复以上步骤。

保存项目修改后,所有问题得到修复。

  1. 创建一个新的业务实体。模拟一个客户投诉,实体属性如下:

通过Generalization,选择此业务实体集成SearchableObject

通过这一步的操作,Global Search启动后会自动为此业务事业进行索引创建和维护。

  1. 打开Settings->runtime配置页签,点击"After Startup"的"Select"按钮

选择Global Search->_USE_ME->0.After Startup->ASU_GlobalSearch

  1. 将Global Search->_USE_ME->1. Indexing下面,SUB_IndexObject 和 SUB_DeleteIndex两个Microflow复制到项目模块中
  1. 修改Global Search->_USE_ME->1. Indexing下面的连个Microflow ACO_SearchableObject 和 BDE_SearchableObject, 使用在上一步复制到项目模块的UB_IndexObject 和 SUB_DeleteIndex
  1. 右键MyFirstModule,创建新的MicoFlow

命名为SUB_Incident_Index

添加一个Input Parameter,类型为MyFirstModule.Incidents

依次使用一下Activity配置

完整的Microflow如下:

  1. 修改MyFirstModule->SUB_IndexObject,修改后MicroFlow如下
  1. 修改MyFirstModule->SUB_DeleteIndex,修改后截图如下
  1. 在MyFirstModule中创建一个新的页面,GlobalSearchPage

拖拽一个Snippet Call 控件到画布上,然后选择GlobalSearch->_USE_ME->5. Example Implementation->Snippets->SNIP_Search

双击打开GlobalSearch->_USE_ME->5. Example Implementation->Snippets->SNIP_Search,添加一个模板

  1. 将GlobalSearchPage设置为首页

13 创建测试页面录入测试数据

配置完成,接下来就是见证奇迹的时刻:

我们来做一个查询

测试成功!

以上就是如何在Mendix中基于Global Search组件,进行全文检索配置的全过程。

GO MAKE IT!

关于Mendix

作为西门子Xcelerator平台的低代码引擎,Mendix正在迅速成为推动企业数字化发展的首选应用程序开发平台。Mendix让企业能够以前所未有的速度构建应用程序、促进IT团队与业务专家之间开展有意义的协作,并帮助IT团队保持对整个应用程序环境的控制。作为一直被领先的行业分析师视为"领军者和远见者"的低代码平台,Mendix是云原生的、开放的、可扩展的、敏捷的,并且经过实践验证。从人工智能和增强现实,到智能自动化和原生移动,Mendix和西门子Xcelerator已成为"数字优先"企业的中坚力量。Mendix已被46个国家的4,000多家企业采用,并建立了由30多万名开发人员组成的活跃社区,这些开发人员使用该平台创建了20多万款应用程序。

相关推荐
武子康5 小时前
Java-06 深入浅出 MyBatis - 一对一模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据仓库·sql·mybatis·springboot·springcloud
爱上口袋的天空6 小时前
09 - Clickhouse的SQL操作
数据库·sql·clickhouse
2401_882727577 小时前
BY组态-低代码web可视化组件
前端·后端·物联网·低代码·数学建模·前端框架
Yang.998 小时前
基于Windows系统用C++做一个点名工具
c++·windows·sql·visual studio code·sqlite3
王ASC11 小时前
ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值。ojdbc8版本23.2.0.0驱动BUG【已解决】
数据库·sql·oracle
Elastic 中国社区官方博客12 小时前
Elasticsearch 中的热点以及如何使用 AutoOps 解决它们
大数据·运维·elasticsearch·搜索引擎·全文检索
执键行天涯13 小时前
【日常经验】修改大数据量的表字段类型,怎么修改更快
sql
sevevty-seven14 小时前
幻读是什么?用什么隔离级别可以防止幻读
大数据·sql
天涯倦客的美丽人生19 小时前
SQL递归查询树结构语法
数据库·sql
Java 第一深情20 小时前
Linux上安装单机版ElasticSearch6.8.1
linux·elasticsearch·全文检索