热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用springdatajpa管理多对多关系时,需要字段筛选并封装,分页,模糊查询时,应该如何做?

问题描述使用springdatajpa管理多对多关系时,查询封装总是报错.查询方式是EAGER.

问题描述

使用spring data jpa管理多对多关系时,查询封装总是报错.查询方式是EAGER.




问题出现的环境背景及自己尝试过哪些方法

spring data jpa + hibernate
使用fetch会报错,不适用fetch也会报错,似乎是无法封装进App类里面

相关代码


AppDetail.class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
@Entity

@Table(name = "app")

@AllArgsConstructor

@NoArgsConstructor

@JsonIgnoreProperties(value = { "hibernateLazyInitializer", "handler"})

@Data

public class AppDetail implements Serializable {

    public static final int ACTION = 1;

    public static final int CLOSE = 0;



    public static final int NON_CLASSIFY = -1;



    private static final long serialVersiOnUID= 1L;



    @Id

    @GeneratedValue(strategy = GenerationType.IDENTITY)

    int id = 0;

    String name;

    String logoUrl;

    String downloadUrl;





    int classifyId;

    String version;

    int score;

    String packageName;

    @JsonFormat(timezOne= "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")

    Date releaseDate;

    int downloadCount;

    String developer;

    String introduce;

    String updateLog;

    @OneToMany(cascade= CascadeType.ALL,fetch=FetchType.EAGER,targetEntity = AppImgs.class)

    @JoinColumn(name = "appId",referencedColumnName = "id")

    Set imgUrls;

    int state = 1;

    int weight = 0;

    String md5;

    long apkSize;

    String bucketName;



    public Set getClassifies() {

        return classifies;

    }



    public void setClassifies(Set classifies) {

        this.classifies = classifies;

    }



    @ManyToMany(fetch = FetchType.EAGER,targetEntity = Classify.class)

    @JoinTable(name = "app_classify",

            joinColumns = {@JoinColumn(name = "appId",referencedColumnName = "id")},

            inverseJoinColumns = {@JoinColumn(name = "classifyId",referencedColumnName = "id")})

    Set classifies;


App.class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
@AllArgsConstructor

@NoArgsConstructor

@Data

public class App {

    int id;

    String name;

    String logoUrl;

    String downloadUrl;

    int classifyId;

    String version;

    int score;

    String packageName;

    String md5;

    String bucketName;

    @JsonFormat(timezOne= "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")

    Date releaseDate;

    int state = 1;

    int downloadCount;

    Set classifies;


查询语句

1
2
3
    @Query(value = "select distinct new com.flyaudio.server.iov.appstore.domain.App(a.id,a.name,a.logoUrl,a.downloadUrl,a.classifyId,a.version,a.score,a.packageName,a.md5,a.bucketName,a.releaseDate,a.state,a.downloadCount,a.classifies )" +

            " from AppDetail as a left join a.classifies where a.name like CONCAT('%',?1,'%')")

    Page findAppByPage(String name,Pageable pageable);


结果


  • 请问如何才能做到筛选分页模糊查询的同时封装进一个类呢?


   



推荐阅读
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • baresip android编译、运行教程1语音通话
    本文介绍了如何在安卓平台上编译和运行baresip android,包括下载相关的sdk和ndk,修改ndk路径和输出目录,以及创建一个c++的安卓工程并将目录考到cpp下。详细步骤可参考给出的链接和文档。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
author-avatar
just_roshinn5
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有