存储库接口的实例通常由容器创建,在使用 Spring Data 时,Spring 容器是最自然的选择。
Spring Data for Apache Cassandra 附带了一个自定义 CDI 扩展,允许在 CDI 环境中使用存储库抽象。
该扩展是 JAR.To 激活它的一部分,将 Spring Data for Apache Cassandra JAR 拖放到您的类路径中。
现在,您可以通过为 实现 的 CDI 生产者来设置基础架构,如以下检查所示:CassandraTemplate
class CassandraTemplateProducer {
@Produces
@Singleton
public CqlSession createSession() {
return CqlSession.builder().withKeyspace("my-keyspace").build();
}
@Produces
@ApplicationScoped
public CassandraOperations createCassandraOperations(CqlSession session) {
CassandraMappingContext mappingContext = new CassandraMappingContext();
mappingContext.afterPropertiesSet();
MappingCassandraConverter cassandraConverter = new MappingCassandraConverter(mappingContext);
cassandraConverter.setUserTypeResolver(new SimpleUserTypeResolver(session));
cassandraConverter.afterPropertiesSet();
return new CassandraAdminTemplate(session, cassandraConverter);
}
public void close(@Disposes CqlSession session) {
session.close();
}
}
Spring Data for Apache Cassandra CDI 扩展将作为 CDI Bean 选取,并在容器请求存储库类型的 Bean 时为 Spring Data 存储库创建代理。
因此,获取 Spring Data 存储库的实例只需声明注入的属性即可,如以下示例所示:CassandraOperations
class RepositoryClient {
@Inject PersonRepository repository;
public void businessMethod() {
List<Person> people = repository.findAll();
}
}