华恒Mes鼎捷代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

98 lines
4.4 KiB

5 months ago
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using ICSSoft.Frame.Data.Entity;
  6. using ICSSoft.Base.Config.AppConfig;
  7. using System.Data;
  8. using System.Data.Sql;
  9. using System.Data.Linq;
  10. using ICSSoft.Base.Config.DBHelper;
  11. using System.Data.SqlClient;
  12. namespace ICSSoft.Frame.Data.DAL
  13. {
  14. public class CheckDAL
  15. {
  16. public static DataTable PoArriveCheckData(string LotNO, string dsconn)
  17. {
  18. string sql = @"SELECT A.LotNO, B.INVCODE, B.INVNAME, B.INVSTD, A.LOTQTY, A.VenderLotNO, A.EATTRIBUTE3 AS iNum, B.INVUOM, A.EATTRIBUTE2, ISNULL(A.EATTRIBUTE5, '') EATTRIBUTE5
  19. FROM ICSITEMLot A INNER JOIN ICSINVENTORY B ON A.MCODE = B.INVCODE WHERE 1=1 AND A.LotNO = '{0}' AND TYPE = '' ";
  20. sql = string.Format(sql, LotNO);
  21. DataTable dt = DBHelper.ExecuteDataset(dsconn, CommandType.Text, sql).Tables[0];
  22. return dt;
  23. }
  24. public static bool UpdateCheck(SqlConnection sqlConnection, SqlTransaction trans, string LotNO, string iStatus, string User, string dsconn)
  25. {
  26. string sql = "";
  27. string ConnectString = dsconn;
  28. bool isSuccess = false;
  29. SqlCommand cmd = new SqlCommand();
  30. cmd.Connection = sqlConnection;
  31. cmd.Transaction = trans;
  32. try
  33. {
  34. sql = @"UPDATE ICSITEMLot SET EATTRIBUTE2 = '{1}', VENDORITEMCODE = '{2}', VENDORCODE = '{3}', EATTRIBUTE5 = '已检' WHERE LotNO = '{0}' ";
  35. sql = string.Format(sql, LotNO, iStatus, User, DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  36. cmd.CommandText = sql;
  37. cmd.ExecuteNonQuery();
  38. isSuccess = true;
  39. }
  40. catch (Exception ex)
  41. {
  42. throw new Exception(ex.Message);
  43. }
  44. return isSuccess;
  45. }
  46. public static DataTable IQCCheckData(string LotNO, string dsconn)
  47. {
  48. string sql = @"SELECT TOP 1 A.LotNO, D.INVCODE, D.INVNAME, D.INVSTD, B.OPCODE, A.VenderLotNO, D.INVUOM, B.LOTQTY,
  49. B.UserCodeBegin, B.EQPCODE, ISNULL(C.Result, '') Result, E.EATTRIBUTE1 FROM ICSITEMLot A
  50. INNER JOIN ICSLOTONWIP B ON A.LotNO = B.LOTNO LEFT JOIN ICSLOTONWIPCheck C ON B.ID = C.ONWIPID
  51. JOIN ICSINVENTORY D ON A.MCODE = D.INVCODE LEFT JOIN ICSMO2User E ON B.LotNO = E.LOTNO AND B.OPCODE = E.OPCODE
  52. WHERE 1=1 AND A.LotNO = '{0}' AND A.TYPE = '' ORDER BY B.MTIME DESC ";
  53. sql = string.Format(sql, LotNO);
  54. DataTable dt = DBHelper.ExecuteDataset(dsconn, CommandType.Text, sql).Tables[0];
  55. return dt;
  56. }
  57. public static bool UpdateIQCCheck(SqlConnection sqlConnection, SqlTransaction trans, string LotNO, string iStatus, string User, string UserName, string WorkPoint, string dsconn)
  58. {
  59. string sql = "";
  60. string ConnectString = dsconn;
  61. bool isSuccess = false;
  62. SqlCommand cmd = new SqlCommand();
  63. cmd.Connection = sqlConnection;
  64. cmd.Transaction = trans;
  65. try
  66. {
  67. sql = @"
  68. INSERT INTO ICSLOTONWIPCheck
  69. (ID, ONWIPID, Result, [USER], TIME, MUSER, MUSERName, MTIME, WorkPoint)
  70. SELECT NEWID(), A.ID, '{1}', '{2}', GETDATE(), '{2}', '{3}', GETDATE(), '{4}' FROM ICSLOTONWIP A
  71. LEFT JOIN ICSLOTONWIPCheck B ON A.ID = B.ONWIPID WHERE 1=1 AND LOTNO = '{0}' AND B.ID IS NULL ";
  72. sql = string.Format(sql, LotNO, iStatus, User, UserName, WorkPoint);
  73. cmd.CommandText = sql;
  74. cmd.ExecuteNonQuery();
  75. isSuccess = true;
  76. }
  77. catch (Exception ex)
  78. {
  79. throw new Exception(ex.Message);
  80. }
  81. return isSuccess;
  82. }
  83. public static DataTable isFinished(string LotNO, string dsconn)
  84. {
  85. string sql = @"SELECT TOP 1 CollectStatus FROM ICSLOTSIMULATION WHERE 1=1 AND LOTNO = '{0}' ORDER BY MTIME DESC ";
  86. sql = string.Format(sql, LotNO);
  87. DataTable dt = DBHelper.ExecuteDataset(dsconn, CommandType.Text, sql).Tables[0];
  88. return dt;
  89. }
  90. }
  91. }