mongoDB轨迹保存和查询

复制代码
TrajectoryPoint对象

package com.gjxx.mongo.entity;

import lombok.Data;
import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Data
@Document(collection = "trajectoryPoint")  //类似于@Table标签,用于指明数据库表名/集合名
public class TrajectoryPoint {

    @Id
    /** sim卡号_轨迹时间 */
    private String id;
    /** 轨迹对象json */
    private String traceVoJson;
}
复制代码
TrajectoryPointService对象
复制代码
package com.gjxx.mongo.service;

import com.gjxx.mongo.entity.TrajectoryPoint;

import java.util.List;

public interface TrajectoryPointService {
    //定义一个查询方法
    TrajectoryPoint findTrajectoryPointById(String id);
    //定义一个保存方法
    void save(TrajectoryPoint trajectoryPoint);
    //定义一个删除方法
    void delete(String id);
    //定义一个根据时间查询方法
    List<TrajectoryPoint> findAllByTime(String startTime, String endTime);
}
复制代码
TrajectoryPointServiceImpl对象
复制代码
package com.gjxx.mongo.service.impl;

import com.gjxx.mongo.dao.TrajectoryPointRepository;
import com.gjxx.mongo.entity.TrajectoryPoint;
import com.gjxx.mongo.service.TrajectoryPointService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class TrajectoryPointServiceImpl implements TrajectoryPointService {

    //注入dao
    @Autowired
    private TrajectoryPointRepository trajectoryPointRepository;
    @Autowired
    private MongoTemplate mongoTemplate;


    @Override
    public TrajectoryPoint findTrajectoryPointById(String id) {
        return trajectoryPointRepository.findTrajectoryPointById(id);
    }

    @Override
    public void save(TrajectoryPoint trajectoryPoint) {
        trajectoryPointRepository.save(trajectoryPoint);
    }

    @Override
    public void delete(String id) {
        trajectoryPointRepository.deleteById(id);
    }

    @Override
    public List<TrajectoryPoint> findAllByTime(String startTime,String endTime) {
        Query query = new Query();
        query.addCriteria(Criteria.where("id").lt(endTime).gt(startTime));
        return mongoTemplate.find(query, TrajectoryPoint.class);
    }
}
相关推荐
瀚高PG实验室21 分钟前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)32 分钟前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU2 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng2 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿3 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-3 小时前
Redis 命令
数据库·redis·缓存
小江的记录本4 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`4 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存
二宝哥4 小时前
离线安装maven
java·数据库·maven
SZLSDH5 小时前
场景适配论 | 数字孪生IOC建设中渲染技术与智能体能力的协同逻辑
前端·数据库·ai·数字孪生·数据可视化·智能体