1. 定位日志

2. 低电量警报开关
This commit is contained in:
邱贞招 2024-09-12 16:54:56 +08:00
parent 8bc7c4c95d
commit fb772973e0
14 changed files with 355 additions and 46 deletions

View File

@ -251,7 +251,7 @@ public class AppController extends BaseController
@GetMapping("/fee/list")
public AjaxResult feeList(EtFeeRule etFeeRule)
{
List<EtFeeRule> list = etFeeRuleService.selectRuleInfoListByModelId(etFeeRule.getModelId());
List<EtFeeRule> list = etFeeRuleService.selectEtFeeRuleListByAreaId(etFeeRule.getAreaId());
return success(list);
}

View File

@ -0,0 +1,105 @@
package com.ruoyi.web.controller.system;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.system.domain.EtLocationLog;
import com.ruoyi.system.service.IEtLocationLogService;
import com.ruoyi.common.utils.poi.ExcelUtil;
import com.ruoyi.common.core.page.TableDataInfo;
/**
* 定位日志Controller
*
* @author ruoyi
* @date 2024-09-12
*/
@RestController
@RequestMapping("/system/locationLog")
public class EtLocationLogController extends BaseController
{
@Autowired
private IEtLocationLogService etLocationLogService;
/**
* 查询定位日志列表
*/
@PreAuthorize("@ss.hasPermi('system:locationLog:list')")
@GetMapping("/list")
public TableDataInfo list(EtLocationLog etLocationLog)
{
startPage();
List<EtLocationLog> list = etLocationLogService.selectEtLocationLogList(etLocationLog);
etLocationLogService.analytic(list);
return getDataTable(list);
}
/**
* 导出定位日志列表
*/
@PreAuthorize("@ss.hasPermi('system:locationLog:export')")
@Log(title = "定位日志", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, EtLocationLog etLocationLog)
{
List<EtLocationLog> list = etLocationLogService.selectEtLocationLogList(etLocationLog);
ExcelUtil<EtLocationLog> util = new ExcelUtil<EtLocationLog>(EtLocationLog.class);
util.exportExcel(response, list, "定位日志数据");
}
/**
* 获取定位日志详细信息
*/
@PreAuthorize("@ss.hasPermi('system:locationLog:query')")
@GetMapping(value = "/{locationId}")
public AjaxResult getInfo(@PathVariable("locationId") Long locationId)
{
return success(etLocationLogService.selectEtLocationLogByLocationId(locationId));
}
/**
* 新增定位日志
*/
@PreAuthorize("@ss.hasPermi('system:locationLog:add')")
@Log(title = "定位日志", businessType = BusinessType.INSERT)
@PostMapping
public AjaxResult add(@RequestBody EtLocationLog etLocationLog)
{
return toAjax(etLocationLogService.insertEtLocationLog(etLocationLog));
}
/**
* 修改定位日志
*/
@PreAuthorize("@ss.hasPermi('system:locationLog:edit')")
@Log(title = "定位日志", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody EtLocationLog etLocationLog)
{
return toAjax(etLocationLogService.updateEtLocationLog(etLocationLog));
}
/**
* 删除定位日志
*/
@PreAuthorize("@ss.hasPermi('system:locationLog:remove')")
@Log(title = "定位日志", businessType = BusinessType.DELETE)
@DeleteMapping("/{locationIds}")
public AjaxResult remove(@PathVariable Long[] locationIds)
{
return toAjax(etLocationLogService.deleteEtLocationLogByLocationIds(locationIds));
}
}

View File

@ -9,7 +9,7 @@ public class LocationVo {
private String lat;//纬度
private Integer status;//电动车状态 0断电1上电运行 2轮动抱死 3超出区域断电远程下发了qlose
private Integer status;//电动车状态 0断电1上电运行 2轮动抱死 3超出区域断电远程下发了qlose 解析参数
private Integer bat;//电池电压 "bat":571 ==> 57.1V

View File

@ -44,4 +44,25 @@ public class AccessTokenUtil {
Long expirationTime = tokenExpirationTimes.get(cacheKey);
return expirationTime == null || System.currentTimeMillis() > expirationTime;
}
/**
* 强制刷新token
* */
@SneakyThrows
public static String getForceRefreshToken(String appid, String appsecret) {
String cacheKey = appid + ":" + appsecret;
log.info("强制获取token");
WxMaService wxMaService = new WxMaServiceImpl();
WxMaDefaultConfigImpl config = new WxMaDefaultConfigImpl();
config.setAppid(appid);
config.setSecret(appsecret);
wxMaService.setWxMaConfig(config);
String accessToken = wxMaService.getAccessToken(true);
// 更新缓存
cachedTokens.put(cacheKey, accessToken);
tokenExpirationTimes.put(cacheKey, System.currentTimeMillis() + TimeUnit.SECONDS.toMillis(3600L));
return accessToken;
}
}

View File

@ -33,7 +33,7 @@ import com.ruoyi.system.domain.SysOperLog;
/**
* 操作日志记录处理
*
*
* @author ruoyi
*/
@Aspect
@ -54,6 +54,7 @@ public class LogAspect
@Before(value = "@annotation(controllerLog)")
public void boBefore(JoinPoint joinPoint, Log controllerLog)
{
log.info("设置TIME_THREADLOCAL时间");
TIME_THREADLOCAL.set(System.currentTimeMillis());
}
@ -70,7 +71,7 @@ public class LogAspect
/**
* 拦截异常操作
*
*
* @param joinPoint 切点
* @param e 异常
*/
@ -117,8 +118,13 @@ public class LogAspect
operLog.setRequestMethod(ServletUtils.getRequest().getMethod());
// 处理设置注解上的参数
getControllerMethodDescription(joinPoint, controllerLog, operLog, jsonResult);
// 设置消耗时间
operLog.setCostTime(System.currentTimeMillis() - TIME_THREADLOCAL.get());
Long startTime = TIME_THREADLOCAL.get();
if (startTime != null) {
operLog.setCostTime(System.currentTimeMillis() - startTime);
} else {
log.warn("TIME_THREADLOCAL为空无法设置消耗时间。");
operLog.setCostTime(0L); // 你可以设置为0或其他合适的默认值
}
// 保存数据库
AsyncManager.me().execute(AsyncFactory.recordOper(operLog));
}
@ -136,7 +142,7 @@ public class LogAspect
/**
* 获取注解中对方法的描述信息 用于Controller层注解
*
*
* @param log 日志
* @param operLog 操作日志
* @throws Exception
@ -164,7 +170,7 @@ public class LogAspect
/**
* 获取请求的参数放到log中
*
*
* @param operLog 操作日志
* @throws Exception 异常
*/
@ -220,7 +226,7 @@ public class LogAspect
/**
* 判断是否需要过滤的对象
*
*
* @param o 对象信息
* @return 如果是需要过滤的对象则返回true否则返回false
*/

View File

@ -225,6 +225,12 @@ public class SysLoginService
String post = HttpUtils.sendPost(url,jsonObject.toString());
JSONObject jsonObject1 = JSONObject.parseObject(post);
if(jsonObject1.getInteger("errcode")!=0){// 如果token无效则重新获取一次最新的token
token = AccessTokenUtil.getForceRefreshToken(dept.getAppid(), dept.getAppSecret());
url = url+token;
post = HttpUtils.sendPost(url,jsonObject.toString());
jsonObject1 = JSONObject.parseObject(post);
}
String phoneInfo = jsonObject1.getString("phone_info");
WxMaPhoneNumberInfo wxMaPhoneNumberInfo = JSONObject.parseObject(phoneInfo, WxMaPhoneNumberInfo.class);
if(StringUtils.isEmpty(wxMaPhoneNumberInfo.getPhoneNumber())){

View File

@ -1,11 +1,8 @@
package com.ruoyi.system.domain;
import com.ruoyi.common.constant.ServiceConstants;
import lombok.Data;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.core.domain.BaseEntity;
import lombok.Data;
import java.util.Date;
@ -50,4 +47,19 @@ public class EtLocationLog extends BaseEntity
@Excel(name = "锁状态")
private String lockStatus;
@Excel(name = "电动车状态")
private Integer status2;//电动车状态 0断电1上电运行 2轮动抱死 3超出区域断电远程下发了qlose 解析参数
@Excel(name = "电池电压")
private Integer bat;//电池电压 "bat":571 ==> 57.1V
@Excel(name = "信号强度")
private Integer csq;//信号强度
@Excel(name = "卫星数量")
private Integer s;//卫星数量
@Excel(name = "钥匙")
private Integer q;//钥匙
}

View File

@ -61,6 +61,10 @@ public class EtModel extends BaseEntity
@Excel(name = "骑行低电量提醒")
private Integer lowBatteryReminder;
/** 骑行低电量提醒开关 */
@Excel(name = "骑行低电量提醒开关")
private Boolean lowBatteryReminderSwitch;
/** 已投放车辆数 */
private Integer deviceNum;

View File

@ -94,6 +94,10 @@ public class EtOrder extends BaseEntity
@TableField(exist = false)
private List<EtRefund> etRefunds;
/** 总退款金额 */
@TableField(exist = false)
private BigDecimal totalRefundFee;
/** 设备sn编码 */
@Excel(name = "设备sn编码")
private String sn;
@ -348,4 +352,7 @@ public class EtOrder extends BaseEntity
@Excel(name = "可退停车点外调度费退款")
@TableField(exist = false)
private BigDecimal refundableManageFee;
@Excel(name = "描述")
private String description;
}

View File

@ -5,15 +5,15 @@ import com.ruoyi.system.domain.EtLocationLog;
/**
* 定位日志Service接口
*
*
* @author ruoyi
* @date 2024-08-20
*/
public interface IEtLocationLogService
public interface IEtLocationLogService
{
/**
* 查询定位日志
*
*
* @param locationId 定位日志主键
* @return 定位日志
*/
@ -21,7 +21,7 @@ public interface IEtLocationLogService
/**
* 查询定位日志列表
*
*
* @param etLocationLog 定位日志
* @return 定位日志集合
*/
@ -29,7 +29,7 @@ public interface IEtLocationLogService
/**
* 新增定位日志
*
*
* @param etLocationLog 定位日志
* @return 结果
*/
@ -37,7 +37,7 @@ public interface IEtLocationLogService
/**
* 修改定位日志
*
*
* @param etLocationLog 定位日志
* @return 结果
*/
@ -45,7 +45,7 @@ public interface IEtLocationLogService
/**
* 批量删除定位日志
*
*
* @param locationIds 需要删除的定位日志主键集合
* @return 结果
*/
@ -53,9 +53,17 @@ public interface IEtLocationLogService
/**
* 删除定位日志信息
*
*
* @param locationId 定位日志主键
* @return 结果
*/
public int deleteEtLocationLogByLocationId(Long locationId);
/**
* 解析参数
*
* @param list
* @return 结果
*/
public List<EtLocationLog> analytic(List<EtLocationLog> list);
}

View File

@ -1,28 +1,32 @@
package com.ruoyi.system.service.impl;
import java.util.List;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.ruoyi.common.utils.DateUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ruoyi.system.mapper.EtLocationLogMapper;
import com.ruoyi.system.domain.EtLocationLog;
import com.ruoyi.system.service.IEtLocationLogService;
import javax.annotation.Resource;
/**
* 定位日志Service业务层处理
*
*
* @author ruoyi
* @date 2024-08-20
*/
@Service
public class EtLocationLogServiceImpl implements IEtLocationLogService
public class EtLocationLogServiceImpl implements IEtLocationLogService
{
@Autowired
@Resource
private EtLocationLogMapper etLocationLogMapper;
/**
* 查询定位日志
*
*
* @param locationId 定位日志主键
* @return 定位日志
*/
@ -34,7 +38,7 @@ public class EtLocationLogServiceImpl implements IEtLocationLogService
/**
* 查询定位日志列表
*
*
* @param etLocationLog 定位日志
* @return 定位日志
*/
@ -46,7 +50,7 @@ public class EtLocationLogServiceImpl implements IEtLocationLogService
/**
* 新增定位日志
*
*
* @param etLocationLog 定位日志
* @return 结果
*/
@ -59,7 +63,7 @@ public class EtLocationLogServiceImpl implements IEtLocationLogService
/**
* 修改定位日志
*
*
* @param etLocationLog 定位日志
* @return 结果
*/
@ -71,7 +75,7 @@ public class EtLocationLogServiceImpl implements IEtLocationLogService
/**
* 批量删除定位日志
*
*
* @param locationIds 需要删除的定位日志主键
* @return 结果
*/
@ -83,7 +87,7 @@ public class EtLocationLogServiceImpl implements IEtLocationLogService
/**
* 删除定位日志信息
*
*
* @param locationId 定位日志主键
* @return 结果
*/
@ -92,4 +96,51 @@ public class EtLocationLogServiceImpl implements IEtLocationLogService
{
return etLocationLogMapper.deleteEtLocationLogByLocationId(locationId);
}
/**
* 解析参数
*
* @param list
* @return 结果
*/
@Override
public List<EtLocationLog> analytic(List<EtLocationLog> list) {
// 创建 ObjectMapper 实例用于解析 JSON
ObjectMapper objectMapper = new ObjectMapper();
for (EtLocationLog log : list) {
try {
// 解析 onenetMsg 字段中的 JSON 字符串
JsonNode rootNode = objectMapper.readTree(log.getOnenetMsg());
JsonNode valueNode = rootNode.path("value");
// 提取各个字段的值并填充到 EtLocationLog 对象中
if (valueNode.has("status")) {
log.setStatus2(valueNode.get("status").asInt());
}
if (valueNode.has("bat")) {
// 电池电压例如 bat: 511 表示 51.1V
log.setBat(valueNode.get("bat").asInt());
}
if (valueNode.has("csq")) {
// 信号强度
log.setCsq(valueNode.get("csq").asInt());
}
if (valueNode.has("s")) {
// 卫星数量
log.setS(valueNode.get("s").asInt());
}
if (valueNode.has("q")) {
// 钥匙状态
log.setQ(valueNode.get("q").asInt());
}
} catch (Exception e) {
// 捕获并打印解析异常信息
e.printStackTrace();
}
}
return list;
}
}

View File

@ -1,8 +1,10 @@
package com.ruoyi.system.service.impl;
import cn.hutool.core.util.ObjectUtil;
import com.alibaba.fastjson2.JSON;
import com.ruoyi.common.annotation.DataScope;
import com.ruoyi.common.constant.IotConstants;
import com.ruoyi.common.constant.ServiceConstants;
import com.ruoyi.common.core.domain.entity.SysDept;
import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.utils.CommonUtil;
@ -10,10 +12,7 @@ import com.ruoyi.common.utils.DateUtils;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.common.utils.onenet.ResponseVo;
import com.ruoyi.common.utils.onenet.Token;
import com.ruoyi.system.domain.AsDevice;
import com.ruoyi.system.domain.EtModel;
import com.ruoyi.system.domain.EtModelRule;
import com.ruoyi.system.domain.EtOperatingArea;
import com.ruoyi.system.domain.*;
import com.ruoyi.system.mapper.AsDeviceMapper;
import com.ruoyi.system.mapper.EtModelMapper;
import com.ruoyi.system.mapper.EtModelRuleMapper;
@ -28,7 +27,12 @@ import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.util.List;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
/**
* 车辆型号Service业务层处理
@ -55,6 +59,12 @@ public class EtModelServiceImpl implements IEtModelService
@Resource
private EtModelRuleMapper etModelRuleMapper;
@Resource
private AsDeviceMapper asDeviceMapper;
@Autowired
private ScheduledExecutorService scheduledExecutorService;
/**
* 查询车辆型号
@ -128,6 +138,10 @@ public class EtModelServiceImpl implements IEtModelService
etModelRuleMapper.insert(EtModelRule.builder().modelId(etModel.getModelId()).ruleId(ruleId).build());
}
}
// Java报错:No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
if(!etModel.getLowBatteryReminderSwitch()){// 提醒关闭时发送低电压命令 为0
asynchronousSendCommand(etModel.getModelId());
}
// // 发送设置低电压命令
// Integer lowBatteryReminder = etModel.getLowBatteryReminder();
@ -174,6 +188,9 @@ public class EtModelServiceImpl implements IEtModelService
}
}
}
if(!etModel.getLowBatteryReminderSwitch()){// 提醒关闭时发送低电压命令 为0
asynchronousSendCommand(etModel.getModelId());
}
// 发送设置低电压命令
// Integer lowBatteryReminder = etModel.getLowBatteryReminder();
// if(ObjectUtil.isNotNull(lowBatteryReminder) && lowBatteryReminder > 0){
@ -194,6 +211,36 @@ public class EtModelServiceImpl implements IEtModelService
return i;
}
/**
* 异步发送低电压命令
*/
private void asynchronousSendCommand(Long modelId) {
//开异步线程
scheduledExecutorService.schedule(() -> {
AsDevice device = new AsDevice();
device.setModelId(modelId);
List<AsDevice> asDevices = asDeviceMapper.selectAsDeviceList(device);
for(AsDevice asDevice: asDevices){
// 根据百分比计算提醒电压值
String lowVoltageCommand = IotConstants.COMMAND_BAT + 0 + "@";
log.info("发送低电压命令:" + lowVoltageCommand);
ResponseVo responseVo = null;
try {
responseVo = asDeviceService.sendCommandWithResp(asDevice.getMac(), Token.getToken(), lowVoltageCommand,"发送低电压播报",null);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
e.printStackTrace();
}
if(responseVo.getCode()!=0){
log.info("【还车关锁】设备【{}】远程关锁失败", asDevice.getMac());
}
}
}, 0, TimeUnit.SECONDS);
}
/**
* 批量删除车辆型号
*

View File

@ -3,6 +3,7 @@ package com.ruoyi.system.service.impl;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson2.JSON;
import com.alibaba.fastjson2.JSONObject;
import com.ruoyi.common.annotation.DataScope;
import com.ruoyi.common.constant.Constants;
import com.ruoyi.common.constant.IotConstants;
@ -141,6 +142,7 @@ public class EtOrderServiceImpl implements IEtOrderService
AsDevice device = asDeviceMapper.selectAsDeviceBySn(order.getSn());
order.setDevice(device);
EtFeeRule etFeeRule = etFeeRuleService.selectEtFeeRuleByRuleIdIncludeDelete(order.getRuleId());
setDescription(order);
String endTime;
if(ObjectUtil.isNull(order.getReturnTime())){
endTime = DateUtils.parseDateToStr(DateUtils.YYYY_MM_DD_HH_MM_SS, DateUtils.getNowDate());
@ -166,6 +168,24 @@ public class EtOrderServiceImpl implements IEtOrderService
return order;
}
private void setDescription(EtOrder order) {
StringBuilder sb = new StringBuilder();
String ridingRuleJson = order.getRidingRuleJson();
String unit = "";
if(order.getRidingRule() != null && order.getRidingRule().equals("1")){
StartingRuleVo startingRule = JSONObject.parseObject(ridingRuleJson, StartingRuleVo.class);
String rentalUnit = order.getRentalUnit();
if(rentalUnit.equals(ServiceConstants.RENTAL_UNIT_MINUTES)){
unit = "分钟";
}else if(rentalUnit.equals(ServiceConstants.RENTAL_UNIT_HOURS)){
unit = "小时";
}
sb.append("起步价:"+startingRule.getStartingPrice()+"元(含"+startingRule.getStartingTime()+unit+"),");
sb.append("超出价:"+startingRule.getTimeoutPrice()+"元/"+startingRule.getTimeoutTime()+unit);
}
order.setDescription(sb.toString());
}
/**
* 根据订单号查询订单
*
@ -310,14 +330,18 @@ public class EtOrderServiceImpl implements IEtOrderService
}
List<EtOrder> etOrders = etOrderMapper.selectEtOrderList(etOrder);
//如果查询押金则增加退款记录
if(ServiceConstants.ORDER_TYPE_DEPOSIT.equals(etOrder.getType())){
etOrders.forEach(etOrder1 -> {
List<EtRefund> refund = etRefundService.selectEtRefundByOrderNo(etOrder1.getOrderNo());
if(ObjectUtil.isNotNull(refund) && refund.size() > 0){
etOrder1.setEtRefund(refund.get(0));
}
});
}
etOrders.forEach(etOrder1 -> {
List<EtRefund> refunds = etRefundService.selectEtRefundByOrderNo(etOrder1.getOrderNo());
if(ObjectUtil.isNotNull(refunds) && refunds.size() > 0){
etOrder1.setEtRefund(refunds.get(0));
etOrder1.setEtRefunds(refunds);
// 计算总的退款金额
BigDecimal totalRefundFee = refunds.stream()
.map(EtRefund::getAmount)
.reduce(BigDecimal.ZERO, BigDecimal::add);
etOrder1.setTotalRefundFee(totalRefundFee);
}
});
return etOrders;
}
@ -532,6 +556,7 @@ public class EtOrderServiceImpl implements IEtOrderService
if(deposit.compareTo(ridingFee) <= 0){
afterDeductionFee = BigDecimal.ZERO;
mark = "押金抵扣成功,骑行费【"+ridingFee+"】大于押金【"+deposit+"";
order.setPayFee(deposit);//实际支付金额等于押金
}else{
// 押金大于订单金额 扣除后
afterDeductionFee = deposit.subtract(ridingFee);
@ -1832,6 +1857,19 @@ public class EtOrderServiceImpl implements IEtOrderService
if(ObjectUtil.isNotNull(etCoupon)){
order.setCoupon(etCoupon);
}
// 骑行结束并且订单金额等于0并且未支付
if(ServiceConstants.ORDER_STATUS_RIDING_END.equals(order.getStatus()) && order.getTotalFee().compareTo(BigDecimal.ZERO) == 0 && order.getPaid().equals(ServiceConstants.ORDER_PAY_STATUS_NON_PAYMENT)){
order.setPaid(ServiceConstants.ORDER_PAY_STATUS_PAID);
order.setPayTime(new Date());
order.setPayType(ServiceConstants.PAY_TYPE_SYS);
order.setStatus(ServiceConstants.ORDER_STATUS_ORDER_END);
int updateEtOrder = etOrderMapper.updateEtOrder(order);
if(updateEtOrder == 0){
throw new ServiceException("更新订单outTradeNo失败");
}else {
log.info("【isInOrder接口】更新订单outTradeNo成功");
}
}
}
return inOrder;
}

View File

@ -14,6 +14,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<result property="lowVoltage" column="low_voltage" />
<result property="fullEndurance" column="full_endurance" />
<result property="lowBatteryReminder" column="low_battery_reminder" />
<result property="lowBatteryReminderSwitch" column="low_battery_reminder_switch" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
@ -22,12 +23,12 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</resultMap>
<sql id="selectEtModelVo">
select model_id, model, brand, operator, area_id, full_voltage, low_voltage, full_endurance, low_battery_reminder, create_by, create_time, update_by, update_time, remark from et_model
select model_id, model, brand, operator, area_id, full_voltage, low_voltage, full_endurance, low_battery_reminder, low_battery_reminder_switch, create_by, create_time, update_by, update_time, remark from et_model
</sql>
<select id="selectEtModelList" parameterType="EtModel" resultMap="EtModelResult">
select m.model_id, m.model, m.brand, m.operator, m.full_voltage, m.low_voltage,m.area_id,a.area_name areaName,
m.full_endurance, m.low_battery_reminder, m.create_by, m.create_time,
m.full_endurance, m.low_battery_reminder, m.low_battery_reminder_switch, m.create_by, m.create_time,
m.update_by, m.update_time, m.remark from et_model m
left join sys_dept d on d.dept_id = m.operator
left join et_operating_area a on a.area_id = m.area_id
@ -42,7 +43,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<select id="selectEtModelByModelId" parameterType="Long" resultMap="EtModelResult">
select m.model_id, m.model, m.brand, m.operator, d.dept_name, m.full_voltage, m.low_voltage,m.area_id,
m.full_endurance, m.low_battery_reminder, m.create_by, m.create_time,
m.full_endurance, m.low_battery_reminder, m.low_battery_reminder_switch, m.create_by, m.create_time,
m.update_by, m.update_time, m.remark from et_model m
left join sys_dept d on d.dept_id = m.operator
where m.model_id = #{modelId}
@ -64,6 +65,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="lowVoltage != null">low_voltage,</if>
<if test="fullEndurance != null">full_endurance,</if>
<if test="lowBatteryReminder != null">low_battery_reminder,</if>
<if test="lowBatteryReminderSwitch != null">low_battery_reminder_switch,</if>
<if test="createBy != null">create_by,</if>
<if test="createTime != null">create_time,</if>
<if test="updateBy != null">update_by,</if>
@ -80,6 +82,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="lowVoltage != null">#{lowVoltage},</if>
<if test="fullEndurance != null">#{fullEndurance},</if>
<if test="lowBatteryReminder != null">#{lowBatteryReminder},</if>
<if test="lowBatteryReminderSwitch != null">#{lowBatteryReminderSwitch},</if>
<if test="createBy != null">#{createBy},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateBy != null">#{updateBy},</if>
@ -99,6 +102,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
<if test="lowVoltage != null">low_voltage = #{lowVoltage},</if>
<if test="fullEndurance != null">full_endurance = #{fullEndurance},</if>
<if test="lowBatteryReminder != null">low_battery_reminder = #{lowBatteryReminder},</if>
<if test="lowBatteryReminderSwitch != null">low_battery_reminder_switch = #{lowBatteryReminderSwitch},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>