48.5. 消息正文处理


SQL 组件会尝试将消息正文转换为 java.util.Iterator 类型的对象,然后使用这个迭代器填充查询参数(其中每个查询参数由端点 URI 中的 # 符号(或配置了占位符)表示。如果消息正文不是数组或集合,则转换会导致迭代一个对象(即正文本身)。

例如,如果消息正文是 java.util.List 的实例,列表中的第一个项将替换到 SQL 查询中的第一个 # 的位置,则列表中的第二个项将被替换为 # 的第二个位置,以此类推。

如果 批处理 设置为 true,则入站消息正文的解释稍为 - 而不是参数程序,组件需要含有参数迭代器的迭代器;外部器的大小决定批处理大小。

您可以使用选项 useMessageBodyForSql,允许使用消息正文作为 SQL 语句,然后在带有键 SqlConstants.SQL_PARAMETERS 的标头中提供 SQL 参数。这使得 SQL 组件能够在消息正文中时更动态地工作。根据是否存在查询参数,使用模板(如 VelocityFreemarker)进行条件处理,例如要包含或排除 where 子句。

返回顶部
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2025 Red Hat