DataJudge.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. /*******************************************************************************
  2. * Copyright(c) 2012 dongke All rights reserved. / Confidential
  3. * 类的信息:
  4. * 1.程序名称:DataJudge.cs
  5. * 2.功能描述:对各种数据集数据是否变化的判断类
  6. * 编辑履历:
  7. * 作者 日期 版本 修改内容
  8. * 欧阳涛 2012/06/07 1.00 新建
  9. *******************************************************************************/
  10. using System;
  11. using System.Data;
  12. using System.Windows.Forms;
  13. namespace Dongke.IBOSS.PRD.Basics.Library
  14. {
  15. /// <summary>
  16. /// 对各种数据集数据是否变化的判断类
  17. /// </summary>
  18. public class DataJudge
  19. {
  20. #region IsChange函数
  21. /// <summary>
  22. /// 判断DataSet里面的内容是否发生了改变
  23. /// <br/>
  24. /// Modified状态的情况下,编辑前与编辑后的信息进行比较,查看是否有差异。
  25. /// </summary>
  26. /// <param name="dataSet">需要判断的数据集</param>
  27. /// <returns>
  28. /// True:数据集发生了改变
  29. /// False:数据集未发生改变
  30. /// </returns>
  31. public static bool IsChange(DataSet dataSet)
  32. {
  33. // 数据集为空的情况下,返回False
  34. if (dataSet == null)
  35. {
  36. return false;
  37. }
  38. // 将编辑中的行执行EndEdit结束编辑状态
  39. foreach (DataTable dataTable in dataSet.Tables)
  40. {
  41. foreach (DataRow dataRow in dataTable.Rows)
  42. {
  43. dataRow.EndEdit();
  44. }
  45. }
  46. // 取得数据集中变化的部分,如果为空返回False
  47. DataSet setChanges = dataSet.GetChanges();
  48. if (setChanges == null)
  49. {
  50. return false;
  51. }
  52. // 变化部分的数据表有改变的情况下返回True
  53. foreach (DataTable dataTable in setChanges.Tables)
  54. {
  55. if (IsChange(dataTable))
  56. {
  57. return true;
  58. }
  59. }
  60. return false;
  61. }
  62. /// <summary>
  63. /// 判断DataTable里面的内容是否发生了改变
  64. /// </summary>
  65. /// <param name="dataTable">需要判断的数据集</param>
  66. /// <returns>
  67. /// True:DataTable发生了改变
  68. /// False:DataTable未发生改变
  69. /// </returns>
  70. public static bool IsChange(DataTable dataTable)
  71. {
  72. // 数据表为空的情况下,返回false
  73. if (dataTable == null)
  74. {
  75. return false;
  76. }
  77. // 数据表中有新增数据,返回True
  78. if (dataTable.GetChanges(DataRowState.Added) != null)
  79. {
  80. return true;
  81. }
  82. // 数据表中有删除的数据,返回True
  83. if (dataTable.GetChanges(DataRowState.Deleted) != null)
  84. {
  85. return true;
  86. }
  87. // 判断每一行是否有被编辑过的数据
  88. DataTable tableChanges = dataTable.GetChanges(DataRowState.Modified);
  89. if (tableChanges != null)
  90. {
  91. foreach (DataRow dataRow in tableChanges.Rows)
  92. {
  93. if (IsChange(dataRow))
  94. {
  95. return true;
  96. }
  97. }
  98. }
  99. return false;
  100. }
  101. /// <summary>
  102. /// 判断DataRow数据集里面的内容是否发生了改变
  103. /// </summary>
  104. /// <param name="dataRow">需要判断的DataRow数据集</param>
  105. /// <returns>
  106. /// True:DataRow发生了改变
  107. /// False:DataRow未发生改变
  108. /// </returns>
  109. public static bool IsChange(DataRow dataRow)
  110. {
  111. // DataRow为空的情况,返回False
  112. if (dataRow == null)
  113. {
  114. return false;
  115. }
  116. // DataRow的行状态为增加或者删除的状态,返回True
  117. if (dataRow.RowState == DataRowState.Added
  118. || dataRow.RowState == DataRowState.Deleted)
  119. {
  120. return true;
  121. }
  122. // DataRow的状态为编辑状态,分别判断每一行的每一列是否有改变
  123. if (dataRow.RowState == DataRowState.Modified)
  124. {
  125. foreach (DataColumn dataColumn in dataRow.Table.Columns)
  126. {
  127. if (dataColumn.ReadOnly)
  128. {
  129. continue;
  130. }
  131. if (!Utility.Compare(dataRow[dataColumn, DataRowVersion.Original],
  132. dataRow[dataColumn, DataRowVersion.Current]))
  133. {
  134. return true;
  135. }
  136. }
  137. }
  138. return false;
  139. }
  140. #endregion
  141. }
  142. }