SplitInsertable.cs 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace SqlSugar
  7. {
  8. public class SplitInsertable<T> where T:class ,new()
  9. {
  10. private static readonly object SplitLockObj = new object();
  11. public SqlSugarProvider Context;
  12. internal SplitTableContext Helper;
  13. public EntityInfo EntityInfo;
  14. public SplitType SplitType;
  15. internal IInsertable<T> Inserable { get; set; }
  16. internal List<KeyValuePair<string,object>> TableNames { get; set; }
  17. public int ExecuteCommand()
  18. {
  19. if (this.Context.Ado.Transaction == null)
  20. {
  21. try
  22. {
  23. this.Context.Ado.BeginTran();
  24. var result = _ExecuteCommand();
  25. this.Context.Ado.CommitTran();
  26. return result;
  27. }
  28. catch (Exception ex)
  29. {
  30. this.Context.Ado.RollbackTran();
  31. throw ex;
  32. }
  33. }
  34. else
  35. {
  36. return _ExecuteCommand();
  37. }
  38. }
  39. public async Task<int> ExecuteCommandAsync()
  40. {
  41. if (this.Context.Ado.Transaction == null)
  42. {
  43. try
  44. {
  45. this.Context.Ado.BeginTran();
  46. var result = await _ExecuteCommandAsync();
  47. this.Context.Ado.CommitTran();
  48. return result;
  49. }
  50. catch (Exception ex)
  51. {
  52. this.Context.Ado.RollbackTran();
  53. throw ex;
  54. }
  55. }
  56. else
  57. {
  58. return await _ExecuteCommandAsync();
  59. }
  60. }
  61. public List<long> ExecuteReturnSnowflakeIdList()
  62. {
  63. if (this.Context.Ado.Transaction == null)
  64. {
  65. try
  66. {
  67. this.Context.Ado.BeginTran();
  68. var result = _ExecuteReturnSnowflakeIdList();
  69. this.Context.Ado.CommitTran();
  70. return result;
  71. }
  72. catch (Exception ex)
  73. {
  74. this.Context.Ado.RollbackTran();
  75. throw ex;
  76. }
  77. }
  78. else
  79. {
  80. return _ExecuteReturnSnowflakeIdList();
  81. }
  82. }
  83. public async Task<List<long>> ExecuteReturnSnowflakeIdListAsync()
  84. {
  85. if (this.Context.Ado.Transaction == null)
  86. {
  87. try
  88. {
  89. this.Context.Ado.BeginTran();
  90. var result = await _ExecuteReturnSnowflakeIdListAsync();
  91. this.Context.Ado.CommitTran();
  92. return result;
  93. }
  94. catch (Exception ex)
  95. {
  96. this.Context.Ado.RollbackTran();
  97. throw ex;
  98. }
  99. }
  100. else
  101. {
  102. return await _ExecuteReturnSnowflakeIdListAsync();
  103. }
  104. }
  105. public long ExecuteReturnSnowflakeId()
  106. {
  107. return ExecuteReturnSnowflakeIdList().FirstOrDefault();
  108. }
  109. public async Task<long> ExecuteReturnSnowflakeIdAsync()
  110. {
  111. var list = await ExecuteReturnSnowflakeIdListAsync();
  112. return list.FirstOrDefault();
  113. }
  114. internal int _ExecuteCommand()
  115. {
  116. CreateTable();
  117. var result = 0;
  118. var groups = TableNames.GroupBy(it => it.Key).ToList();
  119. var parent = ((InsertableProvider<T>)Inserable);
  120. var names = parent.InsertBuilder.DbColumnInfoList.GroupBy(it => it.DbColumnName).Select(i => i.Key).ToList();
  121. foreach (var item in groups)
  122. {
  123. var list = item.Select(it => it.Value as T).ToList();
  124. var groupInserable = (InsertableProvider<T>)this.Context.Insertable<T>(list);
  125. groupInserable.InsertBuilder.TableWithString = parent.InsertBuilder.TableWithString;
  126. groupInserable.RemoveCacheFunc = parent.RemoveCacheFunc;
  127. groupInserable.diffModel = parent.diffModel;
  128. groupInserable.IsEnableDiffLogEvent = parent.IsEnableDiffLogEvent;
  129. groupInserable.InsertBuilder.IsNoInsertNull = parent.InsertBuilder.IsNoInsertNull;
  130. groupInserable.IsOffIdentity = parent.IsOffIdentity;
  131. result += groupInserable.AS(item.Key).InsertColumns(names.ToArray()).ExecuteCommand();
  132. }
  133. return result;
  134. }
  135. internal async Task<int> _ExecuteCommandAsync()
  136. {
  137. CreateTable();
  138. var result = 0;
  139. var groups = TableNames.GroupBy(it => it.Key).ToList();
  140. var parent = ((InsertableProvider<T>)Inserable);
  141. var names = parent.InsertBuilder.DbColumnInfoList.GroupBy(it => it.DbColumnName).Select(i => i.Key).ToList();
  142. foreach (var item in groups)
  143. {
  144. var list = item.Select(it => it.Value as T).ToList();
  145. var groupInserable = (InsertableProvider<T>)this.Context.Insertable<T>(list);
  146. groupInserable.InsertBuilder.TableWithString = parent.InsertBuilder.TableWithString;
  147. groupInserable.RemoveCacheFunc = parent.RemoveCacheFunc;
  148. groupInserable.diffModel = parent.diffModel;
  149. groupInserable.IsEnableDiffLogEvent = parent.IsEnableDiffLogEvent;
  150. groupInserable.InsertBuilder.IsNoInsertNull = parent.InsertBuilder.IsNoInsertNull;
  151. groupInserable.IsOffIdentity = parent.IsOffIdentity;
  152. result +=await groupInserable.AS(item.Key).InsertColumns(names.ToArray()).ExecuteCommandAsync();
  153. }
  154. return result;
  155. }
  156. internal List<long> _ExecuteReturnSnowflakeIdList()
  157. {
  158. CreateTable();
  159. var result = new List<long>();
  160. var groups = TableNames.GroupBy(it => it.Key).ToList();
  161. var parent = ((InsertableProvider<T>)Inserable);
  162. var names = parent.InsertBuilder.DbColumnInfoList.GroupBy(it => it.DbColumnName).Select(i => i.Key).ToList();
  163. foreach (var item in groups)
  164. {
  165. var list = item.Select(it => it.Value as T).ToList();
  166. var groupInserable = (InsertableProvider<T>)this.Context.Insertable<T>(list);
  167. groupInserable.InsertBuilder.TableWithString = parent.InsertBuilder.TableWithString;
  168. groupInserable.RemoveCacheFunc = parent.RemoveCacheFunc;
  169. groupInserable.diffModel = parent.diffModel;
  170. groupInserable.IsEnableDiffLogEvent = parent.IsEnableDiffLogEvent;
  171. groupInserable.InsertBuilder.IsNoInsertNull = parent.InsertBuilder.IsNoInsertNull;
  172. groupInserable.IsOffIdentity = parent.IsOffIdentity;
  173. var idList= groupInserable.AS(item.Key).InsertColumns(names.ToArray()).ExecuteReturnSnowflakeIdList();
  174. result.AddRange(idList);
  175. }
  176. return result;
  177. }
  178. internal async Task<List<long>> _ExecuteReturnSnowflakeIdListAsync()
  179. {
  180. CreateTable();
  181. var result = new List<long>();
  182. var groups = TableNames.GroupBy(it => it.Key).ToList();
  183. var parent = ((InsertableProvider<T>)Inserable);
  184. var names = parent.InsertBuilder.DbColumnInfoList.GroupBy(it => it.DbColumnName).Select(i => i.Key).ToList();
  185. foreach (var item in groups)
  186. {
  187. var list = item.Select(it => it.Value as T).ToList();
  188. var groupInserable = (InsertableProvider<T>)this.Context.Insertable<T>(list);
  189. groupInserable.InsertBuilder.TableWithString = parent.InsertBuilder.TableWithString;
  190. groupInserable.RemoveCacheFunc = parent.RemoveCacheFunc;
  191. groupInserable.diffModel = parent.diffModel;
  192. groupInserable.IsEnableDiffLogEvent = parent.IsEnableDiffLogEvent;
  193. groupInserable.InsertBuilder.IsNoInsertNull = parent.InsertBuilder.IsNoInsertNull;
  194. groupInserable.IsOffIdentity = parent.IsOffIdentity;
  195. var idList =await groupInserable.AS(item.Key).InsertColumns(names.ToArray()).ExecuteReturnSnowflakeIdListAsync();
  196. result.AddRange(idList);
  197. }
  198. return result;
  199. }
  200. private void CreateTable()
  201. {
  202. var isLog = this.Context.Ado.IsEnableLogEvent;
  203. this.Context.Ado.IsEnableLogEvent = false;
  204. foreach (var item in TableNames.GroupBy(it=>it.Key).Select(it=>it).ToDictionary(it=>it.Key,it=>it.First().Value))
  205. {
  206. if (!this.Context.CopyNew().DbMaintenance.IsAnyTable(item.Key, false))
  207. {
  208. lock (SplitLockObj)
  209. {
  210. if (!this.Context.CopyNew().DbMaintenance.IsAnyTable(item.Key, false))
  211. {
  212. if (item.Value != null)
  213. {
  214. this.Context.MappingTables.Add(EntityInfo.EntityName, item.Key);
  215. this.Context.CodeFirst.InitTables<T>();
  216. }
  217. }
  218. }
  219. }
  220. }
  221. this.Context.Ado.IsEnableLogEvent = isLog;
  222. this.Context.MappingTables.Add(EntityInfo.EntityName, EntityInfo.DbTableName);
  223. }
  224. }
  225. }