Spring 引导和 Spring 数据 Couchbase N1QL 自动生成的查询
Spring Boot and Spring Data Couchbase N1QL auto-generated query
我正在尝试使用 Spring Boot 和 Spring Data Couchbase 项目创建一个简单的原型。到目前为止,我一直在尝试使用 Spring-Data 的查询派生机制从方法名称构建 N1QL 查询。
这是我的存储库接口定义,问题出在 findBy... 行。
public interface MetricsRepository extends CrudRepository<Single, String> {
Single save(Single entity);
Single findOne(String id);
List<Single> findByServiceID(long serviceId);
}
如果我排除该方法定义,应用程序将毫无问题地启动。如果我包含它,由于以下错误无法创建存储库 bean:
Caused by: java.lang.AbstractMethodError: org.springframework.data.couchbase.repository.support.CouchbaseRepositoryFactory$CouchbaseQueryLookupStrategy.resolveQuery(Ljava/lang/reflect/Method;Lorg/springframework/data/repository/core/RepositoryMetadata;Lorg/springframework/data/repository/core/NamedQueries;)Lorg/springframework/data/repository/query/RepositoryQuery;
at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.<init>(RepositoryFactorySupport.java:416)
at org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository(RepositoryFactorySupport.java:206)
at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.initAndReturn(RepositoryFactoryBeanSupport.java:251)
at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.afterPropertiesSet(RepositoryFactoryBeanSupport.java:237)
at org.springframework.data.couchbase.repository.support.CouchbaseRepositoryFactoryBean.afterPropertiesSet(CouchbaseRepositoryFactoryBean.java:96)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1637)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1574)
... 36 more
如果我指定一个@Query(例如:@Query("#{#n1ql.selectEntity} WHERE role = $1"),我会得到同样的错误。
我的实体定义:
import com.couchbase.client.java.repository.annotation.Id;
import com.couchbase.client.java.repository.annotation.Field;
import org.springframework.data.couchbase.core.mapping.Document;
@Document
public class Single {
@Id private final String eventID;
@Field private final long serviceID;
@Field private final long metric;
@Field private final long timestamp;
@Field private final long previous;
public Single(String eventID, long serviceID, long metric, long timestamp, long previous) {
this.eventID = eventID;
this.serviceID = serviceID;
this.metric = metric;
this.timestamp = timestamp;
this.previous = previous;
}
public String getEventID() { return eventID; }
public long getServiceID() { return serviceID; }
public long getMetric() { return metric; }
public long getTimestamp() { return timestamp; }
public long getPrevious() { return previous; }
}
我在 REST 控制器中通过 @Autowired 批注使用存储库。
我有一个@Configuration 和@EnableCouchbaseRepositories 配置class @Import-ed 到@SpringBootApplication。我的测试实例上安装了 Couchbase Server 4.0.0 社区版,如果没有 n1ql 查询,我可以连接、存储和检索实体。
我在 gradle 中的依赖项:
dependencies {
compile("org.springframework.data:spring-data-couchbase:2.1.1.RELEASE")
compile("org.springframework.boot:spring-boot-starter-web")
compile("org.springframework.boot:spring-boot-starter-actuator")
testCompile("org.springframework.boot:spring-boot-starter-test")
testCompile("junit:junit")
}
我在使用 Spring Data Couchbase 2.1.1 时遇到了同样的问题 (java.lang.AbstractMethodError)。但是在这种情况下,我在项目中使用了其他依赖项,使用了不同的 Spring Commons 所需版本,并且它们存在冲突。尝试使用不同的版本,也许是 2.1.0.
所以我做了一些依赖检测工作:
- Spring Boot 1.3.3 引用 Spring 版本
1.7.4
(Gosling SR4
) 中的数据 BOM
- 那个版本的 Spring 数据 BOM 引入了
spring data-couchbase 1.4.4
。这就是你会得到的,除非你像你那样强制使用版本。
- 但问题的根源在于它还引入了
spring-data-commons 1.11.4
(当然,因为 BOM 是为了捆绑一组连贯的版本)
因此,您最终只能强制使用 Spring Data Couchbase 依赖项的版本,同时依赖 BOM 选择 Spring Data Commons,从而导致工件不兼容。
这里有点坏消息:如果你想要Spring Data Couchbase 2.x(新的"generation"),它只在Spring Data Hopper
中得到官方支持.并且 Hopper
仅在 Spring Boot 1.4.0
中得到官方支持,** 目前处于 MILESTONE 2.
如果您只想开始使用 Spring Data Couchbase 2.x,也许可以使用 Spring Boot 1.4.0.M2?
如果您真的不关心 2.x 版本,您应该简单地删除 Gradle 配置中的版本,它应该可以工作。
危险区域:如果你绝对想在Spring Boot 1.3.3 中做一些Spring Data Couchbase 2.1.1,那么请注意如果依赖冲突,任何事情都可能中断。也就是说,如果您只使用 Couchbase 数据存储,也许您会没事的。 Gradle 的方法很复杂,因为您需要一个插件来导入 BOM。看看 this gist.
我已经更新了项目站点以注意 BOM 通常比强制版本更受青睐。快速入门适用于独立项目。
我正在尝试使用 Spring Boot 和 Spring Data Couchbase 项目创建一个简单的原型。到目前为止,我一直在尝试使用 Spring-Data 的查询派生机制从方法名称构建 N1QL 查询。
这是我的存储库接口定义,问题出在 findBy... 行。
public interface MetricsRepository extends CrudRepository<Single, String> {
Single save(Single entity);
Single findOne(String id);
List<Single> findByServiceID(long serviceId);
}
如果我排除该方法定义,应用程序将毫无问题地启动。如果我包含它,由于以下错误无法创建存储库 bean:
Caused by: java.lang.AbstractMethodError: org.springframework.data.couchbase.repository.support.CouchbaseRepositoryFactory$CouchbaseQueryLookupStrategy.resolveQuery(Ljava/lang/reflect/Method;Lorg/springframework/data/repository/core/RepositoryMetadata;Lorg/springframework/data/repository/core/NamedQueries;)Lorg/springframework/data/repository/query/RepositoryQuery;
at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.<init>(RepositoryFactorySupport.java:416)
at org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository(RepositoryFactorySupport.java:206)
at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.initAndReturn(RepositoryFactoryBeanSupport.java:251)
at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.afterPropertiesSet(RepositoryFactoryBeanSupport.java:237)
at org.springframework.data.couchbase.repository.support.CouchbaseRepositoryFactoryBean.afterPropertiesSet(CouchbaseRepositoryFactoryBean.java:96)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1637)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1574)
... 36 more
如果我指定一个@Query(例如:@Query("#{#n1ql.selectEntity} WHERE role = $1"),我会得到同样的错误。
我的实体定义:
import com.couchbase.client.java.repository.annotation.Id;
import com.couchbase.client.java.repository.annotation.Field;
import org.springframework.data.couchbase.core.mapping.Document;
@Document
public class Single {
@Id private final String eventID;
@Field private final long serviceID;
@Field private final long metric;
@Field private final long timestamp;
@Field private final long previous;
public Single(String eventID, long serviceID, long metric, long timestamp, long previous) {
this.eventID = eventID;
this.serviceID = serviceID;
this.metric = metric;
this.timestamp = timestamp;
this.previous = previous;
}
public String getEventID() { return eventID; }
public long getServiceID() { return serviceID; }
public long getMetric() { return metric; }
public long getTimestamp() { return timestamp; }
public long getPrevious() { return previous; }
}
我在 REST 控制器中通过 @Autowired 批注使用存储库。 我有一个@Configuration 和@EnableCouchbaseRepositories 配置class @Import-ed 到@SpringBootApplication。我的测试实例上安装了 Couchbase Server 4.0.0 社区版,如果没有 n1ql 查询,我可以连接、存储和检索实体。
我在 gradle 中的依赖项:
dependencies {
compile("org.springframework.data:spring-data-couchbase:2.1.1.RELEASE")
compile("org.springframework.boot:spring-boot-starter-web")
compile("org.springframework.boot:spring-boot-starter-actuator")
testCompile("org.springframework.boot:spring-boot-starter-test")
testCompile("junit:junit")
}
我在使用 Spring Data Couchbase 2.1.1 时遇到了同样的问题 (java.lang.AbstractMethodError)。但是在这种情况下,我在项目中使用了其他依赖项,使用了不同的 Spring Commons 所需版本,并且它们存在冲突。尝试使用不同的版本,也许是 2.1.0.
所以我做了一些依赖检测工作:
- Spring Boot 1.3.3 引用 Spring 版本
1.7.4
(Gosling SR4
) 中的数据 BOM
- 那个版本的 Spring 数据 BOM 引入了
spring data-couchbase 1.4.4
。这就是你会得到的,除非你像你那样强制使用版本。 - 但问题的根源在于它还引入了
spring-data-commons 1.11.4
(当然,因为 BOM 是为了捆绑一组连贯的版本)
因此,您最终只能强制使用 Spring Data Couchbase 依赖项的版本,同时依赖 BOM 选择 Spring Data Commons,从而导致工件不兼容。
这里有点坏消息:如果你想要Spring Data Couchbase 2.x(新的"generation"),它只在Spring Data Hopper
中得到官方支持.并且 Hopper
仅在 Spring Boot 1.4.0
中得到官方支持,** 目前处于 MILESTONE 2.
如果您只想开始使用 Spring Data Couchbase 2.x,也许可以使用 Spring Boot 1.4.0.M2?
如果您真的不关心 2.x 版本,您应该简单地删除 Gradle 配置中的版本,它应该可以工作。
危险区域:如果你绝对想在Spring Boot 1.3.3 中做一些Spring Data Couchbase 2.1.1,那么请注意如果依赖冲突,任何事情都可能中断。也就是说,如果您只使用 Couchbase 数据存储,也许您会没事的。 Gradle 的方法很复杂,因为您需要一个插件来导入 BOM。看看 this gist.
我已经更新了项目站点以注意 BOM 通常比强制版本更受青睐。快速入门适用于独立项目。