入站通道适配器
入站通道适配器用于使用 JPA QL 在数据库上执行选择查询并返回结果。消息负载可以是单个实体或实体List。以下 XML 配置了一个inbound-channel-adapter
<int-jpa:inbound-channel-adapter channel="inboundChannelAdapterOne" (1)
entity-manager="em" (2)
auto-startup="true" (3)
query="select s from Student s" (4)
expect-single-result="true" (5)
max-results="" (6)
max-results-expression="" (7)
delete-after-poll="true" (8)
flush-after-delete="true"> (9)
<int:poller fixed-rate="2000" >
<int:transactional propagation="REQUIRED" transaction-manager="transactionManager"/>
</int:poller>
</int-jpa:inbound-channel-adapter>
| 1 | inbound-channel-adapter在执行query属性中的 JPA QL 后将消息(带有效负载)放入的通道。 |
| 2 | 用于执行所需 JPA 操作的EntityManager实例。 |
| 3 | 指示组件是否应在应用程序上下文启动时自动启动的属性。该值默认为true。 |
| 4 | 其结果作为消息有效负载发送的 JPA QL |
| 5 | 此属性指示 JPQL 查询在结果中是提供单个实体还是实体List。如果该值设置为true,则单个实体作为消息的有效负载发送。但是,如果在将其设置为true后返回多个结果,则会抛出MessagingException。该值默认为false。 |
| 6 | 此非零、非负整数值指示适配器在执行选择操作时选择不超过给定行数。默认情况下,如果未设置此属性,则查询会选择所有可能的记录。此属性与max-results-expression互斥。可选。 |
| 7 | 一个表达式,用于评估结果集中最大结果数。与max-results互斥。可选。 |
| 8 | 如果您想在查询执行后删除收到的行,请将此值设置为true。您必须确保组件作为事务的一部分运行。否则,您可能会遇到异常,例如:java.lang.IllegalArgumentException: Removing a detached instance … |
| 9 | 如果您想在删除收到的实体后立即刷新持久化上下文,并且不想依赖EntityManager的flushMode,请将此值设置为true。该值默认为false。 |
配置参数参考
以下列表显示了可以为inbound-channel-adapter设置的所有值
<int-jpa:inbound-channel-adapter
auto-startup="true" (1)
channel="" (2)
delete-after-poll="false" (3)
delete-per-row="false" (4)
entity-class="" (5)
entity-manager="" (6)
entity-manager-factory="" (7)
expect-single-result="false" (8)
id=""
jpa-operations="" (9)
jpa-query="" (10)
named-query="" (11)
native-query="" (12)
parameter-source="" (13)
send-timeout=""> (14)
<int:poller ref="myPoller"/>
</int-jpa:inbound-channel-adapter>
| 1 | 此生命周期属性指示此组件是否应在应用程序上下文启动时自动启动。此属性默认为true。可选。 |
| 2 | 适配器将执行所需 JPA 操作的有效负载消息发送到的通道。 |
| 3 | 一个布尔标志,指示在适配器轮询后是否删除选定的记录。默认情况下,该值为false(即,不删除记录)。您必须确保组件作为事务的一部分运行。否则,您可能会遇到异常,例如:java.lang.IllegalArgumentException: Removing a detached instance …。可选。 |
| 4 | 一个布尔标志,指示记录是批量删除还是一次删除一条记录。默认情况下,该值为false(即,记录可以批量删除)。可选。 |
| 5 | 要从数据库查询的实体类的完全限定名。适配器根据实体类名自动构建 JPA 查询。可选。 |
| 6 | 用于执行 JPA 操作的jakarta.persistence.EntityManager实例。可选。 |
| 7 | 用于获取执行 JPA 操作的jakarta.persistence.EntityManager实例的jakarta.persistence.EntityManagerFactory实例。可选。 |
| 8 | 一个布尔标志,指示选择操作是预期返回单个结果还是结果List。如果此标志设置为true,则选定的单个实体作为消息的有效负载发送。如果返回多个实体,则抛出异常。如果为false,则实体List作为消息的有效负载发送。该值默认为false。可选。 |
| 9 | 用于执行 JPA 操作的org.springframework.integration.jpa.core.JpaOperations实现。我们建议不要提供您自己的实现,而是使用默认的org.springframework.integration.jpa.core.DefaultJpaOperations实现。您可以使用entity-manager、entity-manager-factory或jpa-operations属性中的任何一个。可选。 |
| 10 | 此适配器要执行的 JPA QL。可选。 |
| 11 | 此适配器需要执行的命名查询。可选。 |
| 12 | 此适配器执行的本机查询。您可以使用jpa-query、named-query、entity-class或native-query属性中的任何一个。可选。 |
| 13 | o.s.i.jpa.support.parametersource.ParameterSource的一个实现,用于解析查询中参数的值。如果entity-class属性有值,则忽略。可选。 |
| 14 | 向通道发送消息时等待的最长时间(以毫秒为单位)。可选。 |
使用 Java 配置
以下 Spring Boot 应用程序展示了如何使用 Java 配置入站适配器的示例
@SpringBootApplication
@EntityScan(basePackageClasses = StudentDomain.class)
public class JpaJavaApplication {
public static void main(String[] args) {
new SpringApplicationBuilder(JpaJavaApplication.class)
.web(false)
.run(args);
}
@Autowired
private EntityManagerFactory entityManagerFactory;
@Bean
public JpaExecutor jpaExecutor() {
JpaExecutor executor = new JpaExecutor(this.entityManagerFactory);
jpaExecutor.setJpaQuery("from Student");
return executor;
}
@Bean
@InboundChannelAdapter(channel = "jpaInputChannel",
poller = @Poller(fixedDelay = "${poller.interval}"))
public MessageSource<?> jpaInbound() {
return new JpaPollingChannelAdapter(jpaExecutor());
}
@Bean
@ServiceActivator(inputChannel = "jpaInputChannel")
public MessageHandler handler() {
return message -> System.out.println(message.getPayload());
}
}
使用 Java DSL 进行配置
以下 Spring Boot 应用程序展示了如何使用 Java DSL 配置入站适配器的示例:
@SpringBootApplication
@EntityScan(basePackageClasses = StudentDomain.class)
public class JpaJavaApplication {
public static void main(String[] args) {
new SpringApplicationBuilder(JpaJavaApplication.class)
.web(false)
.run(args);
}
@Autowired
private EntityManagerFactory entityManagerFactory;
@Bean
public IntegrationFlow pollingAdapterFlow() {
return IntegrationFlow
.from(Jpa.inboundAdapter(this.entityManagerFactory)
.entityClass(StudentDomain.class)
.maxResults(1)
.expectSingleResult(true),
e -> e.poller(p -> p.trigger(new OnlyOnceTrigger())))
.channel(c -> c.queue("pollingResults"))
.get();
}
}