From fb1dc85a9ae6a9b8426ec5e29eb0139933ebe233 Mon Sep 17 00:00:00 2001 From: riku <risaku@163.com> Date: 星期日, 29 九月 2019 11:22:24 +0800 Subject: [PATCH] 新增接口: 1. 获取某设备某时间段的数据流个数 --- src/main/kotlin/com/flightfeather/obd/repository/impl/DataStreamDaoImpl.kt | 81 ++++++++++++++++++++++++++++++++++++++++ 1 files changed, 81 insertions(+), 0 deletions(-) diff --git a/src/main/kotlin/com/flightfeather/obd/repository/impl/DataStreamDaoImpl.kt b/src/main/kotlin/com/flightfeather/obd/repository/impl/DataStreamDaoImpl.kt index 12d1583..a72cc1a 100644 --- a/src/main/kotlin/com/flightfeather/obd/repository/impl/DataStreamDaoImpl.kt +++ b/src/main/kotlin/com/flightfeather/obd/repository/impl/DataStreamDaoImpl.kt @@ -2,13 +2,19 @@ import com.flightfeather.obd.domain.entity.DataStream import com.flightfeather.obd.domain.mapper.DataStreamMapper +import com.flightfeather.obd.lightshare.bean.DataStreamVo +import com.flightfeather.obd.lightshare.bean.LatLngVo import com.flightfeather.obd.repository.DataStreamRepository import com.flightfeather.obd.socket.bean.EngineDataStream import com.flightfeather.obd.socket.bean.ObdPackageData import com.flightfeather.obd.socket.bean.ReplacementData import com.flightfeather.obd.socket.bean.SupplementDataStream import com.flightfeather.obd.socket.eunm.ObdCommandUnit +import com.github.pagehelper.PageHelper +import org.springframework.beans.BeanUtils import org.springframework.stereotype.Repository +import tk.mybatis.mapper.entity.Example +import java.text.SimpleDateFormat /** * @author riku @@ -73,4 +79,79 @@ } } + override fun getDataStream(deviceCode: String, pageNum: Int?, pageSize: Int?, startTime: String?, endTime: String?): List<DataStreamVo> { + val sf = SimpleDateFormat("yyyy-MM-dd HH:mm:ss") + val example = Example(DataStream::class.java).apply { + createCriteria().andEqualTo("obdDeviceCode", deviceCode).run { + startTime?.let { + val st = sf.parse(startTime) + andGreaterThanOrEqualTo("obdDataTime", st) + } + endTime?.let { + val et = sf.parse(endTime) + andLessThanOrEqualTo("obdDataTime", et) + } + orderBy("obdDataTime").desc() + } + } + + //鍒嗛〉 + val offset = (pageSize?.times(pageNum?.minus(1) ?: 0)) ?: 0 + PageHelper.offsetPage<DataStream>(offset, pageSize ?: 10) + val result = dataStreamMapper.selectByExample(example) + + val resultList = mutableListOf<DataStreamVo>() + result.forEach { + val vo = DataStreamVo() + BeanUtils.copyProperties(it, vo) + resultList.add(vo) + } + + return resultList + } + + override fun getDataStreamCount(deviceCode: String, startTime: String?, endTime: String?): Int { + val sf = SimpleDateFormat("yyyy-MM-dd HH:mm:ss") + val example = Example(DataStream::class.java).apply { + createCriteria().andEqualTo("obdDeviceCode", deviceCode).run { + startTime?.let { + val st = sf.parse(startTime) + andGreaterThanOrEqualTo("obdDataTime", st) + } + endTime?.let { + val et = sf.parse(endTime) + andLessThanOrEqualTo("obdDataTime", et) + } + orderBy("obdDataTime").desc() + } + } + + return dataStreamMapper.selectCountByExample(example) + } + + override fun getCoordinate(deviceCode: String): LatLngVo { + val example = Example(DataStream::class.java).apply { + createCriteria().andEqualTo("obdDeviceCode", deviceCode).run { + orderBy("obdDataTime").desc() + } + } + + //鑾峰彇鏈�鏂扮殑涓�涓� + PageHelper.offsetPage<DataStream>(0, 1) + val result = dataStreamMapper.selectByExample(example) + + val latLngVo = LatLngVo() + if (result.isNotEmpty()) { + result[0].let { + latLngVo.apply { + this.deviceCode = it.obdDeviceCode + obdDataTime = it.obdDataTime + lat = it.obdLat + lng = it.obdLong + } + } + } + + return latLngVo + } } \ No newline at end of file -- Gitblit v1.9.3