SplitTableUpdateByObjectProvider.cs 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Reflection;
  5. using System.Text;
  6. using System.Text.RegularExpressions;
  7. using System.Threading.Tasks;
  8. namespace SqlSugar
  9. {
  10. public class SplitTableUpdateByObjectProvider<T> where T : class, new()
  11. {
  12. public SqlSugarProvider Context;
  13. public UpdateableProvider<T> updateobj;
  14. public T[] UpdateObjects { get; set; }
  15. public IEnumerable<SplitTableInfo> Tables { get; set; }
  16. public int ExecuteCommandWithOptLock(bool isThrowError = false)
  17. {
  18. List<GroupModel> groupModels;
  19. int result;
  20. GroupDataList(UpdateObjects, out groupModels, out result);
  21. foreach (var item in groupModels.GroupBy(it => it.GroupName))
  22. {
  23. var addList = item.Select(it => it.Item).ToList();
  24. result += this.Context.Updateable(addList)
  25. .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
  26. .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity, this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
  27. .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommandWithOptLock(isThrowError);
  28. }
  29. return result;
  30. }
  31. public int ExecuteCommand()
  32. {
  33. List<GroupModel> groupModels;
  34. int result;
  35. GroupDataList(UpdateObjects, out groupModels, out result);
  36. foreach (var item in groupModels.GroupBy(it => it.GroupName))
  37. {
  38. var addList = item.Select(it => it.Item).ToList();
  39. result += this.Context.Updateable(addList)
  40. .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
  41. .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity,this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
  42. .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommand();
  43. }
  44. return result;
  45. }
  46. public async Task<int> ExecuteCommandAsync()
  47. {
  48. List<GroupModel> groupModels;
  49. int result;
  50. GroupDataList(UpdateObjects, out groupModels, out result);
  51. foreach (var item in groupModels.GroupBy(it => it.GroupName))
  52. {
  53. var addList = item.Select(it => it.Item).ToList();
  54. result += await this.Context.Updateable(addList)
  55. .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
  56. .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity, this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
  57. .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommandAsync();
  58. }
  59. return result;
  60. }
  61. public async Task<int> ExecuteCommandWithOptLockAsync(bool isThrowError = false)
  62. {
  63. List<GroupModel> groupModels;
  64. int result;
  65. GroupDataList(UpdateObjects, out groupModels, out result);
  66. foreach (var item in groupModels.GroupBy(it => it.GroupName))
  67. {
  68. var addList = item.Select(it => it.Item).ToList();
  69. result += await this.Context.Updateable(addList)
  70. .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
  71. .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity, this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
  72. .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommandWithOptLockAsync(isThrowError);
  73. }
  74. return result;
  75. }
  76. private string [] GetIgnoreColumns()
  77. {
  78. if (this.updateobj.UpdateBuilder.DbColumnInfoList.Any())
  79. {
  80. var columns=this.updateobj.UpdateBuilder.DbColumnInfoList.Select(it => it.DbColumnName).Distinct().ToList();
  81. var result= this.Context.EntityMaintenance.GetEntityInfo<T>().Columns.Where(x => !columns.Any(y => y.EqualCase(x.DbColumnName))).Select(it => it.DbColumnName).ToArray();
  82. result = result.Where(it => !string.IsNullOrEmpty(it)).ToArray();
  83. return result;
  84. }
  85. else
  86. {
  87. return null;
  88. }
  89. }
  90. private void GroupDataList(T[] datas, out List<GroupModel> groupModels, out int result)
  91. {
  92. var attribute = typeof(T).GetCustomAttribute<SplitTableAttribute>() as SplitTableAttribute;
  93. Check.Exception(attribute == null, $"{typeof(T).Name} need SplitTableAttribute");
  94. groupModels = new List<GroupModel>();
  95. var db = this.Context;
  96. foreach (var item in datas)
  97. {
  98. var value = db.SplitHelper<T>().GetValue(attribute.SplitType, item);
  99. var tableName = db.SplitHelper<T>().GetTableName(attribute.SplitType, value);
  100. groupModels.Add(new GroupModel() { GroupName = tableName, Item = item });
  101. }
  102. result = 0;
  103. }
  104. internal class GroupModel
  105. {
  106. public string GroupName { get; set; }
  107. public T Item { get; set; }
  108. }
  109. }
  110. }