RGVSystems.cs 60 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467
  1. using PlcSiemens.Core.Extension;
  2. using ServiceCenter.Extensions;
  3. using ServiceCenter.Logs;
  4. using ServiceCenter.SqlSugars;
  5. using SqlSugar;
  6. using System.ComponentModel;
  7. using WCS.Core;
  8. using WCS.Entity;
  9. using WCS.Entity.Protocol.BCR;
  10. using WCS.Entity.Protocol.RGV;
  11. using WCS.Entity.Protocol.Robot;
  12. using WCS.Entity.Protocol.Station;
  13. using WCS.Entity.Protocol.Truss;
  14. using WCS.WorkEngineering.Extensions;
  15. using WCS.WorkEngineering.Worlds;
  16. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  17. using TaskStatus = WCS.Entity.TaskStatus;
  18. using TaskType = WCS.Entity.TaskType;
  19. namespace WCS.WorkEngineering.Systems
  20. {
  21. /// <summary>
  22. /// RGV交互系统
  23. /// </summary>
  24. [BelongTo(typeof(RgvWorld))]
  25. [Description("RGV交互系统")]
  26. public class RGVSystems : DeviceSystem<Device<IRGV520, IRGV521, IBCR81>>
  27. {
  28. protected override bool ParallelDo => true;
  29. /// <summary>
  30. /// 取货点设备集合
  31. /// </summary>
  32. private readonly Dictionary<string, List<Device<IStation520, IStation521, IStation523>>> _pickUpDevices = new();
  33. public RGVSystems()
  34. {
  35. //获取所有的巷道集合
  36. var rgvList = Device.All.Where(v => v.HasFlag(DeviceFlags.RGV));
  37. foreach (var rgv in rgvList)
  38. {
  39. _pickUpDevices.Add(rgv.Code, rgv.Sources.Where(v => v.HasFlag(DeviceFlags.输送机)).Select(v => new Device<IStation520, IStation521, IStation523>(v, this.World)).ToList());
  40. }
  41. }
  42. public override void Do(Device<IRGV520, IRGV521, IBCR81> obj)
  43. {
  44. try
  45. {
  46. if (obj.Data.VoucherNo != obj.Data2.VoucherNo)
  47. {
  48. World.Log($"凭证号不一致,DB520:{obj.Data.VoucherNo}-DB521:{obj.Data2.VoucherNo}", LogLevelEnum.High);
  49. return;
  50. }
  51. if (obj.Data2.WorkMode != RGVWorkMode.Automatic)
  52. {
  53. World.Log(obj.Data2.WorkMode.GetDescription());
  54. return;
  55. }
  56. //wcs任务完成确认信号未清除
  57. if (obj.Data.RES1 == 1)
  58. {
  59. World.Log("wcs任务完成确认信号未清除");
  60. return;
  61. }
  62. if (obj.Data2.Status.HasFlag(RGVStatus.Taskfinishi))
  63. {
  64. switch (obj.Data2.CmdType)
  65. {
  66. case RGVCmdType.PickGoods: //单独取货任务完成,默认只有空托盘才会下发单独取货任务
  67. World.Log($"任务处理:开始-取货完成-任务号[{obj.Data2.TaskNumber}]起始地址[{obj.Data2.StartPosition}]目标地址[{obj.Data2.DestPosition}]");
  68. //开始申请读码信息
  69. var bcrCode = obj.Data3.GetBCRCode();
  70. if (bcrCode.IsNullOrWhiteSpace() || bcrCode.Contains(":"))
  71. {
  72. World.Log("扫码失败,内容为空", LogLevelEnum.Mid);
  73. return;
  74. }
  75. World.Log($"任务处理:扫码结果-{bcrCode}");
  76. var taskNumber = 0;
  77. SqlSugarHelper.Do(_db =>
  78. {
  79. var db = _db.Default;
  80. //检查库存表是否有残留库存信息
  81. if (db.Queryable<BillInvnow>().Any(x => x.ContGrpBarCode == bcrCode))
  82. {
  83. //删除库存
  84. var invNow = db.Queryable<BillInvnow>().Where(x => x.ContGrpBarCode == bcrCode).OrderByDescending(x => x.AddTime).First();
  85. if (invNow.IsTorsChk) //是一楼码垛入库
  86. {
  87. db.DeleteableRowLock(invNow).ExecuteCommand(); //删除库存
  88. var invInit = db.Queryable<BillInvinit>().Where(x => x.ContGrpBarCode == bcrCode).OrderByDescending(x => x.AddTime).First();
  89. db.DeleteableRowLock(invInit).ExecuteCommand();//删除条码
  90. var taskInfos = db.Queryable<WCS_TaskInfo>().Where(x => x.BarCode == bcrCode && x.Status == TaskStatus.NewBuild && x.BusType == "人工满托入库"
  91. || (x.BusType == "重绕满托入库" && x.Status == TaskStatus.WaitingToExecute)).ToList();
  92. if (!taskInfos.Any()) {
  93. World.Log($"未找到托盘条码{bcrCode}对应任务,请联系智能制造组人员确认", LogLevelEnum.Mid);
  94. return;
  95. }
  96. foreach (var task in taskInfos)
  97. {
  98. //取消任务
  99. task.Status = TaskStatus.Cancel;
  100. task.ManualRemarks = "托盘已使用,需在二楼组盘";
  101. db.Updateable(task).ExecuteCommand();
  102. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "", "取消任务");
  103. }
  104. }
  105. World.Log($"【{obj.Entity.Code}】上的托盘 【{bcrCode}】存在历史库存信息,请检查对应托盘条码是否存在未完成的出库任务!!!!!", LogLevelEnum.High);
  106. return;
  107. }
  108. var dev = Device.All.First(x => x.Code == obj.Data2.DestPosition.ToString());
  109. if (dev.HasFlag(DeviceFlags.桁架码垛位))
  110. {
  111. //开始绑定任务,并下发新的任务信息到小车
  112. var palletizingInfo = db.Queryable<WCS_Palletizing>().Single(x => x.Id == obj.Data2.TaskNumber);
  113. if (palletizingInfo == null)
  114. {
  115. World.Log($"未找到对应的码垛信息{obj.Data2.TaskNumber}", LogLevelEnum.Mid);
  116. return;
  117. }
  118. palletizingInfo.PalleCode = bcrCode;
  119. db.UpdateableRowLock(palletizingInfo).UpdateColumns(x => new { x.PalleCode }).ExecuteCommand();
  120. taskNumber = palletizingInfo.Id;
  121. World.Log($"任务处理:当前任务为桁架区域补空托任务");
  122. }
  123. else if (dev.HasFlag(DeviceFlags.环形库码垛工位))
  124. {
  125. //开始处理对应的搬运任务信息
  126. var task = db.Queryable<WCS_TaskInfo>().RowLock().First(x => x.Type == TaskType.Delivery && x.ID == obj.Data2.TaskNumber && x.AddrTo == obj.Data2.DestPosition.ToString());
  127. if (task == null)
  128. {
  129. World.Log($"未找到对应的搬运任务{obj.Data2.TaskNumber}", LogLevelEnum.Mid);
  130. return;
  131. }
  132. task.BarCode = bcrCode;
  133. db.UpdateableRowLock(task).UpdateColumns(x => new { x.BarCode }).ExecuteCommand();
  134. task.AddWCS_TASK_DTL(db, obj.Entity.Code, obj.Data2.DestPosition.ToString(), $"环形库码垛位{obj.Data2.DestPosition}搬运任务绑定条码信息{bcrCode}");
  135. taskNumber = task.ID;
  136. World.Log($"任务处理:当前任务为环形库区域补空托任务");
  137. }
  138. else //默认除了桁架码垛工位与环形库码垛工位外的任务就只有芯股用空托入库了
  139. {
  140. //开始处理对应的入库任务信息
  141. var task = db.Queryable<WCS_TaskInfo>().RowLock().First(x => x.Type == TaskType.EnterDepot && x.ID == obj.Data2.TaskNumber && x.AddrNext == obj.Data2.DestPosition.ToString());
  142. if (task == null)
  143. {
  144. World.Log($"未找到对应的空托入库任务{obj.Data2.TaskNumber}", LogLevelEnum.Mid);
  145. return;
  146. }
  147. task.BarCode = bcrCode;
  148. db.UpdateableRowLock(task).UpdateColumns(x => new { x.BarCode }).ExecuteCommand();
  149. task.AddWCS_TASK_DTL(db, obj.Entity.Code, obj.Data2.DestPosition.ToString(), $"空托入库任务绑定条码信息{bcrCode}");
  150. taskNumber = task.ID;
  151. World.Log($"任务处理:当前任务为芯股用空托入库");
  152. }
  153. });
  154. if (taskNumber == 0)
  155. {
  156. World.Log($"取货完成处理失败", LogLevelEnum.Mid);
  157. return;
  158. }
  159. //清空目标点信息
  160. var destDev = new Device<IStation520>(Device.All.FirstOrDefault(x => x.Code == obj.Data2.DestPosition.ToString())!, World);
  161. destDev.Data.TaskNumber = 0;
  162. destDev.Data.GoodsStart = 0;
  163. destDev.Data.GoodsEnd = 0;
  164. obj.Data2.TaskNumber = taskNumber;
  165. obj.Data.RES1 = 1;
  166. World.Log($"任务处理:结束-取货完成-任务号[{obj.Data2.TaskNumber}]起始地址[{obj.Data2.StartPosition}]目标地址[{obj.Data2.DestPosition}]");
  167. break;
  168. case RGVCmdType.PutGoods:
  169. Device destPosition = null;
  170. bool isPalletizing = false;
  171. try
  172. {
  173. World.Log($"任务处理:开始-放货完成-任务号[{obj.Data2.TaskNumber}]起始地址[{obj.Data2.StartPosition}]目标地址[{obj.Data2.DestPosition}]");
  174. WCS_TaskInfo finishiTask = null;
  175. var startPosition = Device.All.Where(x => x.Code == obj.Data2.StartPosition.ToString())
  176. .Select(x => new Device<IStation520, IStation521, IStation523>(x, World))
  177. .FirstOrDefault();
  178. destPosition = Device.All.FirstOrDefault(x => x.Code == obj.Data2.DestPosition.ToString());
  179. isPalletizing = destPosition!.HasFlag(DeviceFlags.桁架码垛位, DeviceFlags.环形库码垛工位);
  180. short countQty = 0;
  181. short shortCode = 0;
  182. SqlSugarHelper.Do(_db =>
  183. {
  184. var db = _db.Default;
  185. if (isPalletizing)
  186. {
  187. if (destPosition.HasFlag(DeviceFlags.桁架码垛位))
  188. {
  189. var palletizingInfo = db.Queryable<WCS_Palletizing>()
  190. .First(x => x.Id == obj.Data.TaskNumber);
  191. countQty = palletizingInfo.CountQty.ToShort();
  192. shortCode = palletizingInfo.ShortCode;
  193. World.Log($"任务处理:当前任务为桁架区域补空托任务");
  194. }
  195. else if (destPosition.HasFlag(DeviceFlags.环形库码垛工位))
  196. {
  197. var deliveryTask = db.Queryable<WCS_TaskInfo>().RowLock()
  198. .First(x => x.ID == obj.Data.TaskNumber);
  199. countQty = deliveryTask.FullQty;
  200. shortCode = deliveryTask.PalletType;
  201. deliveryTask.Status = TaskStatus.RgvCompleted;
  202. deliveryTask.EditTime = DateTime.Now;
  203. deliveryTask.LastInteractionPoint = obj.Entity.Code;
  204. db.Updateable(deliveryTask).UpdateColumns(x => new { x.Status, x.EditTime, x.LastInteractionPoint }).ExecuteCommand();
  205. deliveryTask.AddWCS_TASK_DTL(db, deliveryTask.AddrTo, $"RGV任务执行结束");
  206. World.Log($"任务处理:当前任务为环形库区域补空托任务");
  207. }
  208. }
  209. else
  210. {
  211. var taskInfo = db.Queryable<WCS_TaskInfo>().RowLock().First(x => x.ID == obj.Data.TaskNumber);
  212. taskInfo.Status = TaskStatus.RgvCompleted;
  213. taskInfo.EditTime = DateTime.Now;
  214. taskInfo.LastInteractionPoint = obj.Entity.Code;
  215. db.Updateable(taskInfo).UpdateColumns(x => new { x.Status, x.EditTime, x.LastInteractionPoint }).ExecuteCommand();
  216. taskInfo.AddWCS_TASK_DTL(db, taskInfo.AddrTo, $"RGV任务执行结束");
  217. World.Log($"任务处理:当前任务为芯股用空托入库");
  218. }
  219. });
  220. if (startPosition.Data.TaskNumber == obj.Data.TaskNumber) //初始化起始点信息
  221. {
  222. startPosition.Data.TaskNumber = 0;
  223. startPosition.Data.GoodsEnd = 0;
  224. World.Log($"任务处理:初始化取货点{startPosition.Entity.Code}任务及目标地址信息");
  225. }
  226. //目标地址是码垛工位
  227. if (isPalletizing)
  228. {
  229. if (destPosition.HasFlag(DeviceFlags.桁架码垛位))
  230. {
  231. var dest = new Device<ITruss530, ITruss531>(destPosition!, World);
  232. if (dest.Data2.MaxQuantity == 0)
  233. {
  234. dest.Data.MaxQuantity = countQty;
  235. dest.Data.Quantity = 0;
  236. dest.Data.Type = shortCode;
  237. dest.Data.VoucherNo++;
  238. World.Log($"任务处理:写入码垛信息-码垛位[{dest.Entity.Code}]最大码垛数量[{dest.Data.MaxQuantity}]已码数量[{dest.Data.Quantity}]垛形[{dest.Data.Type}]凭证号[{dest.Data.VoucherNo}]");
  239. }
  240. else
  241. {
  242. World.Log($"桁架垛型信息未清除,无法写入新垛型信息请检查确认,最大码垛数量[{dest.Data.MaxQuantity}]已码数量[{dest.Data.Quantity}]垛形[{dest.Data.Type}]凭证号[{dest.Data.VoucherNo}]", LogLevelEnum.Mid);
  243. return;
  244. }
  245. }
  246. else if (destPosition.HasFlag(DeviceFlags.环形库码垛工位))
  247. {
  248. var dest = new Device<IRobot530>(destPosition!, World);
  249. dest.Data.MaxQuantity = countQty;
  250. dest.Data.Type = shortCode;
  251. dest.Data.VoucherNo++;
  252. World.Log($"任务处理:写入码垛信息-码垛位[{dest.Entity.Code}]最大码垛数量[{dest.Data.MaxQuantity}]垛形[{dest.Data.Type}]凭证号[{dest.Data.VoucherNo}]");
  253. }
  254. }
  255. }
  256. catch (Exception e)
  257. {
  258. World.Log($"处理小车放货完成是出现错误:{e.Message}-{e.StackTrace}");
  259. return;
  260. }
  261. obj.Data.RES1 = 1;
  262. World.Log($"任务处理:结束-放货完成-任务号[{obj.Data2.TaskNumber}]起始地址[{obj.Data2.StartPosition}]目标地址[{obj.Data2.DestPosition}]");
  263. break;
  264. case RGVCmdType.Move:
  265. World.Log($"任务处理:开始-移动完成-任务号[{obj.Data2.TaskNumber}]目标地址[{obj.Data2.DestPosition}]");
  266. obj.Data.RES1 = 1;
  267. World.Log($"任务处理:结束-移动完成-任务号[{obj.Data2.TaskNumber}]目标地址[{obj.Data2.DestPosition}]");
  268. break;
  269. case RGVCmdType.ChangePutGoods:
  270. break;
  271. case RGVCmdType.ChangePickGoods:
  272. break;
  273. case RGVCmdType.PickPutGoods:
  274. World.Log($"任务处理:开始-取放货完成-任务号[{obj.Data2.TaskNumber}]起始地址[{obj.Data2.StartPosition}]目标地址[{obj.Data2.DestPosition}]");
  275. var statDev = Device.All.FirstOrDefault(x => x.Code == obj.Data.StartPosition.ToString());
  276. var stDev = new Device<IStation520, IStation521>(Device.All.FirstOrDefault(x => x.Code == obj.Data.StartPosition.ToString())!, World);
  277. stDev.Data.TaskNumber = 0;
  278. stDev.Data.GoodsStart = 0;
  279. stDev.Data.GoodsEnd = 0;
  280. World.Log($"任务处理:清除目标地址信息-目标货位{stDev.Entity.Code}");
  281. obj.Data.RES1 = 1;
  282. World.Log($"任务处理:结束-取放货完成-任务号[{obj.Data2.TaskNumber}]起始地址[{obj.Data2.StartPosition}]目标地址[{obj.Data2.DestPosition}]");
  283. break;
  284. default:
  285. throw new ArgumentOutOfRangeException();
  286. }
  287. return;
  288. }
  289. if (obj.Data2.SystemStatus != RGVSystemStatus.空闲)
  290. {
  291. World.Log(obj.Data2.SystemStatus.GetDescription());
  292. return;
  293. }
  294. if (obj.Data2.CmdType == RGVCmdType.PickGoods && !obj.Data2.Status.HasFlag(RGVStatus.Taskfinishi))
  295. {
  296. if (obj.Data2.Status.HasFlag(RGVStatus.PH_Status))
  297. {
  298. World.Log($"任务处理:开始-下发放货任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]起始地址[{obj.Data.StartPosition}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  299. obj.Data.TaskNumber = obj.Data.TaskNumber;
  300. obj.Data.CmdType = RGVCmdType.PutGoods;
  301. obj.Data.StartPosition = obj.Data2.StartPosition;
  302. obj.Data.DestPosition = obj.Data2.DestPosition;
  303. obj.Data.VoucherNo++;
  304. World.Log($"任务处理:结束-下发放货任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]起始地址[{obj.Data.StartPosition}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  305. return;
  306. }
  307. }
  308. var pickUpDevices = _pickUpDevices.FirstOrDefault(x => x.Key == obj.Entity.Code).Value;
  309. //有货且需要搬运货物的站台
  310. var devs = pickUpDevices.Where(v => v.Data3.Status.HasFlag(StationStatus.PH_Status) && v.Data.TaskNumber != 0)
  311. .Where(v => v.Entity.Code.ToShort() != v.Data.GoodsEnd && v.Data.GoodsEnd != 0)
  312. .ToList();
  313. //筛选出目标站台无货的站台
  314. var putDev = obj.Entity.Targets.Where(x => x.HasFlag(DeviceFlags.输送机))
  315. .Select(x => new Device<IStation520, IStation521, IStation523>(x, World))
  316. .Where(x => !x.Data3.Status.HasFlag(StationStatus.PH_Status))
  317. .Where(x => !x.Data3.Status.HasFlag(StationStatus.OT_Status))
  318. .Select(x => x.Entity.Code.ToShort());
  319. //var devList = devs.OrderBy(x => x.Entity.Code).Where(x => putDev.Contains(x.Data.GoodsEnd));
  320. var devList = devs.OrderBy(x => x.Data.TaskNumber).Where(x => putDev.Contains(x.Data.GoodsEnd));
  321. if (!devList.Any())
  322. {
  323. World.Log($"无可用任务");
  324. }
  325. foreach (var dev in devList)
  326. {
  327. //区分任务是拆盘机到码垛工位,还是码垛工位到拆盘机
  328. if (dev.Entity.HasFlag(DeviceFlags.拆盘机))
  329. {
  330. World.Log($"任务处理:开始-下发取货任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]RGV运行状态[{obj.Data2.WorkMode.GetDescription()}]起始地址[{obj.Data.StartPosition}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  331. obj.Data.TaskNumber = dev.Data.TaskNumber;
  332. obj.Data.CmdType = RGVCmdType.PickGoods;
  333. obj.Data.StartPosition = dev.Entity.Code.ToShort();
  334. obj.Data.DestPosition = dev.Data.GoodsEnd;
  335. obj.Data.VoucherNo++;
  336. World.Log($"任务处理:结束-下发取货任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]起始地址[{obj.Data.StartPosition}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  337. return;
  338. }
  339. //if (dev.Entity.HasFlag(DeviceFlags.二次码垛RGV取货口))
  340. //{
  341. // obj.Data.TaskNumber = dev.Data.TaskNumber;
  342. // obj.Data.CmdType = RGVCmdType.PickPutGoods;
  343. // obj.Data.StartPosition = dev.Entity.Code.ToShort();
  344. // obj.Data.DestPosition = dev.Data.GoodsEnd;
  345. // obj.Data.VoucherNo++;
  346. // return;
  347. //}
  348. World.Log($"任务处理:开始-下发满托入库任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]RGV运行状态[{obj.Data2.WorkMode.GetDescription()}]起始地址[{obj.Data.StartPosition}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  349. //非拆盘机起始任务
  350. //站台中的任务号
  351. WCS_TaskInfo task = null;
  352. SqlSugarHelper.Do(_db =>
  353. {
  354. var db = _db.Default;
  355. var taskInfo = db.Queryable<WCS_TaskInfo>().First(p => p.ID == dev.Data.TaskNumber && p.Status == TaskStatus.ConveyorExecution);
  356. if (taskInfo == null)
  357. {
  358. World.Log($"任务处理:未找到对应的任务{dev.Entity.Code}--{dev.Data.TaskNumber}-1");
  359. return;
  360. }
  361. taskInfo.Status = TaskStatus.RgvExecution;
  362. taskInfo.AddrNext = obj.Entity.Code;
  363. taskInfo.EditWho = "WCS";
  364. taskInfo.EditTime = DateTime.Now; ;
  365. db.UpdateableRowLock(taskInfo).UpdateColumns(x => new { x.Status, x.AddrNext, x.EditWho, x.EditTime }).ExecuteCommand();
  366. taskInfo.AddWCS_TASK_DTL(db, dev.Entity.Code, obj.Entity.Code, $"任务分配至{obj.Entity.Code}");
  367. task = taskInfo;
  368. });
  369. if (task == null)
  370. {
  371. World.Log($"任务处理:未找到对应的任务{dev.Entity.Code}--{dev.Data.TaskNumber}-2");
  372. return;
  373. }
  374. World.Log($"任务处理:满托入库业务流程处理完成-任务[{task.ID}]状态已变更为[{task.Status}]开始准备写入PLC");
  375. obj.Data.TaskNumber = task.ID;
  376. obj.Data.CmdType = RGVCmdType.PickPutGoods;
  377. obj.Data.StartPosition = dev.Entity.Code.ToShort();
  378. obj.Data.DestPosition = dev.Data.GoodsEnd;
  379. obj.Data.VoucherNo++;
  380. World.Log($"任务处理:结束-下发满托入库任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]起始地址[{obj.Data.StartPosition}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  381. return;
  382. }
  383. if (obj.Data2.Status.HasFlag(RGVStatus.RES1)) //离开非安全区域
  384. {
  385. World.Log($"任务处理:开始-下发移动任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  386. obj.Data.TaskNumber = obj.Data.TaskNumber;
  387. obj.Data.CmdType = RGVCmdType.Move;
  388. obj.Data.DestPosition = obj.Entity.Code switch
  389. {
  390. "RGV1" => 1668,
  391. "RGV2" => 1683,
  392. "RGV3" => 1698,
  393. "RGV4" => 1713,
  394. "RGV5" => 1728,
  395. "RGV6" => 1743,
  396. _ => throw new ArgumentOutOfRangeException()
  397. };
  398. obj.Data.VoucherNo++;
  399. World.Log($"任务处理:结束-下发移动任务-任务号[{obj.Data.TaskNumber}]任务类型[{obj.Data.CmdType}]目标地址[{obj.Data.DestPosition}]凭证号[{obj.Data.VoucherNo}]");
  400. return;
  401. }
  402. }
  403. catch (Exception ex)
  404. {
  405. if (ex.Message == "Destination array was not long enough. Check the destination index, length, and the array's lower bounds")
  406. {
  407. World.Log($"未知异常:{ex.StackTrace}");
  408. }
  409. else if (ex.Message == "Number was less than the array's lower bound in the first dimension")
  410. {
  411. World.Log($"未知异常:{ex.StackTrace}");
  412. }
  413. else throw new KnownException(ex.Message, LogLevelEnum.Mid);
  414. }
  415. }
  416. public override bool Select(Device dev)
  417. {
  418. return dev.Code is "RGV1" or "RGV2" or "RGV3" or "RGV4" or "RGV5" or "RGV6";
  419. //return dev.HasFlag(Extensions.DeviceFlags.RGV);
  420. }
  421. }
  422. /// <summary>
  423. /// 库存表
  424. /// </summary>
  425. [SugarTable("Bill_InvNow")]
  426. public partial class BillInvnow : BaseModel
  427. {
  428. /// <summary>
  429. /// 仓库ID 关联仓库表 ID
  430. /// </summary>
  431. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  432. public long WarehouseId { get; set; }
  433. /// <summary>
  434. /// 组盘ID
  435. /// 创建库存的时候 获取条码表ContGrpId
  436. /// </summary>
  437. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  438. public long ContGrpId { get; set; }
  439. /// <summary>
  440. /// 容器条码 同联容器表容器条码 ContBarCode
  441. /// </summary>
  442. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  443. public string ContGrpBarCode { get; set; }
  444. /// <summary>
  445. /// 组盘类型(1物料盘 2空盘)
  446. /// </summary>
  447. [SugarColumn(IsNullable = true)]
  448. public FJContGrpType ContGrpType { get; set; }
  449. /// <summary>
  450. /// 箱条码
  451. /// </summary>
  452. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  453. public string BoxBarCode { get; set; }
  454. /// <summary>
  455. /// Bom单号 关联投料单 帘线工序工单号 BillCode
  456. /// </summary>
  457. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  458. public string BomDocsNo { get; set; }
  459. /// <summary>
  460. /// Bom物料ID
  461. /// </summary>
  462. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  463. public long BomMatId { get; set; }
  464. /// <summary>
  465. /// Bom物料编号
  466. /// </summary>
  467. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  468. public string BomMatCode { get; set; }
  469. /// <summary>
  470. /// Bom物料
  471. /// </summary>
  472. [SugarColumn(ColumnDataType = "nvarchar", Length = 100, IsNullable = true)]
  473. public string BomMatName { get; set; }
  474. /// <summary>
  475. /// 垛形主表 ID
  476. /// </summary>
  477. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  478. public long BomSetId { get; set; }
  479. /// <summary>
  480. /// 垛型编码
  481. /// </summary>
  482. [SugarColumn(ColumnDataType = "nvarchar", Length = 100, IsNullable = true)]
  483. public string SetGrpCode { get; set; }
  484. /// <summary>
  485. /// 库存状态码
  486. /// </summary>
  487. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  488. public string ExecStateCode { get; set; }
  489. /// <summary>
  490. /// 单据编号 关联单据表单据编号 DocsNo
  491. /// </summary>
  492. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  493. public string ExecDocsNo { get; set; }
  494. /// <summary>
  495. /// 单据行号
  496. /// </summary>
  497. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  498. public string ExecDocsRowNo { get; set; }
  499. /// <summary>
  500. /// 单据类型编号 同单据表TypeNum
  501. /// </summary>
  502. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  503. public string ExecDocsTypeCode { get; set; }
  504. /// <summary>
  505. /// 出入库标识
  506. /// </summary>
  507. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  508. public FJInvInOutType InvInOut { get; set; }
  509. /// <summary>
  510. /// 执行人
  511. /// </summary>
  512. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  513. public string ExecWho { get; set; }
  514. /// <summary>
  515. /// 执行时间
  516. /// </summary>
  517. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  518. public DateTime ExecTime { get; set; }
  519. /// <summary>
  520. /// 行
  521. /// </summary>
  522. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  523. public int PutRow { get; set; }
  524. /// <summary>
  525. /// 列
  526. /// </summary>
  527. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  528. public int PutCol { get; set; }
  529. /// <summary>
  530. /// 层
  531. /// </summary>
  532. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  533. public int PutLayer { get; set; }
  534. /// <summary>
  535. /// 入库条码号 FJ材料号
  536. /// </summary>
  537. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  538. public string InvBarCode { get; set; }
  539. /// <summary>
  540. /// 库存状态
  541. /// </summary>
  542. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  543. public string InvStateCode { get; set; }
  544. /// <summary>
  545. /// 入库单号
  546. /// </summary>
  547. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  548. public string InDocsNo { get; set; }
  549. /// <summary>
  550. /// 入库单行号
  551. /// </summary>
  552. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  553. public string InDocsRowNo { get; set; }
  554. /// <summary>
  555. /// 供应编号
  556. /// </summary>
  557. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  558. public string SuppCode { get; set; }
  559. /// <summary>
  560. /// 供应商名称
  561. /// </summary>
  562. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  563. public string SuppName { get; set; }
  564. /// <summary>
  565. /// 海关编号
  566. /// </summary>
  567. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  568. public string CustCode { get; set; }
  569. /// <summary>
  570. /// 海关名称
  571. /// </summary>
  572. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  573. public string CustName { get; set; }
  574. /// <summary>
  575. /// 物料ID
  576. /// </summary>
  577. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  578. public long MatId { get; set; }
  579. /// <summary>
  580. /// 物料编号
  581. /// </summary>
  582. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  583. public string MatCode { get; set; }
  584. /// <summary>
  585. /// 物料名称
  586. /// </summary>
  587. [SugarColumn(ColumnDataType = "nvarchar", Length = 100, IsNullable = true)]
  588. public string MatName { get; set; }
  589. /// <summary>
  590. /// 总重量
  591. /// </summary>
  592. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  593. public decimal TolWQty { get; set; }
  594. /// <summary>
  595. /// 净重
  596. /// </summary>
  597. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  598. public decimal NetWQty { get; set; }
  599. /// <summary>
  600. /// 皮重
  601. /// </summary>
  602. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  603. public decimal TareWQty { get; set; }
  604. /// <summary>
  605. /// 总长
  606. /// </summary>
  607. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  608. public decimal LengthQty { get; set; }
  609. /// <summary>
  610. /// 碳当量
  611. /// </summary>
  612. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  613. public decimal CaQty { get; set; }
  614. /// <summary>
  615. /// 销售总量
  616. /// </summary>
  617. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  618. public decimal SolderQty { get; set; }
  619. /// <summary>
  620. /// 暂定
  621. /// </summary>
  622. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  623. public int ContUsageQty { get; set; }
  624. /// <summary>
  625. /// 批次号
  626. /// </summary>
  627. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  628. public string BatchNo { get; set; }
  629. /// <summary>
  630. /// 生产时间
  631. /// </summary>
  632. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  633. public DateTime ProductTime { get; set; }
  634. /// <summary>
  635. /// 第一次入库时间
  636. /// </summary>
  637. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  638. public DateTime OneInTime { get; set; }
  639. /// <summary>
  640. /// 盘条条码
  641. /// </summary>
  642. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  643. public string RodBarCode { get; set; }
  644. /// <summary>
  645. /// 工字轮条码
  646. /// </summary>
  647. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  648. public string HWBarCode { get; set; }
  649. /// <summary>
  650. /// RFID条码
  651. /// </summary>
  652. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  653. public string RFIDBarCode { get; set; }
  654. /// <summary>
  655. /// 材料号
  656. /// </summary>
  657. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  658. public string CLBarCode { get; set; }
  659. /// <summary>
  660. /// 工字轮条码类型
  661. /// </summary>
  662. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  663. public string HWTypeCode { get; set; }
  664. /// <summary>
  665. /// 炉号
  666. /// </summary>
  667. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  668. public string BoilerNo { get; set; }
  669. /// <summary>
  670. /// 包号
  671. /// </summary>
  672. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  673. public string PackNo { get; set; }
  674. /// <summary>
  675. /// 牌号
  676. /// </summary>
  677. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  678. public string BrandNo { get; set; }
  679. /// <summary>
  680. /// 执行标准
  681. /// </summary>
  682. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  683. public string ExecStd { get; set; }
  684. /// <summary>
  685. /// 许可证号
  686. /// </summary>
  687. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  688. public string LicenceCode { get; set; }
  689. /// <summary>
  690. /// 改手盘标记
  691. /// </summary>
  692. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  693. public bool IsSurplus { get; set; }
  694. /// <summary>
  695. /// 返工标记
  696. /// </summary>
  697. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  698. public bool IsRework { get; set; }
  699. /// <summary>
  700. /// 是否黑盘
  701. /// </summary>
  702. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  703. public bool IsBlack { get; set; }
  704. /// <summary>
  705. /// 是否芯股
  706. /// </summary>
  707. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  708. public bool IsCore { get; set; }
  709. /// <summary>
  710. /// 快投标记
  711. /// </summary>
  712. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  713. public bool IsFast { get; set; }
  714. /// <summary>
  715. /// 是否异常
  716. /// </summary>
  717. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  718. public bool IsFail { get; set; }
  719. /// <summary>
  720. /// 异常原因
  721. /// </summary>
  722. [SugarColumn(ColumnDataType = "nvarchar", Length = 200, IsNullable = true)]
  723. public string FailReason { get; set; }
  724. /// <summary>
  725. /// 单/双丝
  726. /// </summary>
  727. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  728. public string SilkTypeCode { get; set; }
  729. /// <summary>
  730. /// 等级
  731. /// </summary>
  732. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  733. public string Grade { get; set; }
  734. /// <summary>
  735. /// 是否退料
  736. /// </summary>
  737. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  738. public bool IsBack { get; set; }
  739. /// <summary>
  740. /// 退料原因
  741. /// </summary>
  742. [SugarColumn(ColumnDataType = "nvarchar", Length = 200, IsNullable = true)]
  743. public string BackReason { get; set; }
  744. /// <summary>
  745. /// 是否扭转检测
  746. /// </summary>
  747. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  748. public bool IsTorsChk { get; set; }
  749. /// <summary>
  750. /// 扭转次数
  751. /// </summary>
  752. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  753. public int TorsChkQty { get; set; }
  754. /// <summary>
  755. /// 扭转检测时间
  756. /// </summary>
  757. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  758. public DateTime TorsChkTime { get; set; }
  759. /// <summary>
  760. /// 正反面
  761. /// </summary>
  762. [SugarColumn(ColumnDataType = "int", IsNullable = true, ColumnDescription = "正反面")]
  763. public int SideNum { get; set; }
  764. /// <summary>
  765. /// 扭转检测结果值
  766. /// </summary>
  767. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = true)]
  768. public decimal? TorsChkValue { get; set; }
  769. /// <summary>
  770. /// 扭转检测设备号
  771. /// </summary>
  772. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  773. public string TorsChkMachCode { get; set; }
  774. /// <summary>
  775. /// 工序订单号
  776. /// </summary>
  777. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  778. public string ProcessDocsCode { get; set; }
  779. /// <summary>
  780. /// 生产机台号
  781. /// </summary>
  782. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  783. public string ProductMachCode { get; set; }
  784. /// <summary>
  785. /// 生成产线号
  786. /// </summary>
  787. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  788. public string ProductLineNo { get; set; }
  789. /// <summary>
  790. /// 货物大小
  791. /// </summary>
  792. [SugarColumn(IsNullable = true)]
  793. public int Size { get; set; }
  794. /// <summary>
  795. /// 托盘类型
  796. /// </summary>
  797. [SugarColumn(IsNullable = true, ColumnDescription = "托盘类型")]
  798. public FJPalletType PalletType { get; set; }
  799. /// <summary>
  800. /// 需要二次码垛的物料
  801. /// </summary>
  802. [SugarColumn(IsNullable = true, ColumnDescription = "循环码垛物料")]
  803. public bool Secondary { get; set; }
  804. }
  805. /// <summary>
  806. /// 条码表
  807. /// </summary>
  808. [SugarTable("Bill_InvInit")]
  809. public partial class BillInvinit : BaseModel
  810. {
  811. /// <summary>
  812. /// 仓库ID 关联仓库表 ID
  813. /// </summary>
  814. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  815. public long WarehouseId { get; set; }
  816. /// <summary>
  817. /// 组盘ID
  818. /// 创建条码表时生成 同库存表组盘ID ContGrpId
  819. /// </summary>
  820. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  821. public long ContGrpId { get; set; }
  822. /// <summary>
  823. /// 容器条码 同联容器表容器条码 ContBarCode
  824. /// </summary>
  825. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  826. public string ContGrpBarCode { get; set; }
  827. /// <summary>
  828. /// 箱条码
  829. /// </summary>
  830. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  831. public string BoxBarCode { get; set; }
  832. /// <summary>
  833. /// Bom单号 关联投料单 帘线工序工单号 BillCode
  834. /// </summary>
  835. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  836. public string BomDocsNo { get; set; }
  837. /// <summary>
  838. /// Bom物料ID
  839. /// </summary>
  840. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  841. public long BomMatId { get; set; }
  842. /// <summary>
  843. /// Bom物料编号
  844. /// </summary>
  845. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  846. public string BomMatCode { get; set; }
  847. /// <summary>
  848. /// Bom物料
  849. /// </summary>
  850. [SugarColumn(ColumnDataType = "nvarchar", Length = 100, IsNullable = true)]
  851. public string BomMatName { get; set; }
  852. /// <summary>
  853. /// 垛形主表 ID
  854. /// </summary>
  855. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  856. public long BomSetId { get; set; }
  857. /// <summary>
  858. /// 垛型编码
  859. /// </summary>
  860. [SugarColumn(ColumnDataType = "nvarchar", Length = 100, IsNullable = true)]
  861. public string SetGrpCode { get; set; }
  862. /// <summary>
  863. /// 库存状态码
  864. /// </summary>
  865. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  866. public string ExecStateCode { get; set; }
  867. /// <summary>
  868. /// 单据编号 关联单据表单据编号 DocsNo
  869. /// </summary>
  870. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  871. public string ExecDocsNo { get; set; }
  872. /// <summary>
  873. /// 单据行号
  874. /// </summary>
  875. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  876. public string ExecDocsRowNo { get; set; }
  877. /// <summary>
  878. /// 单据类型编号 同单据表TypeNum
  879. /// </summary>
  880. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  881. public string ExecDocsTypeCode { get; set; }
  882. /// <summary>
  883. /// 出入库标识
  884. /// </summary>
  885. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  886. public FJInvInOutType InvInOut { get; set; }
  887. /// <summary>
  888. /// 执行人
  889. /// </summary>
  890. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  891. public string ExecWho { get; set; }
  892. /// <summary>
  893. /// 执行时间
  894. /// </summary>
  895. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  896. public DateTime ExecTime { get; set; }
  897. /// <summary>
  898. /// 行
  899. /// </summary>
  900. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  901. public int PutRow { get; set; }
  902. /// <summary>
  903. /// 列
  904. /// </summary>
  905. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  906. public int PutCol { get; set; }
  907. /// <summary>
  908. /// 层
  909. /// </summary>
  910. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  911. public int PutLayer { get; set; }
  912. /// <summary>
  913. /// 入库条码号 FJ材料号
  914. /// </summary>
  915. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  916. public string InvBarCode { get; set; }
  917. /// <summary>
  918. /// 库存状态
  919. /// </summary>
  920. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  921. public string InvStateCode { get; set; }
  922. /// <summary>
  923. /// 入库单号
  924. /// </summary>
  925. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  926. public string InDocsNo { get; set; }
  927. /// <summary>
  928. /// 入库单行号
  929. /// </summary>
  930. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  931. public string InDocsRowNo { get; set; }
  932. /// <summary>
  933. /// 供应编号
  934. /// </summary>
  935. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  936. public string SuppCode { get; set; }
  937. /// <summary>
  938. /// 供应商名称
  939. /// </summary>
  940. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  941. public string SuppName { get; set; }
  942. /// <summary>
  943. /// 海关编号
  944. /// </summary>
  945. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  946. public string CustCode { get; set; }
  947. /// <summary>
  948. /// 海关名称
  949. /// </summary>
  950. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  951. public string CustName { get; set; }
  952. /// <summary>
  953. /// 物料ID
  954. /// </summary>
  955. [SugarColumn(ColumnDataType = "bigint", IsNullable = false)]
  956. public long MatId { get; set; }
  957. /// <summary>
  958. /// 物料编号
  959. /// </summary>
  960. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  961. public string MatCode { get; set; }
  962. /// <summary>
  963. /// 物料名称
  964. /// </summary>
  965. [SugarColumn(ColumnDataType = "nvarchar", Length = 100, IsNullable = true)]
  966. public string MatName { get; set; }
  967. /// <summary>
  968. /// 总重量
  969. /// </summary>
  970. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  971. public decimal TolWQty { get; set; }
  972. /// <summary>
  973. /// 净重
  974. /// </summary>
  975. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  976. public decimal NetWQty { get; set; }
  977. /// <summary>
  978. /// 皮重
  979. /// </summary>
  980. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  981. public decimal TareWQty { get; set; }
  982. /// <summary>
  983. /// 总长
  984. /// </summary>
  985. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  986. public decimal LengthQty { get; set; }
  987. /// <summary>
  988. /// 碳当量
  989. /// </summary>
  990. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  991. public decimal CaQty { get; set; }
  992. /// <summary>
  993. /// 销售总量
  994. /// </summary>
  995. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = false)]
  996. public decimal SolderQty { get; set; }
  997. /// <summary>
  998. /// 暂定
  999. /// </summary>
  1000. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  1001. public int ContUsageQty { get; set; }
  1002. /// <summary>
  1003. /// 批次号
  1004. /// </summary>
  1005. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1006. public string BatchNo { get; set; }
  1007. /// <summary>
  1008. /// 生产时间
  1009. /// </summary>
  1010. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  1011. public DateTime ProductTime { get; set; }
  1012. /// <summary>
  1013. /// 第一次入库时间
  1014. /// </summary>
  1015. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  1016. public DateTime OneInTime { get; set; }
  1017. /// <summary>
  1018. /// 盘条条码
  1019. /// </summary>
  1020. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1021. public string RodBarCode { get; set; }
  1022. /// <summary>
  1023. /// 工字轮条码
  1024. /// </summary>
  1025. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1026. public string HWBarCode { get; set; }
  1027. /// <summary>
  1028. /// RFID条码
  1029. /// </summary>
  1030. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1031. public string RFIDBarCode { get; set; }
  1032. /// <summary>
  1033. /// 材料号
  1034. /// </summary>
  1035. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1036. public string CLBarCode { get; set; }
  1037. /// <summary>
  1038. /// 工字轮条码类型
  1039. /// </summary>
  1040. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1041. public string HWTypeCode { get; set; }
  1042. /// <summary>
  1043. /// 炉号
  1044. /// </summary>
  1045. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1046. public string BoilerNo { get; set; }
  1047. /// <summary>
  1048. /// 包号
  1049. /// </summary>
  1050. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1051. public string PackNo { get; set; }
  1052. /// <summary>
  1053. /// 牌号
  1054. /// </summary>
  1055. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1056. public string BrandNo { get; set; }
  1057. /// <summary>
  1058. /// 执行标准
  1059. /// </summary>
  1060. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1061. public string ExecStd { get; set; }
  1062. /// <summary>
  1063. /// 许可证号
  1064. /// </summary>
  1065. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1066. public string LicenceCode { get; set; }
  1067. /// <summary>
  1068. /// 改手盘标记
  1069. /// </summary>
  1070. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1071. public bool IsSurplus { get; set; }
  1072. /// <summary>
  1073. /// 返工标记
  1074. /// </summary>
  1075. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1076. public bool IsRework { get; set; }
  1077. /// <summary>
  1078. /// 是否黑盘
  1079. /// </summary>
  1080. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1081. public bool IsBlack { get; set; }
  1082. /// <summary>
  1083. /// 是否芯股
  1084. /// </summary>
  1085. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1086. public bool IsCore { get; set; }
  1087. /// <summary>
  1088. /// 快投标记
  1089. /// </summary>
  1090. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1091. public bool IsFast { get; set; }
  1092. /// <summary>
  1093. /// 是否异常
  1094. /// </summary>
  1095. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1096. public bool IsFail { get; set; }
  1097. /// <summary>
  1098. /// 异常原因
  1099. /// </summary>
  1100. [SugarColumn(ColumnDataType = "nvarchar", Length = 200, IsNullable = true)]
  1101. public string FailReason { get; set; }
  1102. /// <summary>
  1103. /// 单/双丝
  1104. /// </summary>
  1105. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1106. public string SilkTypeCode { get; set; }
  1107. /// <summary>
  1108. /// 等级
  1109. /// </summary>
  1110. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1111. public string Grade { get; set; }
  1112. /// <summary>
  1113. /// 是否退料
  1114. /// </summary>
  1115. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1116. public bool IsBack { get; set; }
  1117. /// <summary>
  1118. /// 退料原因
  1119. /// </summary>
  1120. [SugarColumn(ColumnDataType = "nvarchar", Length = 200, IsNullable = true)]
  1121. public string BackReason { get; set; }
  1122. /// <summary>
  1123. /// 是否扭转检测
  1124. /// </summary>
  1125. [SugarColumn(ColumnDataType = "bit", IsNullable = false)]
  1126. public bool IsTorsChk { get; set; }
  1127. /// <summary>
  1128. /// 扭转次数
  1129. /// </summary>
  1130. [SugarColumn(ColumnDataType = "int", IsNullable = false)]
  1131. public int TorsChkQty { get; set; }
  1132. /// <summary>
  1133. /// 扭转检测时间
  1134. /// </summary>
  1135. [SugarColumn(ColumnDataType = "datetime", IsNullable = false)]
  1136. public DateTime TorsChkTime { get; set; }
  1137. /// <summary>
  1138. /// 扭转检测结果值
  1139. /// </summary>
  1140. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = true)]
  1141. public decimal? TorsChkValue { get; set; }
  1142. /// <summary>
  1143. /// 扭转检测设备号
  1144. /// </summary>
  1145. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1146. public string TorsChkMachCode { get; set; }
  1147. /// <summary>
  1148. /// 工序订单号
  1149. /// </summary>
  1150. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1151. public string ProcessDocsCode { get; set; }
  1152. /// <summary>
  1153. /// 生产机台号
  1154. /// </summary>
  1155. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1156. public string ProductMachCode { get; set; }
  1157. /// <summary>
  1158. /// 生成产线号
  1159. /// </summary>
  1160. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true)]
  1161. public string ProductLineNo { get; set; }
  1162. /// <summary>
  1163. /// 货物大小
  1164. /// </summary>
  1165. [SugarColumn(IsNullable = false)]
  1166. public int Size { get; set; }
  1167. /// <summary>
  1168. /// 托盘类型
  1169. /// </summary>
  1170. [SugarColumn(IsNullable = true, ColumnDescription = "托盘类型")]
  1171. public FJPalletType PalletType { get; set; }
  1172. /// <summary>
  1173. /// 组盘类型
  1174. /// </summary>
  1175. [SugarColumn(IsNullable = true)]
  1176. public FJContGrpType ContGrpType { get; set; }
  1177. }
  1178. /// <summary>
  1179. /// 基础表实体
  1180. /// </summary>
  1181. public class BaseModel
  1182. {
  1183. public BaseModel()
  1184. { }
  1185. /// <summary>
  1186. /// ID
  1187. /// </summary>
  1188. [SugarColumn(ColumnName = "Id", IsPrimaryKey = true, ColumnDescription = "ID")]
  1189. public virtual long Id { get; set; }
  1190. /// <summary>
  1191. /// 备注
  1192. /// </summary>
  1193. [SugarColumn(ColumnName = "Memo", Length = 500, IsNullable = true, ColumnDataType = "nvarchar", DefaultValue = "", ColumnDescription = "备注")]
  1194. public virtual string Memo { get; set; }
  1195. /// <summary>
  1196. /// 创建用户
  1197. /// </summary>
  1198. [SugarColumn(ColumnName = "AddWho", Length = 50, ColumnDataType = "nvarchar", DefaultValue = "", IsNullable = false, ColumnDescription = "创建用户")]
  1199. public virtual string AddWho { get; set; } = "";
  1200. /// <summary>
  1201. /// 更新用户
  1202. /// </summary>
  1203. [SugarColumn(ColumnName = "EditWho", Length = 50, ColumnDataType = "nvarchar", DefaultValue = "", IsNullable = false, ColumnDescription = "更新用户")]
  1204. public virtual string EditWho { get; set; } = "";
  1205. /// <summary>
  1206. /// 创建时间
  1207. /// </summary>
  1208. [SugarColumn(ColumnName = "AddTime", DefaultValue = "1900-1-1", IsNullable = false, ColumnDescription = "创建时间")]
  1209. public virtual DateTime AddTime { get; set; } = DateTime.Now;
  1210. /// <summary>
  1211. /// 更新时间
  1212. /// </summary>
  1213. [SugarColumn(ColumnName = "EditTime", DefaultValue = "1900-1-1", IsNullable = false, ColumnDescription = "更新时间")]
  1214. public virtual DateTime EditTime { get; set; } = DateTime.Now;
  1215. }
  1216. /// <summary>
  1217. /// 组盘类型
  1218. /// </summary>
  1219. public enum FJContGrpType
  1220. {
  1221. /// <summary>
  1222. /// 物料盘
  1223. /// </summary>
  1224. [Description("物料盘")]
  1225. Material = 1,
  1226. /// <summary>
  1227. /// 空盘
  1228. /// </summary>
  1229. [Description("空盘")]
  1230. EmptyCon = 2,
  1231. }
  1232. /// <summary>
  1233. /// 托盘类型
  1234. /// </summary>
  1235. public enum FJPalletType
  1236. {
  1237. /// <summary>
  1238. /// 09使用的托盘
  1239. /// </summary>
  1240. [Description("09使用的托盘")]
  1241. Pallet09 = 1,
  1242. /// <summary>
  1243. /// 非09使用的托盘
  1244. /// </summary>
  1245. [Description("非09使用的托盘")]
  1246. PalletNo09 = 2,
  1247. }
  1248. /// <summary>
  1249. /// 出入库类型
  1250. /// </summary>
  1251. public enum FJInvInOutType
  1252. {
  1253. /// <summary>
  1254. /// 默认
  1255. /// </summary>
  1256. [Description("默认")]
  1257. Default = 0,
  1258. /// <summary>
  1259. /// 入库
  1260. /// </summary>
  1261. [Description("入库")]
  1262. In = 1,
  1263. /// <summary>
  1264. /// 出库
  1265. /// </summary>
  1266. [Description("出库")]
  1267. Out = 2,
  1268. }
  1269. }