JLH_FetchPriceExcutor.cs 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using JLHHJSvr.Com;
  5. using JLHHJSvr.Com.Model;
  6. using LJLib.Net.SPI.Server;
  7. using LJLib.SQLEX;
  8. namespace JLHHJSvr.Excutor
  9. {
  10. internal sealed class JLH_FetchPriceExcutor:ExcutorBase<JLH_FetchPriceRequest, JLH_FetchPriceResponse>
  11. {
  12. protected override void ExcuteInternal(JLH_FetchPriceRequest request, object state, JLH_FetchPriceResponse rslt)
  13. {
  14. if (request.token != "7DEA6FF3-3E81-4EDA-8A02-1F56073A45FD")
  15. {
  16. rslt.ErrMsg = "会话已经中断,请重新登录";
  17. return;
  18. }
  19. using (var con = GlobalVar.ConnectionString.NewSqlConnection())
  20. using (var cmd = con.CreateCommand())
  21. {
  22. con.Open();
  23. rslt.list = new List<u_configure_codemx>();
  24. cmd.CommandText = @"SELECT
  25. MAX(
  26. CASE WHEN u_mattress_interface_qd.erp_mtrlid > 0 and u_mattress_interface_qd.useqty > 0
  27. THEN u_mattress_mx_mtrl.costamt / u_mattress_interface_qd.useqty
  28. ELSE 0 END
  29. ) AS price
  30. ,MAX(u_mattress_interface_qd.useqty) AS useqty
  31. , u_mattress.erp_mtrlcode
  32. , u_mtrldef.mtrlcode
  33. , u_mattress_interface_qd.wrkgrpcode2
  34. from u_mattress_interface_qd
  35. INNER JOIN u_mattress_mx_mtrl on u_mattress_mx_mtrl.mattressid = u_mattress_interface_qd.mattressid
  36. and u_mattress_mx_mtrl.mtrlid = u_mattress_interface_qd.mtrlid
  37. INNER JOIN u_mtrldef on u_mtrldef.mtrlid = u_mattress_interface_qd.erp_mtrlid
  38. INNER JOIN u_mattress on u_mattress.mattressid = u_mattress_interface_qd.mattressid
  39. WHERE
  40. u_mattress_interface_qd.erp_mtrlid > 0
  41. and u_mattress_interface_qd.actual_useqty > 0
  42. and u_mattress_interface_qd.mtrlid > 0
  43. GROUP BY u_mtrldef.mtrlcode, u_mattress.erp_mtrlcode, u_mattress_interface_qd.wrkgrpcode2
  44. ";
  45. cmd.Parameters.Clear();
  46. using (var reader = cmd.ExecuteReader())
  47. {
  48. while (reader.Read())
  49. {
  50. rslt.list.Add(new u_configure_codemx()
  51. {
  52. mtrlcode = Convert.ToString(reader["mtrlcode"]).Trim(),
  53. price = Convert.ToDecimal(reader["price"]),
  54. useqty = Convert.ToDecimal(reader["useqty"]),
  55. erp_mtrlcode = Convert.ToString(reader["erp_mtrlcode"]).Trim(),
  56. wrkgrpcode2 = Convert.ToString(reader["wrkgrpcode2"]).Trim(),
  57. });
  58. }
  59. }
  60. }
  61. }
  62. }
  63. }