前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >jpa Page 1 of 0 containing UNKNOWN instances错误

jpa Page 1 of 0 containing UNKNOWN instances错误

作者头像
Diuut
发布2022-11-22 20:09:36
1.3K0
发布2022-11-22 20:09:36
举报
文章被收录于专栏:Diuut

问题排查

代码语言:javascript
复制
 @Autowired
    WeekRankDao weekRankDao;
    @Test
    public void test(){
        Sort sort = Sort.by(Sort.Direction.DESC, "winChip");
        Pageable pageable = PageRequest.of(0, 5, sort);
        WeekRank weekRank=new WeekRank();
        weekRank.setWeek(174);
        log.info("weekRank:{}", weekRank);
        Example<WeekRank> example = Example.of(weekRank);
        Page<WeekRank> rankPage = weekRankDao.findAll(example,pageable);
        log.info("rankPage:{}", rankPage);
        List<WeekRank> content = rankPage.getContent();
        log.info("content:{}", content);
    }

错误代码:jpa Page 1 of 0 containing UNKNOWN instances错误

网上搜索类似的情况有的说是因为传入页数错误导致,但是我换成0,还是1都一样的错误,所以排除页码错误。最终定位到一般是你多个条件查询时,有条件添加进去了,但为空条件。但我代码example模板中确定只传入了一个条件,如果有空的话应该就不是代码的问题,最后又定位到了实体类中.

代码语言:javascript
复制
@Data
@Entity
public class WeekRank {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int id;
    private int uid;
    private String name;
    private int week;
    ``````
}

发现实体类中所有数字字段皆为int类型,而int类型默认值为0,这是否就是导致了JPA认定的空条件,于是把所有的int 换成包装类Integer。同样的代码进行测试,结果显示正常。

代码语言:javascript
复制
@Data
@Entity
public class WeekRank {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    private Integer uid;
    private String name;
    private Integer week;
    ``````
}

总结: 能用Integer就不用int,当基本数据类型定义的变量作为类的成员使用时,Java会确保给定默认值,以保证这些成员变量得到初始化,以防止产生程序错误。但是,这些初始值对程序来说,可能不正确,甚至是不合法的,比如在此处的JPA模板查询中就是非法的空条件。如果一定要使用基本数据类型,最好明确地对变量进行初始化。在对应数据库中的数值类型时,个人强烈建议使用Integer!不能因为一时的想法就去偷懒,而留下安全隐患。

参考:

Post Views: 1,086

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020年7月29日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档