123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Reflection;
- using System.Text;
- using System.Text.RegularExpressions;
- using System.Threading.Tasks;
- namespace SqlSugar
- {
- public class SplitTableUpdateByObjectProvider<T> where T : class, new()
- {
- public SqlSugarProvider Context;
- public UpdateableProvider<T> updateobj;
- public T[] UpdateObjects { get; set; }
- public IEnumerable<SplitTableInfo> Tables { get; set; }
- public int ExecuteCommandWithOptLock(bool isThrowError = false)
- {
- List<GroupModel> groupModels;
- int result;
- GroupDataList(UpdateObjects, out groupModels, out result);
- foreach (var item in groupModels.GroupBy(it => it.GroupName))
- {
- var addList = item.Select(it => it.Item).ToList();
- result += this.Context.Updateable(addList)
- .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
- .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity, this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
- .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommandWithOptLock(isThrowError);
- }
- return result;
- }
- public int ExecuteCommand()
- {
- List<GroupModel> groupModels;
- int result;
- GroupDataList(UpdateObjects, out groupModels, out result);
- foreach (var item in groupModels.GroupBy(it => it.GroupName))
- {
- var addList = item.Select(it => it.Item).ToList();
- result += this.Context.Updateable(addList)
- .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
- .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity,this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
- .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommand();
- }
- return result;
- }
- public async Task<int> ExecuteCommandAsync()
- {
- List<GroupModel> groupModels;
- int result;
- GroupDataList(UpdateObjects, out groupModels, out result);
- foreach (var item in groupModels.GroupBy(it => it.GroupName))
- {
- var addList = item.Select(it => it.Item).ToList();
- result += await this.Context.Updateable(addList)
- .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
- .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity, this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
- .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommandAsync();
- }
- return result;
- }
- public async Task<int> ExecuteCommandWithOptLockAsync(bool isThrowError = false)
- {
- List<GroupModel> groupModels;
- int result;
- GroupDataList(UpdateObjects, out groupModels, out result);
- foreach (var item in groupModels.GroupBy(it => it.GroupName))
- {
- var addList = item.Select(it => it.Item).ToList();
- result += await this.Context.Updateable(addList)
- .UpdateColumns(updateobj.UpdateBuilder.UpdateColumns?.ToArray())
- .IgnoreColumns(this.updateobj.UpdateBuilder.IsNoUpdateNull, this.updateobj.UpdateBuilder.IsOffIdentity, this.updateobj.UpdateBuilder.IsNoUpdateDefaultValue)
- .IgnoreColumns(GetIgnoreColumns()).AS(item.Key).ExecuteCommandWithOptLockAsync(isThrowError);
- }
- return result;
- }
- private string [] GetIgnoreColumns()
- {
- if (this.updateobj.UpdateBuilder.DbColumnInfoList.Any())
- {
- var columns=this.updateobj.UpdateBuilder.DbColumnInfoList.Select(it => it.DbColumnName).Distinct().ToList();
- var result= this.Context.EntityMaintenance.GetEntityInfo<T>().Columns.Where(x => !columns.Any(y => y.EqualCase(x.DbColumnName))).Select(it => it.DbColumnName).ToArray();
- result = result.Where(it => !string.IsNullOrEmpty(it)).ToArray();
- return result;
- }
- else
- {
- return null;
- }
- }
- private void GroupDataList(T[] datas, out List<GroupModel> groupModels, out int result)
- {
- var attribute = typeof(T).GetCustomAttribute<SplitTableAttribute>() as SplitTableAttribute;
- Check.Exception(attribute == null, $"{typeof(T).Name} need SplitTableAttribute");
- groupModels = new List<GroupModel>();
- var db = this.Context;
- foreach (var item in datas)
- {
- var value = db.SplitHelper<T>().GetValue(attribute.SplitType, item);
- var tableName = db.SplitHelper<T>().GetTableName(attribute.SplitType, value);
- groupModels.Add(new GroupModel() { GroupName = tableName, Item = item });
- }
- result = 0;
- }
- internal class GroupModel
- {
- public string GroupName { get; set; }
- public T Item { get; set; }
- }
- }
- }
|