PublicTableHelper.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. using MySystem.Models;
  2. using System;
  3. using System.Data;
  4. using Library;
  5. namespace MySystem
  6. {
  7. public class PublicTableHelper
  8. {
  9. public readonly static PublicTableHelper Instance = new PublicTableHelper();
  10. private PublicTableHelper()
  11. { }
  12. public string Start(string table)
  13. {
  14. bool op = true;
  15. OtherMySqlConn.connstr = Library.ConfigurationManager.AppSettings["Pxc1SqlConnStr"].ToString();
  16. string result = "success";
  17. int startId = TendisDbconn.Instance.Get<int>("Start" + table + "Id");
  18. // int total = 0;
  19. while (op)
  20. {
  21. try
  22. {
  23. DataTable dt = OtherMySqlConn.dtable("select * from " + table + " where Id>" + startId + " order by Id");
  24. if (dt.Rows.Count > 0)
  25. {
  26. foreach (DataRow dr in dt.Rows)
  27. {
  28. startId = int.Parse(function.CheckInt(dr["Id"].ToString()));
  29. string fields = "";
  30. string values = "";
  31. DataTable localTable = dbconn.dtable("select * from " + table + " where Id=" + startId);
  32. if (localTable.Rows.Count > 0)
  33. {
  34. foreach (DataColumn dc in localTable.Columns)
  35. {
  36. if (!string.IsNullOrEmpty(dr[dc.ColumnName].ToString()))
  37. {
  38. fields += dc.ColumnName + ",";
  39. if (dc.DataType == typeof(int) || dc.DataType == typeof(decimal) || dc.DataType == typeof(ulong))
  40. {
  41. fields += dc.ColumnName + "=" + dr[dc.ColumnName].ToString() + ",";
  42. }
  43. else
  44. {
  45. fields += dc.ColumnName + "='" + dr[dc.ColumnName].ToString() + "',";
  46. }
  47. }
  48. }
  49. fields = fields.TrimEnd(',');
  50. string sql = "update " + table + " set " + fields + " where Id=" + startId;
  51. dbconn.op(sql);
  52. }
  53. else
  54. {
  55. foreach (DataColumn dc in localTable.Columns)
  56. {
  57. if (!string.IsNullOrEmpty(dr[dc.ColumnName].ToString()))
  58. {
  59. fields += dc.ColumnName + ",";
  60. if (dc.DataType == typeof(int) || dc.DataType == typeof(decimal) || dc.DataType == typeof(ulong))
  61. {
  62. values += dr[dc.ColumnName].ToString() + ",";
  63. }
  64. else
  65. {
  66. string val = "";
  67. if (dc.DataType == typeof(DateTime))
  68. {
  69. val = DateTime.Parse(dr[dc.ColumnName].ToString()).ToString("yyyy-MM-dd HH:mm:ss");
  70. }
  71. else
  72. {
  73. val = dr[dc.ColumnName].ToString();
  74. }
  75. values += "'" + val + "',";
  76. }
  77. }
  78. }
  79. fields = fields.TrimEnd(',');
  80. values = values.TrimEnd(',');
  81. string sql = "insert into " + table + " (" + fields + ") values (" + values + ")";
  82. dbconn.op(sql);
  83. }
  84. startId = int.Parse(function.CheckInt(dr["Id"].ToString()));
  85. }
  86. }
  87. else
  88. {
  89. op = false;
  90. TendisDbconn.Instance.Set("Start" + table + "Id", startId);
  91. }
  92. }
  93. catch (Exception ex)
  94. {
  95. ErrorMsg msg = new ErrorMsg();
  96. msg.Time = DateTime.Now;
  97. msg.ErrorContent = ex.ToString();
  98. TendisDbconn.Instance.AddList(table + ":Error", msg);
  99. }
  100. }
  101. OtherMySqlConn.connstr = "";
  102. return result;
  103. }
  104. }
  105. }