第 51 章 SQL
支持制作者和消费者
SQL 组件允许您使用 JDBC 查询来处理数据库。此组件和 JDBC 组件之间的区别是,如果 SQL,查询是端点的属性,它使用消息有效负载作为传递给查询的参数。
此组件使用 spring-jdbc
在 scenes 后面进行实际处理。
Maven 用户需要将以下依赖项添加到其 pom.xml
中:
<dependency> <groupId>org.apache.camel</groupId> <artifactId>camel-sql</artifactId> <version>{CamelSBVersion}</version> <!-- use the same version as your Camel core version --> </dependency>
SQL 组件还支持:
- 基于 JDBC 的存储库,用于 Idempotent Consumer EIP 模式。请参见下文。
- 基于 JDBC EIP 模式的软件仓库。请参见下文。
51.1. URI 格式
此组件可用作 交易客户端。
SQL 组件使用以下端点 URI 表示法:
sql:select * from table where id=# order by name[?options]
您可以使用 :'#name_of_the_parameter' 风格来使用命名参数,如下所示:
sql:select * from table where id=:#myId order by name[?options]
使用指定参数时,Camel 将以给定的优先级从中查找名称:
-
如果
java.util.Map
来自消息正文 - 来自消息标头
如果无法解析命名参数,则会抛出异常。
您可以使用 Simple 表达式作为参数,如下所示:
sql:select * from table where id=:#${exchangeProperty.myId} order by name[?options]
请注意,标准 ? 符号表示 SQL 查询的参数已替换为 # 符号,因为 ? 符号用于指定端点的选项。可以基于端点配置 ? 符号替换。
您可以对 classpath 或文件系统中的文件外部化 SQL 查询,如下所示:
sql:classpath:sql/myquery.sql[?options]
和 myquery.sql 文件位于 classpath 中,只是纯文本
-- this is a comment select * from table where id = :#${exchangeProperty.myId} order by name
在文件中,您可以根据需要使用多行并格式化 SQL。和 也使用注释,如 - dash 行。