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.

133 lines
4.4 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 id,ConveyorNo,TaskNo,FlightNo,DeliverAGVNo, MAX(StartTime) as StartTime,TaskState, TotalCount ,LoadCount FROM AirportTask group by ConveyorNo ";
//taskInfos = base._rep.AsTenant().GetConnection("AGV").Ado.SqlQuery<AirportTask>(sql);
taskInfos = _rep.GetList();
}
catch (Exception ex)
{
_logger.LogError($"获取任务信息异常:{ex.Message}");
}
return taskInfos;
}
/// <summary>
/// 获取所有的任务信息
/// </summary>
/// <returns></returns>
public List<AirportTask> GetTaskInfos(Expression<Func<AirportTask, bool>> expression)
{
List<AirportTask> taskInfos = null;
try
{
//string sql = "SELECT id,ConveyorNo,TaskNo,FlightNo,DeliverAGVNo, MAX(StartTime) as StartTime,TaskState, TotalCount ,LoadCount FROM AirportTask group by ConveyorNo ";
//taskInfos = base._rep.AsTenant().GetConnection("AGV").Ado.SqlQuery<AirportTask>(sql);
taskInfos = _rep.GetList(expression);
}
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 *from ( SELECT id, ConveyorNo,TaskNo,FlightNo,DeliverAGVNo, amragvno,MAX(StartTime) as StartTime,TaskState, TotalCount ,LoadCount FROM AirportTask group by ConveyorNo )";
//taskInfos = base._rep.AsTenant().GetConnection("AGV").Ado.SqlQuery<AirportTask>(sql);
taskInfos = _rep.GetList();
}
catch (Exception ex)
{
_logger.LogError($"获取AGV任务信息异常:{ex.Message}");
}
return taskInfos;
}
public async Task<List<AirportTask>> GetTaskInfoListAsync(string ConveyorNo)
{
List<AirportTask> list = null;
list = await _rep.GetListAsync(x=>x.conveyorno == ConveyorNo);
return list;
}
public async Task<bool> UpdateTaskAsync(AirportTask record)
{
bool result = await _rep.UpdateAsync(record);
return result;
}
public async Task<bool> AddTaskAsync(AirportTask record)
{
bool result = await _rep.InsertAsync(record);
return result;
}
public async Task<bool> DeleteTaskAsync(AirportTask record)
{
bool iFlag = await _rep.DeleteAsync(record);
return iFlag;
}
}
}