package com.ruoyi.jianguan.mongodb.service.impl; import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.integration.api.model.TimingSetting; import com.ruoyi.integration.api.model.TransactionRecord; import com.ruoyi.jianguan.constant.IotConstant; import com.ruoyi.jianguan.mongodb.service.TransactionRecordService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Sort; 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.Date; import java.util.List; import java.util.Objects; @Service public class TransactionRecordServiceImpl implements TransactionRecordService { @Autowired private MongoTemplate mongoTemplate; @Override public int create(TransactionRecord transactionRecord) { mongoTemplate.save(transactionRecord); return IotConstant.SUCCESS; } @Override public TransactionRecord findById(String id) { return mongoTemplate.findById(id, TransactionRecord.class); } @Override public List findAll() { return mongoTemplate.findAll(TransactionRecord.class); } /** * 根据订单流水号查询数据 * @param code * @return */ @Override public TransactionRecord findOne(String code) { Query query = new Query(); if(StringUtils.isNotEmpty(code)){ query.addCriteria(Criteria.where("transaction_serial_number").is(code)); } List transactionRecords = mongoTemplate.find( query.with(Sort.by(Sort.Order.desc("create_time"))) , TransactionRecord.class); return transactionRecords.size() > 0 ? transactionRecords.get(0) : null; } @Override public List getRangeTimeData(Date startTime, Date endTime) { Query query = new Query(); // 根据时间范围查询 if (Objects.nonNull(startTime) && Objects.nonNull(endTime)) { query.addCriteria(Criteria.where("create_time").gte(startTime).lte(endTime)); } List list = mongoTemplate.find( query.with(Sort.by(Sort.Order.desc("create_time"))) , TransactionRecord.class); return list; } }