TaskExtension.cs 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643
  1. using ServiceCenter.Extensions;
  2. using ServiceCenter.Logs;
  3. using ServiceCenter.Redis;
  4. using ServiceCenter.SqlSugars;
  5. using SqlSugar;
  6. using WCS.Core;
  7. using WCS.Entity;
  8. using WCS.WorkEngineering.Systems;
  9. using TaskStatus = WCS.Entity.TaskStatus;
  10. namespace WCS.WorkEngineering.Extensions
  11. {
  12. /// <summary>
  13. /// 任务扩展
  14. /// </summary>
  15. public static class TaskExtension
  16. {
  17. /// <summary>
  18. /// 更新任务执行记录
  19. /// 同步更新历史任务
  20. /// </summary>
  21. /// <param name="task">任务信息</param>
  22. /// <param name="db">数据库上下文</param>
  23. /// <param name="curPoint">当前地址</param>
  24. /// <param name="desc">描述</param>
  25. public static void AddWCS_TASK_DTL(this WCS_TaskInfo task, SqlSugarScopeProvider db, string curPoint, string desc) => task.AddWCS_TASK_DTL(db, curPoint, "", desc);
  26. /// <summary>
  27. /// 更新任务执行记录
  28. /// 同步更新历史任务
  29. /// </summary>
  30. /// <param name="task">任务信息</param>
  31. /// <param name="db">数据库上下文</param>
  32. /// <param name="curPoint">当前地址</param>
  33. /// <param name="nextPoint">下一个地址</param>
  34. /// <param name="desc">描述</param>
  35. public static void AddWCS_TASK_DTL(this WCS_TaskInfo task, SqlSugarScopeProvider db, string curPoint, string nextPoint, string desc)
  36. {
  37. db.InsertableRowLock(new WCS_TaskDtl
  38. {
  39. ID = Guid.NewGuid(),
  40. ParentTaskCode = task.ID,
  41. CurPoint = curPoint,
  42. NextPoint = nextPoint,
  43. Desc = desc,
  44. AddWho = "WCS"
  45. }).SplitTable().ExecuteCommand();
  46. task.UpdateableOldTask(db);
  47. }
  48. /// <summary>
  49. /// 更新任务执行记录
  50. /// 同步更新历史任务
  51. /// </summary>
  52. /// <param name="task">任务信息</param>
  53. /// <param name="db">数据库上下文</param>
  54. /// <param name="curPoint">当前地址</param>
  55. /// <param name="desc">描述</param>
  56. public static void AddWCS_TASK_DTL(this WCS_TaskOld task, SqlSugarScopeProvider db, string curPoint, string desc) => task.AddWCS_TASK_DTL(db, curPoint, "", desc);
  57. /// <summary>
  58. /// 更新任务执行记录
  59. /// 同步更新历史任务
  60. /// </summary>
  61. /// <param name="task">任务信息</param>
  62. /// <param name="db">数据库上下文</param>
  63. /// <param name="curPoint">当前地址</param>
  64. /// <param name="nextPoint">下一个地址</param>
  65. /// <param name="desc">描述</param>
  66. public static void AddWCS_TASK_DTL(this WCS_TaskOld task, SqlSugarScopeProvider db, string curPoint, string nextPoint, string desc)
  67. {
  68. db.InsertableRowLock(new WCS_TaskDtl
  69. {
  70. ID = Guid.NewGuid(),
  71. ParentTaskCode = task.Id,
  72. CurPoint = curPoint,
  73. NextPoint = nextPoint,
  74. Desc = desc,
  75. AddWho = "WCS"
  76. }).SplitTable().ExecuteCommand();
  77. }
  78. /// <summary>
  79. /// 更新历史表数据
  80. /// </summary>
  81. /// <param name="taskInfo"></param>
  82. /// <param name="db"></param>
  83. public static void UpdateableOldTask(this WCS_TaskInfo taskInfo, SqlSugarScopeProvider db)
  84. {
  85. if (taskInfo.Status == TaskStatus.NewBuild) return;
  86. // 同步任务信息
  87. var taskOld = db.Queryable<WCS_TaskOld>().UpdLock().Where(v => v.Id == taskInfo.ID).SplitTable(tabs => tabs.Take(2)).ToList().OrderByDescending(v => v.AddTime).First();
  88. if (taskOld is not null)
  89. {
  90. if (taskInfo.Status >= TaskStatus.Finish) taskInfo.CompleteOrCancelTasks(db);
  91. else
  92. {
  93. taskOld = taskInfo.Mapper<WCS_TaskOld, WCS_TaskInfo>();
  94. taskOld.Id = taskInfo.ID;
  95. db.UpdateableRowLock(taskOld).Where(x => x.Id == taskOld.Id).SplitTable(tabs => tabs.Take(2)).ExecuteCommand();
  96. }
  97. }
  98. else
  99. {
  100. throw new KnownException($"WCS_TaskOld表中不存在任务:{taskInfo.ID},无法执行WCS_TaskInfo与WCS_TaskOld同步动作", LogLevelEnum.Mid);
  101. }
  102. }
  103. /// <summary>
  104. /// 完成或取消任务
  105. /// </summary>
  106. /// <param name="taskInfo"></param>
  107. /// <param name="db"></param>
  108. public static void CompleteOrCancelTasks(this WCS_TaskInfo taskInfo, SqlSugarScopeProvider db)
  109. {
  110. if (taskInfo.Status is not Entity.TaskStatus.Finish and not Entity.TaskStatus.Cancel) throw new KnownException("任务未完成或取消,无法执行WCS_TaskInfo与WCS_TaskOld同步动作", LogLevelEnum.Mid);
  111. // 任务完成或取消,进行相关同步动作
  112. var taskOld = db.Queryable<WCS_TaskOld>().UpdLock().Where(v => v.Id == taskInfo.ID).SplitTable(tabs => tabs.Take(2)).ToList().OrderByDescending(v => v.AddTime).First();
  113. if (taskOld is not null)
  114. {
  115. taskOld = taskInfo.Mapper<WCS_TaskOld, WCS_TaskInfo>();
  116. taskOld.Id = taskInfo.ID;
  117. //更新任务历史表,删除任务当前表
  118. db.UpdateableRowLock(taskOld).Where(x => x.Id == taskOld.Id).SplitTable(tabs => tabs.Take(2)).ExecuteCommand();
  119. db.DeleteableRowLock(taskInfo).ExecuteCommand();
  120. }
  121. else
  122. {
  123. throw new KnownException($"WCS_TaskOld表中不存在任务:{taskInfo.ID},无法执行WCS_TaskInfo与WCS_TaskOld同步动作", LogLevelEnum.Mid);
  124. }
  125. }
  126. /// <summary>
  127. /// 更新表数据
  128. /// </summary>
  129. /// <param name="taskInfo"></param>
  130. /// <param name="db"></param>
  131. public static void Updateable(this WCS_TaskInfo taskInfo, SqlSugarScopeProvider db)
  132. {
  133. }
  134. ///// <summary>
  135. ///// 获取出库任务
  136. ///// </summary>
  137. ///// <param name="taskInfo">任务</param>
  138. ///// <param name="db">db</param>
  139. ///// <param name="allOutCode">可用出库站台</param>
  140. ///// <param name="floor">楼层</param>
  141. ///// <param name="obj">堆垛机</param>
  142. ///// <param name="index">递归次数</param>
  143. ///// <returns></returns>
  144. ///// <exception cref="KnownException"></exception>
  145. //public static WCS_TaskInfo GetOutTask(this WCS_TaskInfo taskInfo, SqlSugarHelper db, List<string> allOutCode, int floor, SRM obj, int index = 1)
  146. //{
  147. // return task;
  148. //}
  149. /// <summary>
  150. /// 获取AGV任务ID
  151. /// </summary>
  152. /// <param name="db">db</param>
  153. /// <returns></returns>
  154. public static int GetAgvTaskId(this SqlSugarHelper db)
  155. {
  156. //最多任务号不再连续
  157. var id = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().SplitTable(v => v.Take(2)).Max(v => v.ID);
  158. return id + 1;
  159. }
  160. /// <summary>
  161. /// 更新任务执行记录
  162. /// </summary>
  163. /// <param name="task">任务信息</param>
  164. public static void UpdateRedisHash(this WCS_TaskInfo task)
  165. {
  166. var key = $"Hash:{task.ID}";
  167. if (task.Status >= TaskStatus.Finish)
  168. {
  169. RedisHub.WMS.Del(key);
  170. }
  171. else
  172. {
  173. RedisHub.WMS.HMSet(key, task.ToDic());
  174. }
  175. }
  176. public static int GetOutTime(this List<BaseMatinfo> matInfoList, string matCode, string defaultOutTime)
  177. {
  178. var outTime = Convert.ToInt32(defaultOutTime);
  179. if (matInfoList.Any(m => matCode.Contains(m.Code)))
  180. {
  181. outTime = matInfoList.Where(m => matCode.Contains(m.Code)).Min(m => m.TimeOut);
  182. }
  183. return outTime;
  184. }
  185. #region 工字轮支线分流
  186. /// <summary>
  187. /// 初始化码垛信息
  188. /// </summary>
  189. /// <param name="task"></param>
  190. public static void InitStackStructure(this WCS_TaskInfo task, SqlSugarScopeProvider db, World world)
  191. {
  192. var billBomsetgrp = db.Queryable<BillBomsetgrp>().Single(x => x.IsStop == 0 && x.BomCode.Contains(task.MatCode));
  193. if (billBomsetgrp == null)
  194. {
  195. world.Log($"物料规格[{task.MatCode}]无可用码垛垛形");
  196. return;
  197. };
  198. var billBomsetinfos = db.Queryable<BillBomsetinfo>().Where(x => x.BomSetHdrId == billBomsetgrp.Id).ToList();
  199. var addTime = DateTime.Now;
  200. //开始构造垛形信息
  201. var palletizing = new WCS_Palletizing()
  202. {
  203. Code = billBomsetgrp.Code,
  204. ShortCode = billBomsetgrp.ShortCode,
  205. ProMaterCode = billBomsetgrp.ProMaterCode,
  206. TpTypeCode = billBomsetgrp.TpTypeCode,
  207. LayerCountQty = 2,
  208. StampType = billBomsetgrp.StampType,
  209. Finish = false,
  210. AddTime = addTime,
  211. EditTime = addTime,
  212. TaskId = task.ID,
  213. WarehouseCode = task.WarehouseCode,
  214. DeviceCode = task.Device
  215. };
  216. var matInfoList = db.Queryable<BaseMatinfo>().NoLock().Where(x => x.TimeOut != 0).ToList();
  217. var defaultOutTime = db.Queryable<fjSysConfig>().First(x => x.Code == "DefaultOutTime") ?? new fjSysConfig() { SContent = "12" };
  218. palletizing = db.InsertableRowLock(palletizing).ExecuteReturnEntity();
  219. foreach (var item in billBomsetinfos.Where(x => x.IsEmpty == 0).GroupBy(x => x.Row).OrderBy(x => x.Key))
  220. {
  221. var layerNo = item.Key <= 6 ? 1 : 2;
  222. //获取层信息
  223. var palletizingLayer = db.Queryable<WCS_PalletizingLayer>().Single(x => x.PalletizingId == palletizing.Id && x.LayerNo == layerNo);
  224. if (palletizingLayer == null)
  225. {
  226. palletizingLayer = new WCS_PalletizingLayer()
  227. {
  228. LayerNo = layerNo,
  229. PalletizingId = palletizing.Id,
  230. WarehouseCode = palletizing.WarehouseCode,
  231. };
  232. palletizingLayer = db.InsertableRowLock(palletizingLayer).ExecuteReturnEntity();
  233. }
  234. //获取行信息
  235. var palletizingRow = db.Queryable<WCS_PalletizingRow>().Single(x => x.PalletizingLayerId == palletizingLayer.Id && x.RowNo == item.Key);
  236. if (palletizingRow == null)
  237. {
  238. palletizingRow = new WCS_PalletizingRow()
  239. {
  240. RowNo = item.Key,
  241. PalletizingLayerId = palletizingLayer.Id,
  242. PalletizingId = palletizing.Id,
  243. WarehouseCode = palletizingLayer.WarehouseCode,
  244. AddTime = addTime,
  245. EditTime = addTime,
  246. };
  247. palletizingRow = db.InsertableRowLock(palletizingRow).ExecuteReturnEntity();
  248. }
  249. //重新查询最新的数据
  250. var layer = palletizingLayer;
  251. palletizingLayer = db.Queryable<WCS_PalletizingLayer>().Single(x => x.Id == layer.Id);
  252. var row = palletizingRow;
  253. palletizingRow = db.Queryable<WCS_PalletizingRow>().Single(x => x.Id == row.Id);
  254. //构造位信息
  255. foreach (var loc in item)
  256. {
  257. var palletizingLoc = db.Queryable<WCS_PalletizingLoc>().Single(x => x.PalletizingRowId == palletizingRow.Id && x.XYNo == loc.XYNo);
  258. if (palletizingLoc == null)
  259. {
  260. palletizingLoc = new WCS_PalletizingLoc()
  261. {
  262. IsEmpty = loc.IsEmpty != 0,
  263. XYNo = loc.XYNo,
  264. MatCode = loc.MatCode,
  265. SideNum = loc.SideNum,
  266. SpoolType = loc.SpoolType,
  267. TaskId = task.ID,
  268. PalletizingRowId = palletizingRow.Id,
  269. Finish = false,
  270. PalletizingId = palletizing.Id,
  271. WarehouseCode = palletizingRow.WarehouseCode,
  272. TimeOut = matInfoList.GetOutTime(loc.MatCode, defaultOutTime.SContent)
  273. };
  274. db.InsertableRowLock(palletizingLoc).ExecuteReturnEntity();
  275. }
  276. //同步是否混合料行
  277. palletizingRow.IsMixRow = loc.IsMixRow != 0;
  278. db.UpdateableRowLock(palletizingRow).UpdateColumns(x => new { x.IsMixRow }).ExecuteCommand();
  279. }
  280. //更新行信息
  281. palletizingRow = db.Queryable<WCS_PalletizingRow>().Includes(x => x.Locs).Single(x => x.Id == row.Id);
  282. palletizingRow.QtyMaxCount = palletizingRow.Locs.Count(x => !x.IsEmpty);
  283. palletizingRow.IsEmpty = palletizingRow.QtyMaxCount <= 0;
  284. palletizingRow.MatCodeList = palletizingRow.Locs.Select(x => x.MatCode).ToList().GetMatList();
  285. db.UpdateableRowLock(palletizingRow).UpdateColumns(x => new { x.QtyMaxCount, x.IsEmpty, x.MatCodeList }).ExecuteCommand();
  286. //更新层信息
  287. palletizingLayer = db.Queryable<WCS_PalletizingLayer>().Includes(x => x.Rows, l => l.Locs).Single(x => x.Id == layer.Id);
  288. var count = palletizingLayer.Rows.Count(x => !x.IsEmpty); //计算所有不空数量
  289. palletizingLayer.IsEmpty = count <= 0;
  290. palletizingLayer.RowCountQty = palletizingLayer.Rows.Count;
  291. palletizingLayer.Finish = false;
  292. palletizingLayer.MatCodeList = palletizingLayer.Rows.SelectMany(x => x.Locs).Select(x => x.MatCode).ToList().GetMatList();
  293. db.UpdateableRowLock(palletizingLayer).UpdateColumns(x => new { x.IsEmpty, x.RowCountQty, x.Finish, x.MatCodeList }).ExecuteCommand();
  294. }
  295. var palletizing1 = palletizing;
  296. palletizing = db.Queryable<WCS_Palletizing>().Includes(x => x.Layers, r => r.Rows, l => l.Locs).Single(x => x.Id == palletizing1.Id);
  297. //计算垛形信息
  298. var goods = palletizing.Layers.Select(x => x.Rows).SelectMany(x => x).Select(x => x.Locs).SelectMany(x => x).ToList();
  299. palletizing.CountQty = goods.Count(x => !x.IsEmpty);
  300. palletizing.MatCodeList = palletizing.Layers.SelectMany(x => x.Rows).SelectMany(x => x.Locs).Select(x => x.MatCode).ToList().GetMatList();
  301. db.UpdateableRowLock(palletizing).UpdateColumns(x => new { x.CountQty, x.MatCodeList }).ExecuteCommand();
  302. }
  303. public static string GetMatList(this List<string> matList)
  304. {
  305. return matList.Distinct().Aggregate("", (current, mat) => current + $"[{mat}]");
  306. }
  307. /// <summary>
  308. /// 去除转义字符
  309. /// </summary>
  310. /// <param name="value"></param>
  311. /// <returns></returns>
  312. public static string RemoveEscapeCharacters(this string? value)
  313. {
  314. return value.Trim('\0', '\a', '\b', '\f', '\n', '\r', '\t', '\v').Trim();
  315. }
  316. #endregion 工字轮支线分流
  317. }
  318. /// <summary>
  319. /// 垛形位信息
  320. /// </summary>
  321. public class StackPosInfo
  322. {
  323. /// <summary>
  324. /// 任务号
  325. /// </summary>
  326. public int TaskNumber { get; set; }
  327. /// <summary>
  328. /// 是否空置
  329. /// </summary>
  330. public bool IsEmpty { get; set; }
  331. /// <summary>
  332. /// 坐标号
  333. /// </summary>
  334. public string XYNo { get; set; }
  335. /// <summary>
  336. /// 物料编码
  337. /// </summary>
  338. public string MatCode { get; set; }
  339. /// <summary>
  340. /// 正反面
  341. /// </summary>
  342. public int SideNum { get; set; }
  343. /// <summary>
  344. /// 工字轮类型
  345. /// </summary>
  346. public string SpoolType { get; set; }
  347. /// <summary>
  348. /// 是否结束
  349. /// </summary>
  350. public bool Finish { get; set; }
  351. }
  352. /// <summary>
  353. /// 垛型明细表
  354. /// </summary>
  355. [SugarTable("Bill_BomSetInfo", tableDescription: "垛型明细表")]
  356. public partial class BillBomsetinfo
  357. {
  358. /// <summary>
  359. /// ID
  360. /// </summary>
  361. [SugarColumn(ColumnName = "Id", IsPrimaryKey = true, ColumnDescription = "ID")]
  362. public virtual long Id { get; set; }
  363. /// <summary>
  364. /// 备注
  365. /// </summary>
  366. [SugarColumn(ColumnName = "Memo", Length = 500, IsNullable = true, ColumnDataType = "nvarchar", DefaultValue = "", ColumnDescription = "备注")]
  367. public virtual string Memo { get; set; }
  368. /// <summary>
  369. /// 创建用户
  370. /// </summary>
  371. [SugarColumn(ColumnName = "AddWho", Length = 50, ColumnDataType = "nvarchar", DefaultValue = "", IsNullable = false, ColumnDescription = "创建用户")]
  372. public virtual string AddWho { get; set; } = "";
  373. /// <summary>
  374. /// 更新用户
  375. /// </summary>
  376. [SugarColumn(ColumnName = "EditWho", Length = 50, ColumnDataType = "nvarchar", DefaultValue = "", IsNullable = false, ColumnDescription = "更新用户")]
  377. public virtual string EditWho { get; set; } = "";
  378. /// <summary>
  379. /// 创建时间
  380. /// </summary>
  381. [SugarColumn(ColumnName = "AddTime", DefaultValue = "1900-1-1", IsNullable = false, ColumnDescription = "创建时间")]
  382. public virtual DateTime AddTime { get; set; } = DateTime.Now;
  383. /// <summary>
  384. /// 更新时间
  385. /// </summary>
  386. [SugarColumn(ColumnName = "EditTime", DefaultValue = "1900-1-1", IsNullable = false, ColumnDescription = "更新时间")]
  387. public virtual DateTime EditTime { get; set; } = DateTime.Now;
  388. /// <summary>
  389. /// 垛型id
  390. /// </summary>
  391. [SugarColumn(ColumnDataType = "bigint", IsNullable = false, ColumnDescription = "垛型id")]
  392. public long BomSetHdrId { get; set; }
  393. /// <summary>
  394. /// 是否停用
  395. /// </summary>
  396. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "是否停用")]
  397. public int IsStop { get; set; }
  398. /// <summary>
  399. /// 是否空置
  400. /// </summary>
  401. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "是否空置")]
  402. public int IsEmpty { get; set; }
  403. /// <summary>
  404. /// 坐标号
  405. /// </summary>
  406. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = false, ColumnDescription = "坐标号")]
  407. public string XYNo { get; set; }
  408. /// <summary>
  409. /// 物料id
  410. /// </summary>
  411. [SugarColumn(ColumnDataType = "bigint", ColumnDescription = "物料id")]
  412. public long MatId { get; set; }
  413. /// <summary>
  414. /// 物料编码
  415. /// </summary>
  416. [SugarColumn(ColumnDataType = "nvarchar", IsNullable = true, Length = 50, ColumnDescription = "物料编码")]
  417. public string MatCode { get; set; }
  418. /// <summary>
  419. /// 正反面
  420. /// </summary>
  421. [SugarColumn(ColumnDataType = "int", IsNullable = true, ColumnDescription = "正反面")]
  422. public int SideNum { get; set; }
  423. /// <summary>
  424. /// 工字轮类型
  425. /// </summary>
  426. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true, ColumnDescription = "工字轮类型")]
  427. public string SpoolType { get; set; }
  428. /// <summary>
  429. /// 钢丝类型
  430. /// </summary>
  431. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = true, ColumnDescription = "钢丝类型")]
  432. public string SilkType { get; set; }
  433. /// <summary>
  434. /// 钢丝直径
  435. /// </summary>
  436. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = true, ColumnDescription = "钢丝直径")]
  437. public decimal SilkDiam { get; set; }
  438. /// <summary>
  439. /// 钢丝直径上限
  440. /// </summary>
  441. [SugarColumn(ColumnDataType = "decimal", Length = 18, IsNullable = true, ColumnDescription = "钢丝直径上限")]
  442. public decimal SilkDiamMaxCount { get; set; }
  443. /// <summary>
  444. /// 数量上限
  445. /// </summary>
  446. [SugarColumn(ColumnDataType = "int", IsNullable = true, ColumnDescription = "数量上限")]
  447. public int QtyMaxCount { get; set; }
  448. /// <summary>
  449. /// 是否芯股
  450. /// </summary>
  451. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "是否芯股")]
  452. public int IsCore { get; set; }
  453. /// <summary>
  454. /// 09垛型里面的行(1-12)
  455. /// </summary>
  456. [SugarColumn(ColumnDataType = "int", IsNullable = true, ColumnDescription = "09垛型里面的行(1-12)")]
  457. public int Row { get; set; }
  458. /// <summary>
  459. /// 是否混合料行(09垛型使用,1是0否)
  460. /// </summary>
  461. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "是否混合料行(09垛型使用,1是0否)")]
  462. public int IsMixRow { get; set; }
  463. /// <summary>
  464. /// 混合料行编码
  465. /// </summary>
  466. [SugarColumn(ColumnDataType = "nvarchar", IsNullable = true, Length = 50, ColumnDescription = "混合料行编码")]
  467. public string MixRowCode { get; set; }
  468. /// <summary>
  469. /// 第一种第二种第三种
  470. /// </summary>
  471. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "第一种第二种第三种")]
  472. public int CategoryId { get; set; }
  473. }
  474. /// <summary>
  475. /// 垛形主表
  476. /// </summary>
  477. [Tenant("fj")]
  478. [SugarTable("Bill_BomSetGrp", tableDescription: "垛形主表")]
  479. public partial class BillBomsetgrp
  480. {
  481. /// <summary>
  482. /// ID
  483. /// </summary>
  484. [SugarColumn(ColumnName = "Id", IsPrimaryKey = true, ColumnDescription = "ID")]
  485. public virtual long Id { get; set; }
  486. /// <summary>
  487. /// 备注
  488. /// </summary>
  489. [SugarColumn(ColumnName = "Memo", Length = 500, IsNullable = true, ColumnDataType = "nvarchar", DefaultValue = "", ColumnDescription = "备注")]
  490. public virtual string Memo { get; set; }
  491. /// <summary>
  492. /// 创建用户
  493. /// </summary>
  494. [SugarColumn(ColumnName = "AddWho", Length = 50, ColumnDataType = "nvarchar", DefaultValue = "", IsNullable = false, ColumnDescription = "创建用户")]
  495. public virtual string AddWho { get; set; } = "";
  496. /// <summary>
  497. /// 更新用户
  498. /// </summary>
  499. [SugarColumn(ColumnName = "EditWho", Length = 50, ColumnDataType = "nvarchar", DefaultValue = "", IsNullable = false, ColumnDescription = "更新用户")]
  500. public virtual string EditWho { get; set; } = "";
  501. /// <summary>
  502. /// 创建时间
  503. /// </summary>
  504. [SugarColumn(ColumnName = "AddTime", DefaultValue = "1900-1-1", IsNullable = false, ColumnDescription = "创建时间")]
  505. public virtual DateTime AddTime { get; set; } = DateTime.Now;
  506. /// <summary>
  507. /// 更新时间
  508. /// </summary>
  509. [SugarColumn(ColumnName = "EditTime", DefaultValue = "1900-1-1", IsNullable = false, ColumnDescription = "更新时间")]
  510. public virtual DateTime EditTime { get; set; } = DateTime.Now;
  511. /// <summary>
  512. /// 是否停用
  513. /// </summary>
  514. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "是否停用")]
  515. public int IsStop { get; set; }
  516. /// <summary>
  517. /// 垛型编码
  518. /// </summary>
  519. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = false, ColumnDescription = "垛型编码")]
  520. public string Code { get; set; }
  521. /// <summary>
  522. /// 短垛型编码
  523. /// </summary>
  524. [SugarColumn(ColumnDataType = "smallint", IsNullable = false, ColumnDescription = "短垛型编码")]
  525. public short ShortCode { get; set; }
  526. /// <summary>
  527. /// 垛型名称
  528. /// </summary>
  529. [SugarColumn(ColumnDataType = "nvarchar", Length = 100, IsNullable = false, ColumnDescription = "垛型名称")]
  530. public string Name { get; set; }
  531. /// <summary>
  532. /// BomCode(投料信息)
  533. /// </summary>
  534. [SugarColumn(ColumnDataType = "nvarchar", Length = 200, IsNullable = false, ColumnDescription = "BomCode(投料信息)")]
  535. public string BomCode { get; set; }
  536. /// <summary>
  537. /// 帘线物料编码
  538. /// </summary>
  539. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = false, ColumnDescription = "帘线物料编码")]
  540. public string ProMaterCode { get; set; }
  541. /// <summary>
  542. /// 工字轮个数
  543. /// </summary>
  544. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "工字轮个数")]
  545. public int HWCountQty { get; set; }
  546. /// <summary>
  547. /// 托盘类型
  548. /// </summary>
  549. [SugarColumn(ColumnDataType = "nvarchar", Length = 50, IsNullable = false, ColumnDescription = "托盘类型")]
  550. public string TpTypeCode { get; set; }
  551. /// <summary>
  552. /// 层数
  553. /// </summary>
  554. [SugarColumn(ColumnDataType = "int", IsNullable = false, ColumnDescription = "层数")]
  555. public int LayerCountQty { get; set; }
  556. /// <summary>
  557. /// 垛型大类
  558. /// </summary>
  559. [SugarColumn(ColumnDataType = "int", IsNullable = true, ColumnDescription = "垛型大类")]
  560. public int StampType { get; set; }
  561. /// <summary>
  562. /// 是否在桁架进行码垛
  563. /// </summary>
  564. [SugarColumn(IsNullable = true, ColumnDescription = "是否在桁架进行码垛")]
  565. public bool IsTruss { get; set; }
  566. }
  567. }