首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >方法public,spring jpa的查询验证失败?

方法public,spring jpa的查询验证失败?
EN

Stack Overflow用户
提问于 2020-05-30 14:37:06
回答 2查看 104关注 0票数 0

我正在创建一个api来从DB中查询并返回结果。

这是请求

代码语言:javascript
复制
@RequestMapping(value = "/config", params = { "appCode", "appVersion" }, method = RequestMethod.GET)
public List<AppConfig> getConfig(@RequestParam(value = "appCode", required = true) String appCode,
        @RequestParam(value = "appVersion", required = true) String appVersion) {
    return configRepository.findByCodeAndVersion(appCode, appCode);
}

表类

代码语言:javascript
复制
@Entity
@Table(name = "app_config")
@EntityListeners(AuditingEntityListener.class)
public class AppConfig {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(columnDefinition = "serial")
private long id;
@Column(name = "app_code", nullable = false)
private String appCode;
@Column(name = "app_name", nullable = false)
private String appName;
@Column(name = "api_url", nullable = true)
private String apiUrl;
@Column(name = "db_name", nullable = true)
private String dbName;
@Column(name = "app_version", nullable = false)
private String appVersion;
}

我在其中进行自定义查询的存储库

代码语言:javascript
复制
@Repository
public interface AppConfigRepository extends CrudRepository<AppConfig, Long> {

@Query("SELECT n FROM AppConfig WHERE n.appCode = ?1 and n.appVersion = ?2")
List<AppConfig> findByCodeAndVersion(String appCode, String appVersion);
}

在运行应用程序时,我得到了异常

代码语言:javascript
复制
Validation failed for query for method public abstract java.util.List com.api.repository.AppConfigRepository.findByCodeAndVersion(java.lang.String,java.lang.String)!
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-05-30 14:44:55

在查询中,您必须在实体名称AppConfig之后添加别名n,应该如下所示:

代码语言:javascript
复制
@Query("SELECT n FROM AppConfig n WHERE n.appCode = ?1 and n.appVersion = ?2")
List<AppConfig> findByCodeAndVersion(String appCode, String appVersion);

您还可以在查询字符串中使用命名参数,如下所示:

代码语言:javascript
复制
@Query("SELECT n FROM AppConfig n WHERE n.appCode = :appCode and n.appVersion = :appVersion")
List<AppConfig> findByCodeAndVersion(String appCode, String appVersion);

像这样的查询可以由Spring data query方法处理,只需确保重命名该方法以使用实体的字段名称:

代码语言:javascript
复制
List<AppConfig> findByAppCodeAndAppVersion(String appCode, String appVersion);
票数 1
EN

Stack Overflow用户

发布于 2020-05-30 14:45:32

试试这个:

代码语言:javascript
复制
@Query("SELECT FROM AppConfig n WHERE n.appCode = :x and n.appVersion = :y")
List<AppConfig> findByCodeAndVersion(@Param("x")String appCode,@Param("y") String appVersion);

或者,您可以直接使用该方法:

代码语言:javascript
复制
List<AppConfig> findByAppCodeAndAppVersion(String appCode,String appVersion);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62098753

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档