| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636 |
- using LocalhostMES.Core;
- using LocalhostMES.Enums;
- using LocalhostMES.Models;
- using SqlSugar;
- using System;
- using System.Collections;
- using System.Collections.Generic;
- using System.Linq;
- using System.Runtime.InteropServices;
- using System.Security.Claims;
- using System.Text;
- using System.Threading.Tasks;
- using static Org.BouncyCastle.Pqc.Crypto.Utilities.PqcOtherInfoGenerator;
- namespace LocalhostMES.DataBase
- {
- public class DatabaseHelper
- {
- private static void NotifyChanged(MesDataScope scope)
- {
- MesDataChangedNotifier.Raise(scope);
- }
- public static SqlSugarScope Db = new SqlSugarScope(new ConnectionConfig()
- {
- //192.168.1.100
- ConnectionString = "Database=LingPaoProject; Data Source=127.0.0.1; Port=3306;User Id=root; Password=root;Charset=utf8;AllowPublicKeyRetrieval=True;SslMode=None;",//连接符字串
- DbType = SqlSugar.DbType.MySql,//数据库类型
- IsAutoCloseConnection = true //不设成true要手动close
- },
- db =>
- {
- db.Aop.OnLogExecuting = (sql, pars) =>
- {
- Console.WriteLine(UtilMethods.GetNativeSql(sql, pars));
- };
- });
- public static void CreataDataTable()
- {
- try
- {
- Db.CodeFirst.InitTables<SnInfo>();
- Db.CodeFirst.InitTables<BindRecord>();
- Db.CodeFirst.InitTables<ProcessRecord>();
- Db.CodeFirst.InitTables<ParkingLot>();
- Db.CodeFirst.InitTables<WorkOrderInfo>();
- Db.CodeFirst.InitTables<LocalhostPartInfo>();
- EnsureLocalhostPartInfoColumns();
- // 您的数据库操作代码
- }
- catch ( AggregateException ex )
- {
- // 遍历所有内部异常
- foreach ( var inner in ex.InnerExceptions )
- {
- Console.WriteLine($"内部异常: {inner.Message}");
- Console.WriteLine(inner.StackTrace);
- }
- // 或者只取第一个
- // var actualException = ex.InnerException;
- }
- catch ( SqlSugarException ex )
- {
- Console.WriteLine($"错误消息:{ex.Message}");
- Console.WriteLine($"内部异常:{ex.InnerException?.Message}");
- Console.WriteLine($"堆栈:{ex.StackTrace}");
- // 也可以记录日志
- }
- catch ( Exception e )
- {
- }
- }
- private static void EnsureLocalhostPartInfoColumns()
- {
- Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `MaterialCode` varchar(128) NULL");
- Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `StationCode` varchar(128) NULL");
- Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `PositionCode` varchar(128) NULL");
- Db.Ado.ExecuteCommand("ALTER TABLE `LocalhostPartInfo` ADD COLUMN IF NOT EXISTS `PartInfoName` varchar(200) NULL");
- }
- public static int GetProductProductionRecords(string sn)
- {
- try
- {
- return Db.Queryable<ProductionToStation>().Where(it => it.SN == sn).ToList().Count;
- }
- catch ( Exception ex )
- {
- LogHelper.WriteLogError("获取一条产品的生产记录至数据库时出错!", ex);
- }
- return 0;
- }
- public static List<WorkOrderInfo> SelectWorkOrderInfo(string workOrderNo = null)
- {
- if ( workOrderNo != null )
- {
- var single = Db.Queryable<WorkOrderInfo>()
- .Where(it => it.WorkOrderNo == workOrderNo)
- .Select(it => new WorkOrderInfo
- {
- OrderNo = it.OrderNo,
- LineCode = it.LineCode,
- CreateTime = it.CreateTime,
- EndTime = it.EndTime,
- IsLocalhost = it.IsLocalhost,
- MaterialCode = it.MaterialCode,
- MaterialName = it.MaterialName,
- PlannedQuantity = it.PlannedQuantity,
- StartTime = it.StartTime,
- Status = it.Status,
- WorkOrderNo = it.WorkOrderNo,
- CompletedQuantity = SqlFunc.Subqueryable<SnInfo>().Where(s => s.WorkOrderNo == it.WorkOrderNo&&s.IsUsed).Count()
- }).ToList();
- NormalizeWorkOrderStatus(single);
- return single;
- }
- else
- {
- var list = Db.Queryable<WorkOrderInfo>().
- Select(it=>new WorkOrderInfo
- {
- OrderNo=it.OrderNo,
- LineCode=it.LineCode,
- CreateTime=it.CreateTime,
- EndTime=it.EndTime,
- IsLocalhost=it.IsLocalhost,
- MaterialCode=it.MaterialCode,
- MaterialName=it.MaterialName,
- PlannedQuantity=it.PlannedQuantity,
- StartTime=it.StartTime,
- Status=it.Status,
- WorkOrderNo=it.WorkOrderNo,
- CompletedQuantity=SqlFunc.Subqueryable<SnInfo>().Where(s=>s.WorkOrderNo==it.WorkOrderNo && s.IsUsed).Count()
- }).ToList();
- NormalizeWorkOrderStatus(list);
- return list;
- }
- }
- private static void NormalizeWorkOrderStatus(List<WorkOrderInfo> workOrders)
- {
- if ( workOrders == null || workOrders.Count == 0 )
- {
- return;
- }
- var changed = false;
- foreach ( var workOrder in workOrders )
- {
- if ( workOrder.PlannedQuantity > 0 &&
- workOrder.CompletedQuantity >= workOrder.PlannedQuantity &&
- workOrder.Status != "6" )
- {
- workOrder.Status = "6";
- Db.Updateable<WorkOrderInfo>()
- .SetColumns(it => new WorkOrderInfo { Status = "6" })
- .Where(it => it.WorkOrderNo == workOrder.WorkOrderNo)
- .ExecuteCommand();
- changed = true;
- }
- }
- if ( changed )
- {
- NotifyChanged(MesDataScope.WorkOrder);
- }
- }
- public static bool InsertWorkOrderInfo(WorkOrderInfo info)
- {
- if ( Db.Storageable(info).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.WorkOrder);
- return true;
- }
- return false;
- }
- public static bool UpdateWorkOrderInfo(WorkOrderInfo info)
- {
- if ( Db.Updateable(info).Where(it => it.WorkOrderNo == info.WorkOrderNo).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.WorkOrder);
- return true;
- }
- return false;
- }
- public static bool DeleteWorkOrderInfo(WorkOrderInfo info)
- {
- if ( Db.Deleteable(info).Where(it => it.WorkOrderNo == info.WorkOrderNo).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.WorkOrder);
- return true;
- }
- return false;
- }
- public static List<SnInfo> SelectSnInfo(string workOrderNo = null, bool needused = false, bool isused = false)
- {
- if ( workOrderNo != null )
- {
- if ( needused )
- {
- return Db.Queryable<SnInfo>().Where(it => it.WorkOrderNo == workOrderNo && it.IsUsed == isused).ToList();
- }
- else
- {
- return Db.Queryable<SnInfo>().Where(it => it.WorkOrderNo == workOrderNo).ToList();
- }
- }
- else
- {
- return Db.Queryable<SnInfo>().ToList();
- }
- }
- public static SnInfo SelectSnInfoForStation(string workOrderNo,StationType type)
- {
- if ( workOrderNo != null )
- {
- var query=Db.Queryable<SnInfo>();
- switch ( type )
- {
- case StationType.OP10:
- break;
- case StationType.OP20L:
- case StationType.OP20R:
- query = query.Where(it => it.OP20State==false);
- break;
- case StationType.OP30L:
- case StationType.OP30R:
- query = query.Where(it => it.OP30State == false);
- break;
- case StationType.OP40L:
- case StationType.OP40R:
- query = query.Where(it => it.OP40State == false);
- break;
- case StationType.OP50L:
- case StationType.OP50R:
- query = query.Where(it => it.OP50State == false);
- break;
- case StationType.OP60L:
- case StationType.OP60R:
- query = query.Where(it => it.OP60State == false);
- break;
- case StationType.OP70L:
- case StationType.OP70R:
- query = query.Where(it => it.OP70State == false);
- break;
- case StationType.OP80L:
- case StationType.OP80R:
- query = query.Where(it => it.OP80State == false);
- break;
- default:
- break;
- }
- List<SnInfo> snInfos= query.Where(it => it.WorkOrderNo == workOrderNo).OrderBy(it => it.GenerateTime).Take(1).ToList();
- if ( snInfos.Count != 0 )
- {
- return snInfos[ 0 ];
- }
- return null;
- }
- else
- {
- return null;
- }
- }
- public static bool InsertSnInfo(SnInfo info)
- {
- if ( Db.Storageable(info).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.Sn);
- return true;
- }
- return false;
- }
- public static bool InsertSnInfos(List<SnInfo> info)
- {
- if ( Db.Storageable(info).ExecuteCommand() == info.Count )
- {
- NotifyChanged(MesDataScope.Sn);
- return true;
- }
- return false;
- }
- public static bool UpdateSnInfo(SnInfo info)
- {
- if ( Db.Updateable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.Sn);
- return true;
- }
- return false;
- }
- public static bool UpdateSnInfo(string sn,string workorder,StationType type)
- {
- var query= Db.Updateable<SnInfo>().Where(it => it.Sn == sn&&it.WorkOrderNo==workorder);
- switch ( type )
- {
- case StationType.OP10:
- break;
- case StationType.OP20L:
- case StationType.OP20R:
- query= query.SetColumns(it => it.OP20State == true);
- break;
- case StationType.OP30L:
- case StationType.OP30R:
- query = query.SetColumns(it => it.OP30State == false);
- break;
- case StationType.OP40L:
- case StationType.OP40R:
- query = query.SetColumns(it => it.OP40State == false);
- break;
- case StationType.OP50L:
- case StationType.OP50R:
- query = query.SetColumns(it => it.OP50State == false);
- break;
- case StationType.OP60L:
- case StationType.OP60R:
- query = query.SetColumns(it => it.OP60State == false);
- break;
- case StationType.OP70L:
- case StationType.OP70R:
- query = query.SetColumns(it => it.OP70State == false);
- break;
- case StationType.OP80L:
- case StationType.OP80R:
- query = query.SetColumns(it => it.OP80State == false);
- break;
- default:
- break;
- }
- if ( query.ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.Sn);
- return true;
- }
- return false;
- }
- public static bool DeleteSnInfo(SnInfo info)
- {
- if ( Db.Deleteable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.Sn);
- return true;
- }
- return false;
- }
- public static List<BindRecord> SelectBindRecord(string Sn = null, string PartNum = null, string StationCode = null)
- {
- var query = Db.Queryable<BindRecord>();
- // 动态添加查询条件
- if ( !string.IsNullOrWhiteSpace(Sn) )
- {
- query = query.Where(it => it.Sn == Sn);
- }
- if ( !string.IsNullOrWhiteSpace(PartNum) )
- {
- query = query.Where(it => it.PartNum == PartNum);
- }
- if ( !string.IsNullOrWhiteSpace(StationCode) )
- {
- query = query.Where(it => it.StationCode == StationCode);
- }
- return query.ToList();
- }
- public static bool InsertBindRecord(BindRecord info)
- {
- if ( Db.Storageable(info).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.BindRecord);
- return true;
- }
- return false;
- }
- public static bool UpdateBindRecord(BindRecord info)
- {
- if ( Db.Updateable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.BindRecord);
- return true;
- }
- return false;
- }
- public static bool DeleteBindRecord(string sn = null)
- {
- if ( sn != null )
- {
- if ( Db.Deleteable<BindRecord>().Where(it => it.Sn == sn).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.BindRecord);
- return true;
- }
- }
- else
- {
- if ( Db.Deleteable<BindRecord>().ExecuteCommand() != 0 )
- {
- NotifyChanged(MesDataScope.BindRecord);
- return true;
- }
- }
- return false;
- }
- public static List<ProcessRecord> SelectProcessRecord(string Sn = null, string StationCode = null)
- {
- var query = Db.Queryable<ProcessRecord>();
- // 动态添加查询条件
- if ( !string.IsNullOrWhiteSpace(Sn) )
- {
- query = query.Where(it => it.Sn == Sn);
- }
- if ( !string.IsNullOrWhiteSpace(StationCode) )
- {
- query = query.Where(it => it.Station == StationCode);
- }
- return query.ToList();
- }
- public static bool InsertProcessRecord(ProcessRecord info)
- {
- if ( Db.Storageable(info).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.ProcessRecord);
- return true;
- }
- return false;
- }
- public static bool UpdateProcessRecord(ProcessRecord info)
- {
- if ( Db.Updateable(info).Where(it => it.Sn == info.Sn).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.ProcessRecord);
- return true;
- }
- return false;
- }
- public static bool DeleteProcessRecord(string sn = null)
- {
- if ( Db.Deleteable<ProcessRecord>().Where(it => it.Sn == sn).ExecuteCommand() == 1 )
- {
- NotifyChanged(MesDataScope.ProcessRecord);
- return true;
- }
- return false;
- }
- public static List<LocalhostPartInfo> SelectPartInfo(StationType stationType)
- {
- return Db.Queryable<LocalhostPartInfo>().Where(it => it.StationType == stationType).ToList();
- }
- public static List<LocalhostPartInfo> SelectPartInfo(string _materialCode, string stationCode)
- {
- return Db.Queryable<LocalhostPartInfo>().Where(it => it.StationCode == stationCode&&it.MaterialCode==_materialCode).ToList();
- }
- public static bool InsertPartInfo(LocalhostPartInfo info)
- {
- var ok = Db.Storageable(info).ExecuteCommand() > 0;
- if ( ok )
- {
- NotifyChanged(MesDataScope.KeyPart);
- }
- return ok;
- }
- public static int InsertPartInfos(List<LocalhostPartInfo> infos)
- {
- if ( infos == null || infos.Count == 0 )
- {
- return 0;
- }
- var affected = Db.Storageable(infos).ExecuteCommand();
- if ( affected > 0 )
- {
- NotifyChanged(MesDataScope.KeyPart);
- }
- return affected;
- }
- public static bool DeletePartInfo(StationType stationType, string partNum)
- {
- var ok = Db.Deleteable<LocalhostPartInfo>()
- .Where(it => it.StationType == stationType && it.PartNum == partNum)
- .ExecuteCommand() >= 1;
- if ( ok )
- {
- NotifyChanged(MesDataScope.KeyPart);
- }
- return ok;
- }
- /// <summary>
- /// 零件
- /// </summary>
- /// <returns></returns>
- public static List<ParkingLot> SelectParkingLot()
- {
- return Db.Queryable<ParkingLot>().OrderBy(it => it.Id).ToList();
- }
- public static bool InsertParkingLot(ParkingLot info)
- {
- var ok = Db.Storageable(info).ExecuteCommand() > 0;
- if ( ok )
- {
- NotifyChanged(MesDataScope.ParkingLot);
- }
- return ok;
- }
- public static bool UpdateParkingLot(ParkingLot info)
- {
- var ok = Db.Updateable(info).Where(it => it.Id == info.Id).ExecuteCommand() == 1;
- if ( ok )
- {
- NotifyChanged(MesDataScope.ParkingLot);
- }
- return ok;
- }
- public static bool DeleteParkingLot(int id)
- {
- var ok = Db.Deleteable<ParkingLot>().Where(it => it.Id == id).ExecuteCommand() == 1;
- if ( ok )
- {
- NotifyChanged(MesDataScope.ParkingLot);
- }
- return ok;
- }
- #region 当前左右工位识别码
- public static OrderToMesInfo SelectWorkOrderInfo()
- {
- List<OrderToMesInfo> lilsts = Db.Queryable<OrderToMesInfo>().ToList();
- if ( lilsts.Count != 0 )
- {
- return lilsts[ 0 ];
- }
- else
- {
- return new OrderToMesInfo() { CreateTime = DateTime.Now, Id = 0, LeftCheckCode = "", RightCheckCode = "" };
- }
- }
- public static bool InsertWorkOrderInfo(OrderToMesInfo info)
- {
- if ( Db.Storageable(info).ExecuteCommand() == 1 )
- {
- return true;
- }
- return false;
- }
- public static bool UpdateWorkOrderInfo(OrderToMesInfo info, bool isleft = true)
- {
- if ( info.CurrMarkCode != string.Empty )
- {
- if ( Db.Updateable(info).UpdateColumns(it => new { it.CurrMarkCode }).Where(it => it.Id == info.Id).ExecuteCommand() == 1 )
- {
- return true;
- }
- return false;
- }
- if ( isleft )
- {
- if ( Db.Updateable(info).UpdateColumns(it => new { it.CreateTime, it.LeftCheckCode }).Where(it => it.Id == info.Id).ExecuteCommand() == 1 )
- {
- return true;
- }
- }
- else
- {
- if ( Db.Updateable(info).UpdateColumns(it => new { it.CreateTime, it.RightCheckCode }).Where(it => it.Id == info.Id).ExecuteCommand() == 1 )
- {
- return true;
- }
- }
- return false;
- }
- #endregion
- }
- }
|