TDengineDataAdapter.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. using SqlSugar.TDengineAdo;
  2. using System;
  3. using System.Data;
  4. using System.Data.Common;
  5. namespace SqlSugar.BzTDengineCore
  6. {
  7. /// <summary>
  8. /// 数据填充器
  9. /// </summary>
  10. public class TDengineDataAdapter : IDataAdapter
  11. {
  12. private TDengineCommand command;
  13. private string sql;
  14. private TDengineConnection _TDengineConnection;
  15. /// <summary>
  16. /// SqlDataAdapter
  17. /// </summary>
  18. /// <param name="command"></param>
  19. public TDengineDataAdapter(TDengineCommand command)
  20. {
  21. this.command = command;
  22. }
  23. public TDengineDataAdapter()
  24. {
  25. }
  26. /// <summary>
  27. /// SqlDataAdapter
  28. /// </summary>
  29. /// <param name="sql"></param>
  30. /// <param name="_TDengineConnection"></param>
  31. public TDengineDataAdapter(string sql, TDengineConnection _TDengineConnection)
  32. {
  33. this.sql = sql;
  34. this._TDengineConnection = _TDengineConnection;
  35. }
  36. /// <summary>
  37. /// SelectCommand
  38. /// </summary>
  39. public TDengineCommand SelectCommand
  40. {
  41. get
  42. {
  43. if (this.command == null)
  44. {
  45. this.command = new TDengineCommand(this.sql, this._TDengineConnection);
  46. }
  47. return this.command;
  48. }
  49. set
  50. {
  51. this.command = value;
  52. }
  53. }
  54. public MissingMappingAction MissingMappingAction { get => throw new NotImplementedException(); set => throw new NotImplementedException(); }
  55. public MissingSchemaAction MissingSchemaAction { get => throw new NotImplementedException(); set => throw new NotImplementedException(); }
  56. public ITableMappingCollection TableMappings => throw new NotImplementedException();
  57. /// <summary>
  58. /// Fill
  59. /// </summary>
  60. /// <param name="dt"></param>
  61. public void Fill(DataTable dt)
  62. {
  63. if (dt == null)
  64. {
  65. dt = new DataTable();
  66. }
  67. var columns = dt.Columns;
  68. var rows = dt.Rows;
  69. using (DbDataReader dr = command.ExecuteReader())
  70. {
  71. for (int i = 0; i < dr.FieldCount; i++)
  72. {
  73. string name = dr.GetName(i).Trim();
  74. if (!columns.Contains(name))
  75. columns.Add(new DataColumn(name, dr.GetFieldType(i)));
  76. else
  77. {
  78. columns.Add(new DataColumn(name + i, dr.GetFieldType(i)));
  79. }
  80. }
  81. while (dr.Read())
  82. {
  83. DataRow daRow = dt.NewRow();
  84. for (int i = 0; i < columns.Count; i++)
  85. {
  86. daRow[columns[i].ColumnName] = dr.GetValue(i);
  87. }
  88. dt.Rows.Add(daRow);
  89. }
  90. }
  91. dt.AcceptChanges();
  92. }
  93. /// <summary>
  94. /// Fill
  95. /// </summary>
  96. /// <param name="ds"></param>
  97. public void Fill(DataSet ds)
  98. {
  99. if (ds == null)
  100. {
  101. ds = new DataSet();
  102. }
  103. using (DbDataReader dr = command.ExecuteReader())
  104. {
  105. do
  106. {
  107. var dt = new DataTable();
  108. var columns = dt.Columns;
  109. var rows = dt.Rows;
  110. for (int i = 0; i < dr.FieldCount; i++)
  111. {
  112. string name = dr.GetName(i).Trim();
  113. if (!columns.Contains(name))
  114. columns.Add(new DataColumn(name, dr.GetFieldType(i)));
  115. else
  116. {
  117. columns.Add(new DataColumn(name + i, dr.GetFieldType(i)));
  118. }
  119. }
  120. while (dr.Read())
  121. {
  122. DataRow daRow = dt.NewRow();
  123. for (int i = 0; i < columns.Count; i++)
  124. {
  125. daRow[columns[i].ColumnName] = dr.GetValue(i);
  126. }
  127. dt.Rows.Add(daRow);
  128. }
  129. dt.AcceptChanges();
  130. ds.Tables.Add(dt);
  131. } while (dr.NextResult());
  132. }
  133. }
  134. public DataTable[] FillSchema(DataSet dataSet, SchemaType schemaType)
  135. {
  136. throw new NotImplementedException();
  137. }
  138. }
  139. }