关于 Spring boot QueryDsl 在编译时到不到父类

2020-10-03 17:45:49 +08:00
 glacial

我在 springboot 的项目中使用了 QueryDsl, 如果使用了父类并且不在一个包下在编译时会报错找不到父类的"Q 类" 例如 :QRootEntity

RootEntity 类路径是在 com.zp.mars.entity 中

User 类路径是在 com.zp.mars.user.domain 中

这个时候去编译 User 类会报不找到 QRootEntity 类, 也就是说 QueryDsl 插件是默认不会找到父类并生成父类的 Q 类的 这个时候有两种解决办法

1.项目中加上一个 package-info 类

@QueryEntities(value = {RootEntity.class})
package com.zp.mars.entity;
import com.querydsl.core.annotations.QueryEntities;
import com.zp.mars.entity.RootEntity;

2.因为我用的是微服务这样在每个项目的中加上 package-info 类我觉得有点麻烦.所以我就把生成好的 QRootEntity 类拷到了 com.zp.mars.entity 下 这样也可以编译通过. 因为我的 RootEntity 基本上不会有变化了所以我觉得可以这么做

不知道大家还有没有更好的办法

2441 次点击
所在节点    Java
5 条回复
Jooooooooo
2020-10-03 17:55:42 +08:00
放到一个 common 包里, 大家都引这个包.
glacial
2020-10-03 18:03:54 +08:00
@Jooooooooo 是的 我的 com.zp.mars.entity.RootEntity 就是个一个 common 包里面
crclz
2020-10-03 20:06:39 +08:00
歪个楼,我个人认为 QueryDSL 很无用。

事务类请求直接使用 JpaRepository 。

查询类请求直接写 sql,一方面是因为 sql 本身是一个很成熟、易编写、易理解的语言,另一方面是因为 IDEA 有 sql 智能提示。
wangyanrui
2020-10-03 21:23:25 +08:00
@glacial common 包也导入 querydsl 的 jar 和 maven 插件即可
TuringHero
2023-12-23 19:28:00 +08:00
@crclz 主要动态条件这种场景,Specification 写起来太繁琐,代码可读性也不够,这时候 QueryDSL 就很香

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/712376

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX