文档章节

Spring中使用Criteria遇到的问题

Neon_Wang
 Neon_Wang
发布于 2017/06/04 18:51
字数 359
阅读 22
收藏 0

很久之前也遇到过一样的问题,发现自己没📈什么记性,果然是好记性不如烂笔头,在此记录下,以免下次再次踩坑。 →。→

创建如下对象:

@Document(collection="Work")
@Data
class Work{
    @Id
    @JsonView(InspectionView.class)
    private String id;
    
    @JsonView(WorkTypeView.class)
    private WorkType workType;

    @JsonView(InspectionView.class)
    private PersonSnapshot personSnapshot;

    @Data
    class PersonSnapshot{

        @JsonView(InspectionView.class)
        private String id;
        
        @JsonView(InspectionView.class)
        private String name;
    }
}

在使用Criteria拼接查询语句中,criteria.and("personSnapshot.id").in(Person.getId());

执行后发现没有查到任何数据,一开始还以为是没有对应的数据,手动去Mongo确认了一下发现并不是这样。

想了很久没什么思路,通过Debug信息输出发现每次执行,personSnapshot.id -> personSnapshot._id

Spring提供的MongoTemplate中,对于属性的处理:

try {

    Field field = createPropertyField(entity, key, mappingContext);
    Entry<String, Object> entry = getMappedObjectForField(field, query.get(key));
    result.put(entry.getKey(), entry.getValue());
} catch (InvalidPersistentPropertyPath invalidPathException) {
    // in case the object has not already been mapped
    if (!(query.get(key) instanceof DBObject)) {
	throw invalidPathException;
    }
    result.put(key, query.get(key));
}

由于急于处理问题,所以没有跟踪的很仔细,但QueryMapper以及其内部类Field中发现存在

private static final List<String> DEFAULT_ID_NAMES = Arrays.asList("id", "_id");
private static final String ID_KEY = "_id";

由此猜测Spring会根据传入的对象映射其属性,对id属性进行默认加“_”操作。

所以尝试着在对象属性中加入@Field("id")注解:

    @Data
    class PersonSnapshot{

        @Field("id")
        @JsonView(InspectionView.class)
        private String id;
        
        @JsonView(InspectionView.class)
        private String name;
    }

结果是令人满意的, 终于找出了问题所在。

© 著作权归作者所有

共有 人打赏支持
Neon_Wang
粉丝 2
博文 5
码字总数 3810
作品 0
杭州
私信 提问
Hibernate 的三种查询方式:HQL、Criteria、Sql

第一种方式:HQL(Hibernate Query Languge,Hibernate 查询语言)查询 是一种面向对象的查询语言,其中没有表和字段的概念,只有类、对象和属性的概念,HQL 是应用较为广泛的方式 语法:[se...

风中帆
2014/06/18
0
0
Spring boot 中自定义JpaRepository使用

普通JpaRepository类 JpaRepository一般的筛选查询,均可以通过的形式解决,总的很好用,但是总有一部分的业务查询是需要JpaRepository不能解决的。这个时候,就需要在此基础上面增加自定义的...

亚林瓜子
08/10
0
0
Spring Mongodb入门

安装Spring for Mongodb Spring项目为方便对Mongodb的操作,建立了spring-data的子项目,地址在: http://www.springsource.org/spring-data/mongodb,目前版本是1.0.0M2阶段,已支持对Mongo...

李长春
2011/11/14
0
2
使用Spring访问Mongodb的方法大全——Spring Data MongoDB查询指南

1.概述 Spring Data MongoDB 是Spring框架访问mongodb的神器,借助它可以非常方便的读写mongo库。本文介绍使用Spring Data MongoDB来访问mongodb数据库的几种方法: 使用Query和Criteria类 ...

xiaomin0322
06/28
0
0
深入浅出学Spring Data JPA

第一章:Spring Data JPA入门 Spring Data是什么 Spring Data是一个用于简化数据库访问,并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷,并支持map-reduce框架和云计算...

John-HZ
2014/06/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

微服务分布式事务实现

https://www.processon.com/view/link/5b2144d7e4b001a14d3d2d30

WALK_MAN
今天
2
0
《大漠烟尘》读书笔记及读后感文章3700字

《大漠烟尘》读书笔记及读后感文章3700字: 在这个浮躁的社会里,你有多久没有好好读完一本书了? 我们总觉得自己和别人不一样,所以当看到别人身上的问题时,很少有“反求诸己”,反思自己。...

原创小博客
今天
4
0
大数据教程(9.5)用MR实现sql中的jion逻辑

上一篇博客讲解了使用jar -jar的方式来运行提交MR程序,以及通过修改YarnRunner的源码来实现MR的windows开发环境提交到集群的方式。本篇博主将分享sql中常见的join操作。 一、需求 订单数据表...

em_aaron
今天
3
0
十万个为什么之什么是resultful规范

起源 越来越多的人开始意识到,网站即软件,而且是一种新型的软件。这种"互联网软件"采用客户端/服务器模式,建立在分布式体系上,通过互联网通信,具有高延时(high latency)、高并发等特点...

尾生
今天
3
0
Terraform配置文件(Terraform configuration)

Terraform配置文件 翻译自Terraform Configuration Terraform用文本文件来描述设备、设置变量。这些文件被称为Terraform配置文件,以.tf结尾。这一部分将讲述Terraform配置文件的加载与格式。...

buddie
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部