- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我明白了
INFO 4508 --- [nio-8081-exec-9] j.r.q.QueryParameterSetter$ErrorHandling : Silently ignoring
java.lang.IllegalArgumentException: Could not locate named parameter [user], expecting one of [min, gender, max]
at org.hibernate.query.internal.ParameterMetadataImpl.getNamedParameterDescriptor(ParameterMetadataImpl.java:218) ~[hibernate-core-5.3.10.Final.jar:5.3.10.Final]
at org.hibernate.query.internal.ParameterMetadataImpl.getQueryParameter(ParameterMetadataImpl.java:187) ~[hibernate-core-5.3.10.Final.jar:5.3.10.Final]
at org.hibernate.query.internal.QueryParameterBindingsImpl.getBinding(QueryParameterBindingsImpl.java:188) ~[hibernate-core-5.3.10.Final.jar:5.3.10.Final]
at org.hibernate.query.internal.AbstractProducedQuery.setParameter(AbstractProducedQuery.java:493) ~[hibernate-core-5.3.10.Final.jar:5.3.10.Final]
at org.hibernate.query.internal.AbstractProducedQuery.setParameter(AbstractProducedQuery.java:106) ~[hibernate-core-5.3.10.Final.jar:5.3.10.Final]
at org.springframework.data.jpa.repository.query.QueryParameterSetter$NamedOrIndexedQueryParameterSetter.lambda$setParameter$4(QueryParameterSetter.java:113) [spring-data-jpa-2.1.9.RELEASE.jar:2.1.9.RELEASE]
at org.springframework.data.jpa.repository.query.QueryParameterSetter$ErrorHandling$2.execute(QueryParameterSetter.java:185) ~[spring-data-jpa-2.1.9.RELEASE.jar:2.1.9.RELEASE]
at org.springframework.data.jpa.repository.query.QueryParameterSetter$NamedOrIndexedQueryParameterSetter.setParameter(QueryParameterSetter.java:113) [spring-data-jpa-2.1.9.RELEASE.jar:2.1.9.RELEASE]
at org.springframework.data.jpa.repository.query.ParameterBinder.lambda$bind$0(ParameterBinder.java:79) [spring-data-jpa-2.1.9.RELEASE.jar:2.1.9.RELEASE]
at java.util.ArrayList.forEach(ArrayList.java:1257) ~[na:1.8.0_231]
at java.util.Collections$UnmodifiableCollection.forEach(Collections.java:1082) ~[na:1.8.0_231]
代码
@Repository
public interface UserRepo extends JpaRepository<User, Long> {
@Query("select new com.newcode.meeting.domain.dto.UserDto( " +
" us, " +
" SUM (case when ul.userLike = :user then 1 else 0 end) > 0 " +
") from User us left join us.likes ul where " +
" us.birthDate BETWEEN :max and :min " +
" and us.gender =:gender group by us ")
Page<UserDto> findUsersByBirthDateIsBetweenAndGenderDto(
Pageable pageable,
@Param("max") LocalDate max,
@Param("min") LocalDate min,
@Param("gender") Gender gender,
@Param("user") User user
);
如果您需要有人查看,请将 UserDto 分类。我不知道还有什么要添加的,这样它就不会写 -“看起来你的帖子主要是代码;请添加更多详细信息。”
import com.fasterxml.jackson.annotation.JsonView;
import com.newcode.meeting.domain.Image;
import com.newcode.meeting.domain.ProfileDetail;
import com.newcode.meeting.domain.User;
import com.newcode.meeting.domain.Views;
import com.newcode.meeting.dto.Role;
import lombok.*;
import java.net.URL;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.Set;
@Data
@EqualsAndHashCode(of = "id")
@AllArgsConstructor
@RequiredArgsConstructor
@Getter
@Setter
@ToString(of = {"id", "meLiked"})
@JsonView(Views.FullProfileDetail.class)
public class UserDto {
private Long id;
private String username;
private URL userpic;
private Gender gender;
private LocalDate birthDate;
private boolean isOnline;
private Set<Role> roles;
private boolean active;
private String region;
private String country;
private LocalDateTime lastVisit;
private ProfileDetail profileDetail;
@JsonView(Views.FullProfileDetailImage.class)
private Set<Image> images;
private boolean meLiked;
Integer likeNew;
public UserDto(User user, boolean meLiked) {
this.id = user.getId();
this.username = user.getUsername();
this.userpic = user.getUserpic();
this.gender = user.getGender();
this.birthDate = user.getBirthDate();
this.isOnline = user.isOnline();
this.roles = user.getRoles();
this.active = user.isActive();
this.region = user.getRegion();
this.country = user.getCountry();
this.lastVisit = user.getLastVisit();
this.profileDetail = user.getProfileDetail();
this.images = user.getImages();
this.meLiked = meLiked;
this.likeNew = user.getLikeNew();
}
}
public UserPageDto getAllUser(User user, String ageMax, String ageMin, String gender, Pageable pageable) {
user = userRepo.findUserById(user.getId());
LocalDate minDate = getDateForSearchUser(ageMin);
LocalDate maxDate = getDateForSearchUser(ageMax);
Gender sex;
if (gender.equals(Gender.FEMALE.toString())) {
sex = Gender.MALE;
} else {
sex = Gender.FEMALE;
}
Page<UserDto> page = userRepo.findUsersByBirthDateIsBetweenAndGenderDto(pageable, maxDate, minDate, sex, user);
return new UserPageDto(
page.getContent(),
page.getNumber(),
page.getTotalPages());
}
当我添加“Pageable”时,我开始收到此错误。但结果是得到了正确的。没有“Pageable”或参数“user”可以正常工作
问题是如何消除这个错误?
最佳答案
我遇到了类似的问题。
此错误与您的查询无关 - 它提示 countQuery,它计算所有可分页的结果,因此它可以计算它总共获得了多少页。
如果未明确声明,此 countQuery 将自动生成。所以它被生成为使用所有参数但不使用 User(这一代作为一种优化方式,可能会忽略 ORDER BY 或聚合,因为它只需要查询和订单匹配的记录数或其他数据无关紧要)。
因此生成的 countQuery 可能看起来像这样:
@Query("select count(us)" +
"from User us left join us.likes ul where " +
" us.birthDate BETWEEN :max and :min " +
" and us.gender =:gender group by us ")
如您所见 - 受影响的行数与原始查询中的行数相同,但不包括 :user,这就是 Hibernate 无法验证 countQuery 的原因。
将 Pageable 作为参数删除时,您不会遇到同样的错误,因为在这种情况下,不会生成 countQuery(在不使用 :user 参数时也是如此)。
您现在有三个选择:
@Query(value = "select new com.newcode.meeting.domain.dto.UserDto( " +
" us, " +
" SUM (case when ul.userLike = :user then 1 else 0 end) > 0 " +
") from User us left join us.likes ul where " +
" us.birthDate BETWEEN :max and :min " +
" and us.gender =:gender group by us ",
countQuery = "select count(us)" +
"from User us left join us.likes ul where " +
" us.birthDate BETWEEN :max and :min " +
" and us.gender =:gender group by us " +
"order by :user)
关于java.lang.IllegalArgumentException : Could not locate named parameter [user], 期待 [min, gender, max] 之一,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61231447/
在 Tomcat 6/Ubuntu 12.04 上启动 Grails 2.1.0 应用程序时出现以下错误。 Error 500 - Internal Server Error. groovy.lang
在运行 Storm 拓扑时,我收到此错误。拓扑完美运行 5 分钟,没有任何错误,然后失败。我正在使用 Config.TOPOLOGY_TICK_TUPLE_FREQ_SECS as 300 sec i
我有一个 jsp 代码在其中一台机器上运行良好。但是当我复制到另一台机器时,我得到了这个 no such method found 异常。我是 Spring 的新手。有人可以解释我错过了什么吗? 以下
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我的代码在下面给出了一个错误; Exception in thread "main" java.lang.NoSuchMethodError: com/myApp/Client.cypherCBC(L
我正在尝试一个 Restful web 服务示例,所以当我要访问 url 时,我遇到了异常 java.lang.NoSuchMethodError: jersey.repackaged.com.goo
我正在将一个 Spring web 项目转换为一个 Maven 项目,但我收到了这个错误: java.lang.NoSuchMethodError: org.jboss.logging.Logger.
在我的项目中,我有一个像这样的枚举: public enum MyEnum { FIRST(1), SECOND(2); private int value; private MyEnum(int v
我创建了这个简单的示例,用于读取 Linux 正常运行时间: public String getMachineUptime() throws IOException { String[] di
我正在使用 Eclipse,并且正在使用 Java。我的目标是使用 bogoSort 方法对 vector 进行排序在一个 vector (vectorExample)中适应我的 vector 类型,
我正在运行以下查询。它显示一条错误消息。如何解决这个错误? ListrouteList=null; List companyList = session.createS
我有以下模型类: @Entity @Table(name="user_content") @org.hibernate.annotations.NamedQueries({ @org.
我有那个错误。这是我的代码: GmailSettingsService service = new GmailSettingsService(APPLICATION_NAME, DOMAIN_NAME
实际上我在执行我的java程序时遇到了下面提到的错误 Exception in thread "pool-1-thread-1" java.lang.ClassCastException: jav
java.lang.ClassCastException: java.lang.Float cannot be cast to java.lang.String 我在以下代码中遇到此异常: Strin
我正在尝试从 linkedhashset 中检索随机元素。下面是我的代码,但它每次都给我异常。 private static void generateRandomUserId(Set userIds
我已经完成了 Android 中的代码: List spinnerArray = new ArrayList(); for (int i = 0; i item = (LinkedTreeMap)
这个问题已经有答案了: Explanation of ClassCastException in Java (12 个回答) 已关闭 6 年前。 我已经编写了 java 到 Json 的代码,同时从页
这个问题在这里已经有了答案: ClassCastException java.lang.Long cannot be cast to clojure.lang.IFn (4 个答案) 关闭 6 年前
我在运行时遇到问题来编译这段代码,这给我一个错误,java.lang.Integer 无法转换为 Java.lang.Double。如果有人帮助我更正此代码,我将非常高兴 double x; pu
我是一名优秀的程序员,十分优秀!