wim15013442181 2023-04-13 02:29 采纳率: 36.4%
浏览 116
已结题

Expected one result (or null) to be returned by selectOne(), but found: 3

前端vue

editAdmin (adminInfo) {
          this.axios.get(this.$http.httpUrl('/system/admin/getRoleListByAdminId'), {
            params: {
              adminId: adminInfo.id
            }
          }).then(response => {
            this.adminForm = {
              id: adminInfo.id,
              adminId: adminInfo.adminId,
              loginName: adminInfo.loginName,
              name: adminInfo.name,
              mobile: adminInfo.mobile,
              school_id: 0,
              roleIds: [], // 角色id集合
              disabledFlag: adminInfo.disabledFlag ? 1 : 0
            }

            this.showAdminForm = true
          })
        },

后端 controller

@GetMapping("getRoleListByAdminId")
    @SystemLog(describe = "查看管理员详情")
    public Result getRoleListByAdminId(Integer adminId) {
        System.out.println("管理员"+adminId);
        return Result.success(systemAdminService.getRoleListAdminId(adminId));
    }
service层
@Transactional
    public AdminRoleDto getRoleListAdminId(Integer adminId) {
        AdminRoleDto adminRoleDto = baseMapper.selectById(adminId);
        //System.out.println(adminRoleDto.getRoleId());
        List<Integer>  roleIds = systemAdminRoleService.findRoleListByAdminId2(adminId);
        System.out.println(roleIds);
        //获取角色id集合
        if(ObjectUtils.isNotEmpty(adminRoleDto)){
            Set<Integer> roleIds2 = new HashSet<Integer>(roleIds);
            adminRoleDto.setRoleIds(roleIds2);

        }
        return adminRoleDto;
    }
map层
List<Integer> findRoleListByAdminId2(Integer adminId);

Map XML  SQL 层
<select id="findRoleListByAdminId2" parameterType="Integer" resultType="List">
        select role_id  from system_admin_role where admin_id = #{adminId}
    </select>

对应的role_id 多条数据时候,debug反馈
Expected one result (or null) to be returned by selectOne(), but found: 3

Sql语句有错误吗? 再Navicate 运行查询结果能查询出对应的role_id.这个怎么改呢?

另外调了很久,原本其他项目的数据修改都能成功,但是前端的RoleIds[ ] 这个集合就是取不到数据,修改多了个问题。

  • 写回答

13条回答 默认 最新

  • CSDN专家-sinJack 2023-04-13 12:43
    关注

    xml写的有问题,返回类型写错了。
    mybatis返回List< Integer >时resultType写java.lang.Integer而不是java.util.List

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(12条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 4月15日
  • 已采纳回答 4月14日
  • 赞助了问题酬金15元 4月13日
  • 修改了问题 4月13日
  • 展开全部

悬赏问题

  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来