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);
    }
}
相关推荐
Billow_lamb18 分钟前
redis 中 redisTemplate 的所有操作与函数
数据库·redis·缓存
testpassportcn23 分钟前
Cisco 300-540 SPCNI 認證考試介紹(CCNP Service Provider 專業考試)
网络·数据库
郑州光合科技余经理33 分钟前
实战:攻克海外版同城生活服务平台开发五大挑战
java·开发语言·javascript·数据库·git·php·生活
蟹至之34 分钟前
【MySQL】JDBC的使用(万字解析)
java·数据库·mysql·jdbc
·云扬·1 小时前
InnoDB事务隔离级别与加锁机制深度解析
数据库·sql·mysql
不穿格子的程序员1 小时前
Redis篇8——Redis深度剖析:揭秘 Redis 高性能
数据库·redis·缓存·nio·io多路复用
悦悦子a啊2 小时前
Maven 项目实战入门之--学生管理系统
java·数据库·oracle
他是龙5512 小时前
46:SQLMap实战全攻略(猜解/权限/绕过/调试)
数据库·oracle
一位代码2 小时前
mysql | 环境变量问题及其配置方法详解
数据库·mysql
煎蛋学姐2 小时前
SSM校企协同育人平台j670k(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·ssm 框架开发