相关疑难解决方法(0)

Java 8 Spring Data JPA参数绑定

在我的@Repository接口中,我使用包含参数(addressType)的JPQL @Query创建了自定义查找方法.

from Address a where a.addressType = :addressType

在方法中,我没有在参数上指定@Param("addressType").所以我得到了

java.lang.IllegalArgumentException:参数绑定的名称不能为null或为空!对于命名参数,您需要在Java版本<8上使用@Param作为查询方法参数.

好的,这很清楚,但我使用的是Java 8.那么Java 8的特殊之处在哪里呢?

jpa jpql java-8 spring-data-jpa

15
推荐指数
2
解决办法
1万
查看次数

保留已编译的java类中的参数/参数名称

当我编译这样的东西时:

public class MyClass
{
    void myMethod(String name, String options, String query, String comment)
    {
        ...
    }
}
Run Code Online (Sandbox Code Playgroud)

并将其编译为类文件,似乎参数名称丢失了.也就是说,当其他一些Java代码引用MyClass并想要调用或覆盖时myMethod,我的IDE(当前是Eclipse)似乎从类文件中获取此方法签名:

void myMethod(String arg0, String arg1, String arg2, String arg3);
Run Code Online (Sandbox Code Playgroud)

我知道,Eclipse(可能还有其他的IDE太)让我提供一个链接到源或javadoc的(如Bishiboosh指出的)MyClass,可以充分利用这一点.但我很好奇是否有某种方法可以告诉javac我们将名称包含在类文件中,以便该类的用户可以看到参数名称,即使它们只有类文件.

课程解决方案

当我用类编译一个类时java -g:vars,参数的名称包含在类文件中.-g:vars似乎等同于Eclipse - >项目属性 - > Java编译器 - >将变量属性添加到生成的类文件中.

几位作者提出了这个解决方案,但尼克的回答终于让我相信了.

在我的机器上,Eclipse有时会使用这些信息,有时它没有,这可能是我的错或Eclipse中的错误,但不是类文件或编译的问题.无论如何,现在我知道信息肯定存在.

但没有接口的解决方案

虽然这对于类来说很好(有点),但它不适用于接口.

对我来说,逻辑上的原因似乎是,-g:vars只提供局部变量的名称,这也是javac的文档所述.在方法体中,它的参数与局部变量非常相似,因此它们被-g:vars覆盖.接口方法没有实体,因此它们不能有局部变量.

我最初的问题只是要求上课,因为我不知道可能有任何不同.

类文件格式

正如gid所指出的,类文件格式不支持参数名称的存储.我在类文件规范中找到了一个描述数据结构的部分,该数据结构应该是方法的参数名称,但在编译接口时绝对不会使用它.

在编译类时,我无法判断是否使用了所提到的数据结构,或者Eclipse是否根据方法体内参数的使用推断出参数名称.专家可以澄清这一点,但我认为这并不相关.

java eclipse compilation javac

14
推荐指数
3
解决办法
1万
查看次数

为什么即使在Java 8上,Spring Data存储库方法参数名称也不可用?

我很难让测试从他们的示例中传递Pivotal的spring-boot1.4版本示例项目,该示例显示在其JPQL中spring-data-jpa使用未注释的命名参数

例如

来自example.springdata.jpa.simple.SimpleUserRepository

 @Query("select u from User u where u.firstname = :firstname")
 List<User> findByFirstname(String firstname);
Run Code Online (Sandbox Code Playgroud)

注意它没有使用@Param注释

这不能在我的机器上运行.我在这里详细介绍了这个例外,从标题中可以看出这一点.

参数绑定的名称不能为null或为空!对于命名参数,您需要在Java版本上使用@Param作为查询方法参数

所以我必须这样做:

@Query("select u from User u where u.firstname = ?1")
List<User> findByFirstname(String firstname);
Run Code Online (Sandbox Code Playgroud)

或这个:

@Query("select u from User u where u.firstname = :firstname")
List<User> findByFirstname(@Param("firstname") String firstname);
Run Code Online (Sandbox Code Playgroud)

我在用什么:

  • 操作系统 - Win7
  • Java - 1.8.0_112
  • IDE - Intellij IDEA 2016.2
  • JPA版本 - JPA v2.0
  • 配置 - spring-boot-1.4.1

所以我设置示例的方式有问题吗?

是否一次 …

java spring annotations spring-data spring-data-jpa

8
推荐指数
1
解决办法
1万
查看次数