DatabaseHelper.cs 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636
  1. using LocalhostMES.Core;
  2. using LocalhostMES.Enums;
  3. using LocalhostMES.Models;
  4. using SqlSugar;
  5. using System;
  6. using System.Collections;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Runtime.InteropServices;
  10. using System.Security.Claims;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using static Org.BouncyCastle.Pqc.Crypto.Utilities.PqcOtherInfoGenerator;
  14. namespace LocalhostMES.DataBase
  15. {
  16. public class DatabaseHelper
  17. {
  18. private static void NotifyChanged(MesDataScope scope)
  19. {
  20. MesDataChangedNotifier.Raise(scope);
  21. }
  22. public static SqlSugarScope Db = new SqlSugarScope(new ConnectionConfig()
  23. {
  24. //192.168.1.100
  25. ConnectionString = "Database=LingPaoProject; Data Source=127.0.0.1; Port=3306;User Id=root; Password=root;Charset=utf8;AllowPublicKeyRetrieval=True;SslMode=None;",//连接符字串
  26. DbType = SqlSugar.DbType.MySql,//数据库类型
  27. IsAutoCloseConnection = true //不设成true要手动close
  28. },
  29. db =>
  30. {
  31. db.Aop.OnLogExecuting = (sql, pars) =>
  32. {
  33. Console.WriteLine(UtilMethods.GetNativeSql(sql, pars));
  34. };
  35. });
  36. public static void CreataDataTable()
  37. {
  38. try
  39. {
  40. Db.CodeFirst.InitTables<SnInfo>();
  41. Db.CodeFirst.InitTables<BindRecord>();
  42. Db.CodeFirst.InitTables<ProcessRecord>();
  43. Db.CodeFirst.InitTables<ParkingLot>();
  44. Db.CodeFirst.InitTables<WorkOrderInfo>();
  45. Db.CodeFirst.InitTables<LocalhostPartInfo>();
  46. EnsureLocalhostPartInfoColumns();
  47. // 您的数据库操作代码
  48. }
  49. catch ( AggregateException ex )
  50. {
  51. // 遍历所有内部异常
  52. foreach ( var inner in ex.InnerExceptions )
  53. {
  54. Console.WriteLine($"内部异常: {inner.Message}");
  55. Console.WriteLine(inner.StackTrace);
  56. }
  57. // 或者只取第一个
  58. // var actualException = ex.InnerException;
  59. }
  60. catch ( SqlSugarException ex )
  61. {
  62. Console.WriteLine($"错误消息:{ex.Message}");
  63. Console.WriteLine($"内部异常:{ex.InnerException?.Message}");
  64. Console.WriteLine($"堆栈:{ex.StackTrace}");
  65. // 也可以记录日志
  66. }
  67. catch ( Exception e )
  68. {
  69. }
  70. }
  71. private static void EnsureLocalhostPartInfoColumns()
  72. {
  73. Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `MaterialCode` varchar(128) NULL");
  74. Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `StationCode` varchar(128) NULL");
  75. Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `PositionCode` varchar(128) NULL");
  76. Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `PartInfoName` varchar(200) NULL");
  77. }
  78. public static int GetProductProductionRecords(string sn)
  79. {
  80. try
  81. {
  82. return Db.Queryable<ProductionToStation>().Where(it => it.SN == sn).ToList().Count;
  83. }
  84. catch ( Exception ex )
  85. {
  86. LogHelper.WriteLogError("获取一条产品的生产记录至数据库时出错!", ex);
  87. }
  88. return 0;
  89. }
  90. public static List<WorkOrderInfo> SelectWorkOrderInfo(string workOrderNo = null)
  91. {
  92. if ( workOrderNo != null )
  93. {
  94. var single = Db.Queryable<WorkOrderInfo>()
  95. .Where(it => it.WorkOrderNo == workOrderNo)
  96. .Select(it => new WorkOrderInfo
  97. {
  98. OrderNo = it.OrderNo,
  99. LineCode = it.LineCode,
  100. CreateTime = it.CreateTime,
  101. EndTime = it.EndTime,
  102. IsLocalhost = it.IsLocalhost,
  103. MaterialCode = it.MaterialCode,
  104. MaterialName = it.MaterialName,
  105. PlannedQuantity = it.PlannedQuantity,
  106. StartTime = it.StartTime,
  107. Status = it.Status,
  108. WorkOrderNo = it.WorkOrderNo,
  109. CompletedQuantity = SqlFunc.Subqueryable<SnInfo>().Where(s => s.WorkOrderNo == it.WorkOrderNo&&s.IsUsed).Count()
  110. }).ToList();
  111. NormalizeWorkOrderStatus(single);
  112. return single;
  113. }
  114. else
  115. {
  116. var list = Db.Queryable<WorkOrderInfo>().
  117. Select(it=>new WorkOrderInfo
  118. {
  119. OrderNo=it.OrderNo,
  120. LineCode=it.LineCode,
  121. CreateTime=it.CreateTime,
  122. EndTime=it.EndTime,
  123. IsLocalhost=it.IsLocalhost,
  124. MaterialCode=it.MaterialCode,
  125. MaterialName=it.MaterialName,
  126. PlannedQuantity=it.PlannedQuantity,
  127. StartTime=it.StartTime,
  128. Status=it.Status,
  129. WorkOrderNo=it.WorkOrderNo,
  130. CompletedQuantity=SqlFunc.Subqueryable<SnInfo>().Where(s=>s.WorkOrderNo==it.WorkOrderNo && s.IsUsed).Count()
  131. }).ToList();
  132. NormalizeWorkOrderStatus(list);
  133. return list;
  134. }
  135. }
  136. private static void NormalizeWorkOrderStatus(List<WorkOrderInfo> workOrders)
  137. {
  138. if ( workOrders == null || workOrders.Count == 0 )
  139. {
  140. return;
  141. }
  142. var changed = false;
  143. foreach ( var workOrder in workOrders )
  144. {
  145. if ( workOrder.PlannedQuantity > 0 &&
  146. workOrder.CompletedQuantity >= workOrder.PlannedQuantity &&
  147. workOrder.Status != "6" )
  148. {
  149. workOrder.Status = "6";
  150. Db.Updateable<WorkOrderInfo>()
  151. .SetColumns(it => new WorkOrderInfo { Status = "6" })
  152. .Where(it => it.WorkOrderNo == workOrder.WorkOrderNo)
  153. .ExecuteCommand();
  154. changed = true;
  155. }
  156. }
  157. if ( changed )
  158. {
  159. NotifyChanged(MesDataScope.WorkOrder);
  160. }
  161. }
  162. public static bool InsertWorkOrderInfo(WorkOrderInfo info)
  163. {
  164. if ( Db.Storageable(info).ExecuteCommand() == 1 )
  165. {
  166. NotifyChanged(MesDataScope.WorkOrder);
  167. return true;
  168. }
  169. return false;
  170. }
  171. public static bool UpdateWorkOrderInfo(WorkOrderInfo info)
  172. {
  173. if ( Db.Updateable(info).Where(it => it.WorkOrderNo == info.WorkOrderNo).ExecuteCommand() == 1 )
  174. {
  175. NotifyChanged(MesDataScope.WorkOrder);
  176. return true;
  177. }
  178. return false;
  179. }
  180. public static bool DeleteWorkOrderInfo(WorkOrderInfo info)
  181. {
  182. if ( Db.Deleteable(info).Where(it => it.WorkOrderNo == info.WorkOrderNo).ExecuteCommand() == 1 )
  183. {
  184. NotifyChanged(MesDataScope.WorkOrder);
  185. return true;
  186. }
  187. return false;
  188. }
  189. public static List<SnInfo> SelectSnInfo(string workOrderNo = null, bool needused = false, bool isused = false)
  190. {
  191. if ( workOrderNo != null )
  192. {
  193. if ( needused )
  194. {
  195. return Db.Queryable<SnInfo>().Where(it => it.WorkOrderNo == workOrderNo && it.IsUsed == isused).ToList();
  196. }
  197. else
  198. {
  199. return Db.Queryable<SnInfo>().Where(it => it.WorkOrderNo == workOrderNo).ToList();
  200. }
  201. }
  202. else
  203. {
  204. return Db.Queryable<SnInfo>().ToList();
  205. }
  206. }
  207. public static SnInfo SelectSnInfoForStation(string workOrderNo,StationType type)
  208. {
  209. if ( workOrderNo != null )
  210. {
  211. var query=Db.Queryable<SnInfo>();
  212. switch ( type )
  213. {
  214. case StationType.OP10:
  215. break;
  216. case StationType.OP20L:
  217. case StationType.OP20R:
  218. query = query.Where(it => it.OP20State==false);
  219. break;
  220. case StationType.OP30L:
  221. case StationType.OP30R:
  222. query = query.Where(it => it.OP30State == false);
  223. break;
  224. case StationType.OP40L:
  225. case StationType.OP40R:
  226. query = query.Where(it => it.OP40State == false);
  227. break;
  228. case StationType.OP50L:
  229. case StationType.OP50R:
  230. query = query.Where(it => it.OP50State == false);
  231. break;
  232. case StationType.OP60L:
  233. case StationType.OP60R:
  234. query = query.Where(it => it.OP60State == false);
  235. break;
  236. case StationType.OP70L:
  237. case StationType.OP70R:
  238. query = query.Where(it => it.OP70State == false);
  239. break;
  240. case StationType.OP80L:
  241. case StationType.OP80R:
  242. query = query.Where(it => it.OP80State == false);
  243. break;
  244. default:
  245. break;
  246. }
  247. List<SnInfo> snInfos= query.Where(it => it.WorkOrderNo == workOrderNo).OrderBy(it => it.GenerateTime).Take(1).ToList();
  248. if ( snInfos.Count != 0 )
  249. {
  250. return snInfos[ 0 ];
  251. }
  252. return null;
  253. }
  254. else
  255. {
  256. return null;
  257. }
  258. }
  259. public static bool InsertSnInfo(SnInfo info)
  260. {
  261. if ( Db.Storageable(info).ExecuteCommand() == 1 )
  262. {
  263. NotifyChanged(MesDataScope.Sn);
  264. return true;
  265. }
  266. return false;
  267. }
  268. public static bool InsertSnInfos(List<SnInfo> info)
  269. {
  270. if ( Db.Storageable(info).ExecuteCommand() == info.Count )
  271. {
  272. NotifyChanged(MesDataScope.Sn);
  273. return true;
  274. }
  275. return false;
  276. }
  277. public static bool UpdateSnInfo(SnInfo info)
  278. {
  279. if ( Db.Updateable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
  280. {
  281. NotifyChanged(MesDataScope.Sn);
  282. return true;
  283. }
  284. return false;
  285. }
  286. public static bool UpdateSnInfo(string sn,string workorder,StationType type)
  287. {
  288. var query= Db.Updateable<SnInfo>().Where(it => it.Sn == sn&&it.WorkOrderNo==workorder);
  289. switch ( type )
  290. {
  291. case StationType.OP10:
  292. break;
  293. case StationType.OP20L:
  294. case StationType.OP20R:
  295. query= query.SetColumns(it => it.OP20State == true);
  296. break;
  297. case StationType.OP30L:
  298. case StationType.OP30R:
  299. query = query.SetColumns(it => it.OP30State == false);
  300. break;
  301. case StationType.OP40L:
  302. case StationType.OP40R:
  303. query = query.SetColumns(it => it.OP40State == false);
  304. break;
  305. case StationType.OP50L:
  306. case StationType.OP50R:
  307. query = query.SetColumns(it => it.OP50State == false);
  308. break;
  309. case StationType.OP60L:
  310. case StationType.OP60R:
  311. query = query.SetColumns(it => it.OP60State == false);
  312. break;
  313. case StationType.OP70L:
  314. case StationType.OP70R:
  315. query = query.SetColumns(it => it.OP70State == false);
  316. break;
  317. case StationType.OP80L:
  318. case StationType.OP80R:
  319. query = query.SetColumns(it => it.OP80State == false);
  320. break;
  321. default:
  322. break;
  323. }
  324. if ( query.ExecuteCommand() == 1 )
  325. {
  326. NotifyChanged(MesDataScope.Sn);
  327. return true;
  328. }
  329. return false;
  330. }
  331. public static bool DeleteSnInfo(SnInfo info)
  332. {
  333. if ( Db.Deleteable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
  334. {
  335. NotifyChanged(MesDataScope.Sn);
  336. return true;
  337. }
  338. return false;
  339. }
  340. public static List<BindRecord> SelectBindRecord(string Sn = null, string PartNum = null, string StationCode = null)
  341. {
  342. var query = Db.Queryable<BindRecord>();
  343. // 动态添加查询条件
  344. if ( !string.IsNullOrWhiteSpace(Sn) )
  345. {
  346. query = query.Where(it => it.Sn == Sn);
  347. }
  348. if ( !string.IsNullOrWhiteSpace(PartNum) )
  349. {
  350. query = query.Where(it => it.PartNum == PartNum);
  351. }
  352. if ( !string.IsNullOrWhiteSpace(StationCode) )
  353. {
  354. query = query.Where(it => it.StationCode == StationCode);
  355. }
  356. return query.ToList();
  357. }
  358. public static bool InsertBindRecord(BindRecord info)
  359. {
  360. if ( Db.Storageable(info).ExecuteCommand() == 1 )
  361. {
  362. NotifyChanged(MesDataScope.BindRecord);
  363. return true;
  364. }
  365. return false;
  366. }
  367. public static bool UpdateBindRecord(BindRecord info)
  368. {
  369. if ( Db.Updateable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
  370. {
  371. NotifyChanged(MesDataScope.BindRecord);
  372. return true;
  373. }
  374. return false;
  375. }
  376. public static bool DeleteBindRecord(string sn = null)
  377. {
  378. if ( sn != null )
  379. {
  380. if ( Db.Deleteable<BindRecord>().Where(it => it.Sn == sn).ExecuteCommand() == 1 )
  381. {
  382. NotifyChanged(MesDataScope.BindRecord);
  383. return true;
  384. }
  385. }
  386. else
  387. {
  388. if ( Db.Deleteable<BindRecord>().ExecuteCommand() != 0 )
  389. {
  390. NotifyChanged(MesDataScope.BindRecord);
  391. return true;
  392. }
  393. }
  394. return false;
  395. }
  396. public static List<ProcessRecord> SelectProcessRecord(string Sn = null, string StationCode = null)
  397. {
  398. var query = Db.Queryable<ProcessRecord>();
  399. // 动态添加查询条件
  400. if ( !string.IsNullOrWhiteSpace(Sn) )
  401. {
  402. query = query.Where(it => it.Sn == Sn);
  403. }
  404. if ( !string.IsNullOrWhiteSpace(StationCode) )
  405. {
  406. query = query.Where(it => it.Station == StationCode);
  407. }
  408. return query.ToList();
  409. }
  410. public static bool InsertProcessRecord(ProcessRecord info)
  411. {
  412. if ( Db.Storageable(info).ExecuteCommand() == 1 )
  413. {
  414. NotifyChanged(MesDataScope.ProcessRecord);
  415. return true;
  416. }
  417. return false;
  418. }
  419. public static bool UpdateProcessRecord(ProcessRecord info)
  420. {
  421. if ( Db.Updateable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
  422. {
  423. NotifyChanged(MesDataScope.ProcessRecord);
  424. return true;
  425. }
  426. return false;
  427. }
  428. public static bool DeleteProcessRecord(string sn = null)
  429. {
  430. if ( Db.Deleteable<ProcessRecord>().Where(it => it.Sn == sn).ExecuteCommand() == 1 )
  431. {
  432. NotifyChanged(MesDataScope.ProcessRecord);
  433. return true;
  434. }
  435. return false;
  436. }
  437. public static List<LocalhostPartInfo> SelectPartInfo(StationType stationType)
  438. {
  439. return Db.Queryable<LocalhostPartInfo>().Where(it => it.StationType == stationType).ToList();
  440. }
  441. public static List<LocalhostPartInfo> SelectPartInfo(string _materialCode, string stationCode)
  442. {
  443. return Db.Queryable<LocalhostPartInfo>().Where(it => it.StationCode == stationCode&&it.MaterialCode==_materialCode).ToList();
  444. }
  445. public static bool InsertPartInfo(LocalhostPartInfo info)
  446. {
  447. var ok = Db.Storageable(info).ExecuteCommand() > 0;
  448. if ( ok )
  449. {
  450. NotifyChanged(MesDataScope.KeyPart);
  451. }
  452. return ok;
  453. }
  454. public static int InsertPartInfos(List<LocalhostPartInfo> infos)
  455. {
  456. if ( infos == null || infos.Count == 0 )
  457. {
  458. return 0;
  459. }
  460. var affected = Db.Storageable(infos).ExecuteCommand();
  461. if ( affected > 0 )
  462. {
  463. NotifyChanged(MesDataScope.KeyPart);
  464. }
  465. return affected;
  466. }
  467. public static bool DeletePartInfo(StationType stationType, string partNum)
  468. {
  469. var ok = Db.Deleteable<LocalhostPartInfo>()
  470. .Where(it => it.StationType == stationType && it.PartNum == partNum)
  471. .ExecuteCommand() >= 1;
  472. if ( ok )
  473. {
  474. NotifyChanged(MesDataScope.KeyPart);
  475. }
  476. return ok;
  477. }
  478. /// <summary>
  479. /// 零件
  480. /// </summary>
  481. /// <returns></returns>
  482. public static List<ParkingLot> SelectParkingLot()
  483. {
  484. return Db.Queryable<ParkingLot>().OrderBy(it => it.Id).ToList();
  485. }
  486. public static bool InsertParkingLot(ParkingLot info)
  487. {
  488. var ok = Db.Storageable(info).ExecuteCommand() > 0;
  489. if ( ok )
  490. {
  491. NotifyChanged(MesDataScope.ParkingLot);
  492. }
  493. return ok;
  494. }
  495. public static bool UpdateParkingLot(ParkingLot info)
  496. {
  497. var ok = Db.Updateable(info).Where(it => it.Id == info.Id).ExecuteCommand() == 1;
  498. if ( ok )
  499. {
  500. NotifyChanged(MesDataScope.ParkingLot);
  501. }
  502. return ok;
  503. }
  504. public static bool DeleteParkingLot(int id)
  505. {
  506. var ok = Db.Deleteable<ParkingLot>().Where(it => it.Id == id).ExecuteCommand() == 1;
  507. if ( ok )
  508. {
  509. NotifyChanged(MesDataScope.ParkingLot);
  510. }
  511. return ok;
  512. }
  513. #region 当前左右工位识别码
  514. public static OrderToMesInfo SelectWorkOrderInfo()
  515. {
  516. List<OrderToMesInfo> lilsts = Db.Queryable<OrderToMesInfo>().ToList();
  517. if ( lilsts.Count != 0 )
  518. {
  519. return lilsts[ 0 ];
  520. }
  521. else
  522. {
  523. return new OrderToMesInfo() { CreateTime = DateTime.Now, Id = 0, LeftCheckCode = "", RightCheckCode = "" };
  524. }
  525. }
  526. public static bool InsertWorkOrderInfo(OrderToMesInfo info)
  527. {
  528. if ( Db.Storageable(info).ExecuteCommand() == 1 )
  529. {
  530. return true;
  531. }
  532. return false;
  533. }
  534. public static bool UpdateWorkOrderInfo(OrderToMesInfo info, bool isleft = true)
  535. {
  536. if ( info.CurrMarkCode != string.Empty )
  537. {
  538. if ( Db.Updateable(info).UpdateColumns(it => new { it.CurrMarkCode }).Where(it => it.Id == info.Id).ExecuteCommand() == 1 )
  539. {
  540. return true;
  541. }
  542. return false;
  543. }
  544. if ( isleft )
  545. {
  546. if ( Db.Updateable(info).UpdateColumns(it => new { it.CreateTime, it.LeftCheckCode }).Where(it => it.Id == info.Id).ExecuteCommand() == 1 )
  547. {
  548. return true;
  549. }
  550. }
  551. else
  552. {
  553. if ( Db.Updateable(info).UpdateColumns(it => new { it.CreateTime, it.RightCheckCode }).Where(it => it.Id == info.Id).ExecuteCommand() == 1 )
  554. {
  555. return true;
  556. }
  557. }
  558. return false;
  559. }
  560. #endregion
  561. }
  562. }