zoukankan      html  css  js  c++  java
  • 因为导错包, 我把JPQL换成了Querydsl, 我佛了

    前言

    {
        "success": false,
        "message": "For queries with named parameters you need to use provide names for method parameters. Use @Param for query method parameters, or when on Java 8+ use the javac flag -parameters.; nested exception is java.lang.IllegalStateException: For queries with named parameters you need to use provide names for method parameters. Use @Param for query method parameters, or when on Java 8+ use the javac flag -parameters.",
        "payload": {
            "data": null
        }
    }

    正确导入包

    需要导入

    import org.springframework.data.repository.query.Param;

    导入

    import org.apache.ibatis.annotations.Param;

    时否则会报错

    java.lang.IllegalStateException: For queries with named parameters you need to use provide names for method parameters. Use @Param for query method parameters, or when on Java 8+ use the javac flag -parameters.

    或者不用@Param注解采用占位符的方式也是ok的

    @Modifying
    @Query("delete from UserRolePo u where u.roleId = ?1")
    void deleteRelationByRoleId(Integer roleId);

    另外, 在用Querydsl查询过程中又因为导错包发现predicates add异常, 正确导包

    querydsl查询service层代码如下

    list()方法功能是查询code或name like keyword的user信息

    freeze方法用于修改用户status

    package com.cebbank.api.service.impl;
    
    import com.cebbank.api.model.po.QUserPo;
    import com.cebbank.api.model.po.UserPo;
    import com.cebbank.api.model.qo.UserQo;
    import com.cebbank.api.model.vo.SysUserVo;
    import com.cebbank.api.model.vo.UserVo;
    import com.cebbank.api.repository.RoleRepository;
    import com.cebbank.api.repository.UserRepository;
    import com.cebbank.api.service.UserService;
    import com.cebbank.common.exception.UnexpectedStatusException;
    import com.google.common.collect.Lists;
    import com.querydsl.core.types.Predicate;
    import com.querydsl.core.types.Projections;
    import com.querydsl.jpa.impl.JPAQuery;
    import com.querydsl.jpa.impl.JPAQueryFactory;
    import org.apache.commons.lang3.StringUtils;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    import org.springframework.transaction.annotation.Transactional;
    
    import java.util.List;
    
    import static com.cebbank.api.common.CebStatus.SECTION_NOT_EXISTS;
    
    @Service
    public class UserServiceImpl implements UserService {
    
        @Autowired
        private UserRepository userRepository;
        @Autowired
        private RoleRepository roleRepository;
        @Autowired
        private JPAQueryFactory jpaQueryFactory;
    
        @Override
        public SysUserVo list(UserQo qo) {
            QUserPo userPo = QUserPo.userPo;
            List<Predicate> predicates = Lists.newArrayListWithExpectedSize(10);
            if (StringUtils.isNotBlank(qo.getKeyword())) {
                String likeStr = "%" + qo.getKeyword() + "%";
                predicates.add(userPo.name.like(likeStr).or(userPo.code.like(likeStr)));
            }
            JPAQuery<UserVo> selectService = jpaQueryFactory.select(Projections.bean(UserVo.class,
                    userPo.id.as("userId"),
                    userPo.code.as("code"),
                    userPo.name.as("name"),
                    userPo.status.as("status")
            )).from(userPo);
    
            JPAQuery<UserVo> finalQuery = selectService
                    .where(predicates.toArray(new Predicate[predicates.size()]))
                    .offset((qo.getPageNo() - 1) * qo.getPageSize())
                    .limit(qo.getPageSize());
    
            List<UserVo> userVos = finalQuery.fetch();
            userVos.forEach(userVo -> {
                userVo.setRolePo(roleRepository.findRolesByUserId(userVo.getUserId()));
            });
            long total = finalQuery.fetchCount();
            SysUserVo sysUserVo = SysUserVo.builder()
                    .list(userVos)
                    .total(total)
                    .build();
    
            return sysUserVo;
        }
    
        @Override
        @Transactional
        public void freeze(UserQo qo) {
            UserPo userPo = userRepository.findById(qo.getUserId())
                    .orElseThrow(() -> new UnexpectedStatusException(SECTION_NOT_EXISTS, qo.getUserId()));
            userPo.setStatus(qo.getStatus());
            userRepository.save(userPo);
        }
    }
    import org.springframework.data.repository.query.Param;
  • 相关阅读:
    js数组操作
    docker操作命令
    swoole使用案例
    swoole实现视频弹幕效果
    swoole的UDP服务
    swoole的TCP服务
    安装回环网卡&安装Linux前准备
    Linux之安装Linux详细步骤
    Spring Boot的面试题
    Shell 脚本面试问题大全
  • 原文地址:https://www.cnblogs.com/yadongliang/p/13502062.html
Copyright © 2011-2022 走看看