java jpa 教程 查询_[Java教程]spring data jpa查询部分字段

本文介绍了三种在Spring Data JPA中查询部分字段的方法。第一种是通过建立自定义Model并利用构造函数转化查询结果。第二种是在Service中将查询结果转换为JSON。第三种是使用默认值在SQL查询语句中选择字段。每种方法都有其适用场景,可以根据需求选择合适的方法。
摘要由CSDN通过智能技术生成

[Java教程]spring data jpa查询部分字段

0 2018-09-06 17:02:45

spring data jpa查询部分字段

第一种方法:使用 model 查询时转化

首先建立一个 model ,写上自己想要查询的字段,然后写上构造函数,这步很重要,因为spring jpa 转化时会调用这个构造方法public class MyModel implements Serializable { private String userName; private String name; private String gender; private String description; public MyModel() {}; public MyModel(String userName, String name, String gender, String description) { this.userName = userName; this.name = name; this.gender = gender; this.description = description; }}

然后在 dao 类中写查询方法@Query(value = "select new pers.zhuch.model.MyModel(u.userName, ui.name, ui.gender, ui.description) from UserInfo ui, User u where u.id = ui.userId")public List getAllRecord();

直接在查询语句中 new model 框架底层会调用它,然后返回这个对象(这里我写了完整的类路径,不写的时候它报错说找不到类型什么的)

然后就可以获得只有指定字段的 model 了。然后就把它转成 JSON 格式就 O 了。

第二种方法:在service 里边转换成 JSON

原理其实和第一种方法差不多,只是处理结果的方式不太一样,只是这种方法我们就不在 hql 中 new Model 了,直接写查询方法@Query(value = "select new map(u.userName, ui.name, ui.gender, ui.description) from UserInfo ui, User u where u.id = ui.userId")public List> getCustomField();

直接new map(这里得是小写,不知道大写有木有问题,反正没试,编译器提示是要小写的)

然后返回的结果是这样的[ { "0": "admin", "1": "你猜", "2": "男", "3": "一段描述" }, { "0": "abc", "1": "你猜人家", "2": "女", "3": "没事先挂了" }]

第三种方法:select语句部分字段使用默认值@Query(value = "select u.user_name, ui.name, ui.gender,ui.description,'' as headImg from user_info u where u.id = 1",nativeQuery=true)public List getAllRecord();

参考文章:https://blog.csdn.net/zhu562002124/article/details/75097682 本文网址:http://www.shaoqun.com/a/389891.html

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:admin@shaoqun.com。

Spring

0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值