326.12. 使用带有动态值的 IN 查询
从 Camel 2.17 开始提供
从 Camel 2.17 开始,SQL 生成者允许将 SQL 查询与 IN 语句一起使用,其中 IN 值是动态计算的。例如,消息正文或标头等。
要使用 IN,您需要:
-
使用以下内容为参数名称
添加前缀: -
在参数外添加
( )
示例说明了这一点。使用以下查询:
-- this is a comment select * from projects where project in (:#in:names) order by id
-- this is a comment
select *
from projects
where project in (:#in:names)
order by id
在以下路由中:
from("direct:query")
.to("sql:classpath:sql/selectProjectsIn.sql")
.to("log:query")
.to("mock:query");
from("direct:query")
.to("sql:classpath:sql/selectProjectsIn.sql")
.to("log:query")
.to("mock:query");
然后,IN 查询可以使用带有动态值的键名称的标头,例如:
也可以在端点中指定查询,而不是外部化(注意外部化可以更轻松地维护 SQL 查询)
from("direct:query")
.to("sql:select * from projects where project in (:#in:names) order by id")
.to("log:query")
.to("mock:query");
from("direct:query")
.to("sql:select * from projects where project in (:#in:names) order by id")
.to("log:query")
.to("mock:query");