325장. SQL Component
Camel 버전 1.4에서 사용 가능
sql: 구성 요소를 사용하면 JDBC 쿼리를 사용하여 데이터베이스 작업을 수행할 수 있습니다. 이 구성 요소와 JDBC 구성 요소의 차이점은 SQL의 경우 쿼리가 끝점의 속성이며 쿼리에 전달된 매개 변수로 메시지 페이로드를 사용한다는 것입니다.
이 구성 요소는 실제 SQL 처리를 위해 뒤따르는 spring-jdbc
를 사용합니다.
Maven 사용자는 이 구성 요소의 pom.xml
에 다음 종속성을 추가해야 합니다.
SQL 구성 요소는 다음과 같은 기능도 지원합니다.
- Idempotent Consumer EIP 패턴에 대한 JDBC 기반 리포지토리입니다. 325.13절. “JDBC 기반 idempotent 리포지토리 사용”을 참조하십시오.
- Aggregator EIP 패턴에 대한 JDBC 기반 리포지토리입니다. 325.14절. “JDBC 기반 집계 리포지토리 사용”을 참조하십시오.
325.1. URI 형식 링크 복사링크가 클립보드에 복사되었습니다!
경고: Camel 2.11 이상에서 이 구성 요소는 소비자(예: from())
및 생산자 엔드포인트(예: to())
를 모두 생성할 수 있습니다. 이전 버전에서는 생산자로만 작동할 수 있었습니다.
정보: 이 구성 요소는 트랜잭션 클라이언트로 사용할 수 있습니다.
SQL 구성 요소는 다음 끝점 URI 표기법을 사용합니다.
sql:select * from table where id=# order by name[?options]
sql:select * from table where id=# order by name[?options]
Camel 2.11 이상에서는 다음과 같이 :'#name_of_the_parameter' 스타일을 사용하여 이름이 지정된 매개변수를 사용할 수 있습니다.
sql:select * from table where id=:#myId order by name[?options]
sql:select * from table where id=:#myId order by name[?options]
named 매개변수를 사용하는 경우 Camel은 지정된 우선 순위에서 의 이름을 조회합니다.
1. 메시지 본문에서 java.util.Map
2. 메시지 헤더에서
named 매개변수를 확인할 수 없는 경우 예외가 발생합니다.
Camel 2.14 이상에서는 다음과 같이 Simple 표현식을 매개변수로 사용할 수 있습니다.
sql:select * from table where id=:#${property.myId} order by name[?options]
sql:select * from table where id=:#${property.myId} order by name[?options]
SQL 쿼리에 대한 매개 변수를 나타내는 표준
기호는 끝점에 대한 옵션을 지정하는 데 사용되므로 ?
#
기호로 대체됩니다. ?
기호 교체는 끝점에 따라 구성할 수 있습니다.
다음과 같이 Camel 2.17 에서 SQL 쿼리를 classpath 또는 파일 시스템의 파일에 외부화할 수 있습니다.
sql:classpath:sql/myquery.sql[?options]
sql:classpath:sql/myquery.sql[?options]
그리고 myquery.sql 파일은 classpath에 있으며 일반 텍스트만 있습니다.
파일에서 여러 줄을 사용하고 원하는 대로 SQL 형식을 지정할 수 있습니다. 또한 - 대시 행과 같은 주석을 사용합니다.
?option=value&option=value&… 형식의 URI에 쿼리 옵션을
추가할 수 있습니다.