You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

91 lines
2.9 KiB
C#

using Microsoft.Extensions.Logging;
using SlnMesnac.Model.domain;
using SlnMesnac.Common;
using System;
using System.Collections.Generic;
using System.Linq.Expressions;
using System.Text;
using SlnMesnac.Repository.service.@base;
using System.Threading.Tasks;
#region << 版 本 注 释 >>
/*--------------------------------------------------------------------
* (c) 2024 WenJY
* CLR4.0.30319.42000
* LAPTOP-E0N2L34V
* SlnMesnac.Repository.service.Impl
* 496f8d2b-70e3-4a05-ae18-a9b0fcd06b82
*
* WenJY
* wenjy@mesnac.com
* 2024-03-27 21:58:35
* V1.0.0
*
*
*--------------------------------------------------------------------
*
*
*
*
* V1.0.0
*--------------------------------------------------------------------*/
#endregion << 版 本 注 释 >>
namespace SlnMesnac.Repository.service.Impl
{
public class AirportTaskServiceImpl : BaseServiceImpl<AirportTask>, IAirportTaskService
{
private ILogger<AirportTaskServiceImpl> _logger;
public AirportTaskServiceImpl(Repository<AirportTask> repository, ILogger<AirportTaskServiceImpl> logger):base(repository)
{
_logger = logger;
}
/// <summary>
/// 获取所有的任务信息
/// </summary>
/// <returns></returns>
public List<AirportTask> GetTaskInfos()
{
List<AirportTask> taskInfos = null;
try
{
String sql = "SELECT ConveyorNo,TaskNo,FlightNo,AGVNo,MAX(StartTime) as StartTime,TaskState, TotalCount ,LoadCount FROM AirportTask group by ConveyorNo ";
taskInfos = base._rep.AsTenant().GetConnection("AGV").Ado.SqlQuery<AirportTask>(sql);
}
catch (Exception ex)
{
_logger.LogError($"获取任务信息异常:{ex.Message}");
}
return taskInfos;
}
/// <summary>
/// 获取AGV任务信息
/// </summary>
/// <returns></returns>
public List<AirportTask> GetAGVTaskInfos()
{
List<AirportTask> taskInfos = null;
try
{
String sql = "SELECT id, ConveyorNo,TaskNo,FlightNo,AGVNo,MAX(StartTime) as StartTime,TaskState, TotalCount ,LoadCount FROM AirportTask WHERE AGVNo IS NULL and TaskState = '等待' group by ConveyorNo ";
taskInfos = base._rep.AsTenant().GetConnection("AGV").Ado.SqlQuery<AirportTask>(sql);
}
catch (Exception ex)
{
_logger.LogError($"获取AGV任务信息异常:{ex.Message}");
}
return taskInfos;
}
public async Task<bool> UpdateAsync(AirportTask record)
{
bool result = await _rep.UpdateAsync(record);
return result;
}
}
}