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);
    }
}
相关推荐
禁默10 分钟前
已知 inode 号,如何操作文件?Ext 文件系统增删查改底层逻辑拆解
linux·服务器·数据库
云飞云共享云桌面17 分钟前
工厂办公环境如何实现一台服务器多人共享办公
运维·服务器·网络·数据库·3d
weixin_4569042720 分钟前
MySQL高级特性详解
数据库·mysql
Elastic 中国社区官方博客40 分钟前
使用 cloud-native Elasticsearch 与 ECK 运行
大数据·数据库·elasticsearch·搜索引擎·kubernetes·k8s·全文检索
程序员爱钓鱼1 小时前
Go语言实战案例 — 工具开发篇:编写高可用日志收集脚本
后端·mongodb·go
Mr_hwt_1231 小时前
基于MyCat 中间件实现mysql集群读写分离与从库负载均衡教程(详细案例教程)
数据库·mysql·中间件·mysql集群
酷ku的森2 小时前
Redis中的Zset数据类型
数据库·redis·缓存
zhong liu bin2 小时前
MySQL数据库面试题整理
数据结构·数据库·mysql
luckys.one6 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
言之。8 小时前
Django中的软删除
数据库·django·sqlite