Spring JPA 自定义实体类和自定义sql语句多表关联复杂子查询

本文介绍了在Spring JPA中如何使用自定义实体类配合SQL语句进行多表关联查询,包括注意事项和踩坑经验。讨论了实体类的配置、Repository的创建以及字段命名规则。同时,分享了一个自定义实体类和对应的复杂SQL查询示例,以供参考。
摘要由CSDN通过智能技术生成

   最近在写一个功能,jpa操作,不过还是习惯性地用了sql语句来查询,主要是嫌麻烦,想返回的数据用一条查询返回来,所以就用spring  jpa写了个自定义的实体类来装我专门返回来的数据字段,然后sql也有点复杂,join了几张表,也写了一点子查询什么的,估计后期要改这个sql,但是目前是为了方便,临时写的sql,后期数据量大的话,这个sql语句如果不优化,就不好加载了,会比较慢,然后下面讲一下一些注意点,这也是踩的一些坑吧,最后再把一些图片贴上,给各位参考参考:

    注意点: 

       1,自定义实体类的话,首先是要把这个类放到Repository寻找的model包路径里边的,不然会报错,说你新建的类不存在,创建Bean异常;

      2,自定义的实体类之后,要新建一个专门的Repository来调用它,一个Repository对应一个实体;

      3,@Column注解,在spring jpa中的命名默认是下划线分隔的字段命名,弄成驼峰形式的话,也会转回下划线的格式,这个挺坑的,反正我也弄了挺久,那时候不知道spring jpa有个这样的默认情况,记得@Column的命名要与sql语句中的别名对应一样,不然也会报错,说找不到这个字段;

      4,如果@Column注解,先用驼峰命名的话,就可以在配置文件里配置,配置一个好像是ImprovedNamingStrategy的命名配置吧,

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值