2024-06-13 16:23:37 +08:00
|
|
|
|
using Infrastructure.Attribute;
|
2024-06-13 17:03:54 +08:00
|
|
|
|
using Infrastructure.Extensions;
|
2024-06-13 16:23:37 +08:00
|
|
|
|
using System;
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
using System.Linq;
|
|
|
|
|
|
using System.Text;
|
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
using ZR.Model.MES.dev;
|
|
|
|
|
|
using ZR.Model.MES.dev.Dto;
|
|
|
|
|
|
using ZR.Service.MES.dev.IService;
|
|
|
|
|
|
|
|
|
|
|
|
namespace ZR.Service.MES.dev
|
|
|
|
|
|
{
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 设备数据分析
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
[AppService(ServiceType = typeof(IDeviceDataAnalysisServcie), ServiceLifetime = LifeTime.Transient)]
|
|
|
|
|
|
public class DeviceDataAnalysisService : BaseService<DeviceAccount>, IDeviceDataAnalysisServcie
|
|
|
|
|
|
{
|
2024-06-13 17:03:54 +08:00
|
|
|
|
public static List<DeviceType> FindAllLeafNodes(List<DeviceType> nodeList, int targetId)
|
|
|
|
|
|
{
|
|
|
|
|
|
List<int> childIds = new List<int> { targetId };
|
|
|
|
|
|
List<DeviceType> result = new List<DeviceType>();
|
|
|
|
|
|
|
|
|
|
|
|
while (childIds.Any())
|
|
|
|
|
|
{
|
|
|
|
|
|
int parentId = childIds.First();
|
|
|
|
|
|
childIds.RemoveAt(0);
|
|
|
|
|
|
|
|
|
|
|
|
List<int> children = nodeList.Where(n => n.ParentId == parentId).Select(n => n.Id).ToList();
|
|
|
|
|
|
if (children.Any())
|
|
|
|
|
|
{
|
|
|
|
|
|
childIds.AddRange(children);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
result.Add(nodeList.First(n => n.Id == parentId));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
|
}
|
2024-06-13 16:23:37 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 故障类型 pie
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="devicedefault"></param>
|
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
|
public List<DeviceStatusAnalysisResultDto> DefaultTypePie(DeviceDefaultDto devicedefault)
|
|
|
|
|
|
{
|
|
|
|
|
|
List<DeviceStatusAnalysisResultDto> resultList = new List<DeviceStatusAnalysisResultDto>();
|
2024-06-13 17:03:54 +08:00
|
|
|
|
int[] all_device_type_array = null;
|
|
|
|
|
|
if (devicedefault.DevicetTypeId>0)
|
|
|
|
|
|
{
|
|
|
|
|
|
List<DeviceType> all_device_type_list = FindAllLeafNodes(Context.Queryable<DeviceType>().ToList(), devicedefault.DevicetTypeId??0);
|
|
|
|
|
|
all_device_type_array=all_device_type_list.Select(it=>it.Id).ToArray();
|
|
|
|
|
|
}
|
2024-06-13 16:23:37 +08:00
|
|
|
|
var predicate = Expressionable.Create<DeviceRepair, DeviceAccount>()
|
2024-06-13 17:03:54 +08:00
|
|
|
|
.AndIF(all_device_type_array != null&& all_device_type_array.Length>0, (r, a) => all_device_type_array.Contains(a.FkDeviceType))
|
2024-06-13 16:23:37 +08:00
|
|
|
|
.AndIF(!string.IsNullOrEmpty(devicedefault.DeviceName), (r, a) => a.DeviceName.Contains(devicedefault.DeviceName))
|
|
|
|
|
|
.AndIF(!string.IsNullOrEmpty(devicedefault.DeviceCode), (r, a) => a.DeviceCode.Contains(devicedefault.DeviceCode))
|
2024-06-13 17:19:29 +08:00
|
|
|
|
.AndIF(devicedefault.searchTime[0] > new DateTime(1991, 1, 1), (r, a) => r.CreatedTime >= devicedefault.searchTime[0])
|
|
|
|
|
|
.AndIF(devicedefault.searchTime[1] > new DateTime(1991, 1, 1), (r, a) => r.CreatedTime <= devicedefault.searchTime[1]);
|
2024-06-13 16:23:37 +08:00
|
|
|
|
|
|
|
|
|
|
List<DeviceRepair> deviceRepair_list= Context.Queryable<DeviceRepair>()
|
|
|
|
|
|
.LeftJoin<DeviceAccount>((r, a) => r.FkDeviceId == a.Id)
|
|
|
|
|
|
.Where(predicate.ToExpression())
|
|
|
|
|
|
.Select((r,a)=>r).ToList();
|
|
|
|
|
|
|
2024-06-13 17:19:29 +08:00
|
|
|
|
if(deviceRepair_list.Count > 0)
|
2024-06-13 16:23:37 +08:00
|
|
|
|
{
|
2024-06-13 17:19:29 +08:00
|
|
|
|
var TypeGroups = deviceRepair_list.GroupBy(it => it.Type);
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var group in TypeGroups)
|
|
|
|
|
|
{
|
|
|
|
|
|
DeviceStatusAnalysisResultDto result = new DeviceStatusAnalysisResultDto();
|
|
|
|
|
|
result.name = group.Key;
|
|
|
|
|
|
result.value = group.Count();
|
|
|
|
|
|
resultList.Add(result);
|
|
|
|
|
|
}
|
2024-06-13 16:23:37 +08:00
|
|
|
|
}
|
2024-06-13 17:19:29 +08:00
|
|
|
|
|
2024-06-13 16:23:37 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return resultList;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|