mirror of
				https://github.com/nsnail/FreeSql.git
				synced 2025-11-04 09:15:27 +08:00 
			
		
		
		
	- 增加 IUpdate.ExecuteUpdated 重载方法返回指定字段;#1681
This commit is contained in:
		@@ -27,8 +27,10 @@ namespace FreeSql.ClickHouse.Curd
 | 
			
		||||
        internal void InternalToSqlCaseWhenEnd(StringBuilder sb, ColumnInfo col) => ToSqlCaseWhenEnd(sb, col);
 | 
			
		||||
 | 
			
		||||
        public override int ExecuteAffrows() => SplitExecuteAffrows(_batchRowsLimit > 0 ? _batchRowsLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 3000);
 | 
			
		||||
        public override List<T1> ExecuteUpdated() => SplitExecuteUpdated(_batchRowsLimit > 0 ? _batchRowsLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 3000);
 | 
			
		||||
        protected override List<T1> RawExecuteUpdated() => throw new NotImplementedException($"FreeSql.Provider.ClickHouse {CoreStrings.S_Not_Implemented_Feature}");
 | 
			
		||||
		protected override List<TReturn> ExecuteUpdated<TReturn>(IEnumerable<ColumnInfo> columns) => base.SplitExecuteUpdated<TReturn>(_batchRowsLimit > 0 ? _batchRowsLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 3000, columns);
 | 
			
		||||
 | 
			
		||||
		protected override List<TReturn> RawExecuteUpdated<TReturn>(IEnumerable<ColumnInfo> columns) => throw new NotImplementedException($"FreeSql.Provider.ClickHouse {CoreStrings.S_Not_Implemented_Feature}");
 | 
			
		||||
 | 
			
		||||
        protected override void ToSqlCase(StringBuilder caseWhen, ColumnInfo[] primarys)
 | 
			
		||||
        {
 | 
			
		||||
            if (primarys.Length == 1)
 | 
			
		||||
@@ -228,167 +230,84 @@ namespace FreeSql.ClickHouse.Curd
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        protected override int SplitExecuteAffrows(int valuesLimit, int parameterLimit)
 | 
			
		||||
        {
 | 
			
		||||
            var ss = base.SplitSource(valuesLimit, parameterLimit);
 | 
			
		||||
            var ret = 0;
 | 
			
		||||
            if (ss.Length <= 1)
 | 
			
		||||
            {
 | 
			
		||||
                if (_source?.Any() == true) _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, 1, 1));
 | 
			
		||||
                ret = this.RawExecuteAffrows();
 | 
			
		||||
                ClearData();
 | 
			
		||||
                return ret;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            var before = new Aop.TraceBeforeEventArgs("SplitExecuteAffrows", null);
 | 
			
		||||
            _orm.Aop.TraceBeforeHandler?.Invoke(this, before);
 | 
			
		||||
            Exception exception = null;
 | 
			
		||||
            try
 | 
			
		||||
            {
 | 
			
		||||
                for (var a = 0; a < ss.Length; a++)
 | 
			
		||||
                {
 | 
			
		||||
                    _source = ss[a];
 | 
			
		||||
                    _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, a + 1, ss.Length));
 | 
			
		||||
                    ret += this.RawExecuteAffrows();
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            catch (Exception ex)
 | 
			
		||||
            {
 | 
			
		||||
                exception = ex;
 | 
			
		||||
                throw;
 | 
			
		||||
            }
 | 
			
		||||
            finally
 | 
			
		||||
            {
 | 
			
		||||
                var after = new Aop.TraceAfterEventArgs(before, null, exception);
 | 
			
		||||
                _orm.Aop.TraceAfterHandler?.Invoke(this, after);
 | 
			
		||||
            }
 | 
			
		||||
            ClearData();
 | 
			
		||||
            return ret;
 | 
			
		||||
        }
 | 
			
		||||
        protected override List<T1> SplitExecuteUpdated(int valuesLimit, int parameterLimit)
 | 
			
		||||
        {
 | 
			
		||||
            var ss = SplitSource(valuesLimit, parameterLimit);
 | 
			
		||||
            var ret = new List<T1>();
 | 
			
		||||
            if (ss.Length <= 1)
 | 
			
		||||
            {
 | 
			
		||||
                if (_source?.Any() == true) _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, 1, 1));
 | 
			
		||||
                ret = this.RawExecuteUpdated();
 | 
			
		||||
                ClearData();
 | 
			
		||||
                return ret;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            var before = new Aop.TraceBeforeEventArgs("SplitExecuteUpdated", null);
 | 
			
		||||
            _orm.Aop.TraceBeforeHandler?.Invoke(this, before);
 | 
			
		||||
            Exception exception = null;
 | 
			
		||||
            try
 | 
			
		||||
            {
 | 
			
		||||
                for (var a = 0; a < ss.Length; a++)
 | 
			
		||||
                {
 | 
			
		||||
                    _source = ss[a];
 | 
			
		||||
                    _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, a + 1, ss.Length));
 | 
			
		||||
                    ret.AddRange(this.RawExecuteUpdated());
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            catch (Exception ex)
 | 
			
		||||
            {
 | 
			
		||||
                exception = ex;
 | 
			
		||||
                throw;
 | 
			
		||||
            }
 | 
			
		||||
            finally
 | 
			
		||||
            {
 | 
			
		||||
                var after = new Aop.TraceAfterEventArgs(before, null, exception);
 | 
			
		||||
                _orm.Aop.TraceAfterHandler?.Invoke(this, after);
 | 
			
		||||
            }
 | 
			
		||||
            ClearData();
 | 
			
		||||
            return ret;
 | 
			
		||||
        }
 | 
			
		||||
		protected override void SplitExecute(int valuesLimit, int parameterLimit, string traceName, Action execute)
 | 
			
		||||
		{
 | 
			
		||||
			var ss = SplitSource(valuesLimit, parameterLimit);
 | 
			
		||||
			if (ss.Length <= 1)
 | 
			
		||||
			{
 | 
			
		||||
				if (_source?.Any() == true) _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, 1, 1));
 | 
			
		||||
				execute();
 | 
			
		||||
				ClearData();
 | 
			
		||||
				return;
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			var before = new Aop.TraceBeforeEventArgs(traceName, null);
 | 
			
		||||
			_orm.Aop.TraceBeforeHandler?.Invoke(this, before);
 | 
			
		||||
			Exception exception = null;
 | 
			
		||||
			try
 | 
			
		||||
			{
 | 
			
		||||
				for (var a = 0; a < ss.Length; a++)
 | 
			
		||||
				{
 | 
			
		||||
					_source = ss[a];
 | 
			
		||||
					_batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, a + 1, ss.Length));
 | 
			
		||||
					execute();
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
			catch (Exception ex)
 | 
			
		||||
			{
 | 
			
		||||
				exception = ex;
 | 
			
		||||
				throw;
 | 
			
		||||
			}
 | 
			
		||||
			finally
 | 
			
		||||
			{
 | 
			
		||||
				var after = new Aop.TraceAfterEventArgs(before, null, exception);
 | 
			
		||||
				_orm.Aop.TraceAfterHandler?.Invoke(this, after);
 | 
			
		||||
			}
 | 
			
		||||
			ClearData();
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
#if net40
 | 
			
		||||
#else
 | 
			
		||||
        public override Task<int> ExecuteAffrowsAsync(CancellationToken cancellationToken = default) => SplitExecuteAffrowsAsync(_batchRowsLimit > 0 ? _batchRowsLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 3000, cancellationToken);
 | 
			
		||||
        public override Task<List<T1>> ExecuteUpdatedAsync(CancellationToken cancellationToken = default) => SplitExecuteUpdatedAsync(_batchRowsLimit > 0 ? _batchRowsLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 3000, cancellationToken);
 | 
			
		||||
        protected override Task<List<T1>> RawExecuteUpdatedAsync(CancellationToken cancellationToken = default) => throw new NotImplementedException($"FreeSql.Provider.ClickHouse {CoreStrings.S_Not_Implemented_Feature}");
 | 
			
		||||
		protected override Task<List<TReturn>> ExecuteUpdatedAsync<TReturn>(IEnumerable<ColumnInfo> columns, CancellationToken cancellationToken = default) => base.SplitExecuteUpdatedAsync<TReturn>(_batchRowsLimit > 0 ? _batchRowsLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 3000, columns, cancellationToken);
 | 
			
		||||
 | 
			
		||||
        async protected override Task<int> SplitExecuteAffrowsAsync(int valuesLimit, int parameterLimit, CancellationToken cancellationToken = default)
 | 
			
		||||
        
 | 
			
		||||
        {
 | 
			
		||||
            var ss = SplitSource(valuesLimit, parameterLimit);
 | 
			
		||||
            var ret = 0;
 | 
			
		||||
            if (ss.Length <= 1)
 | 
			
		||||
            {
 | 
			
		||||
                if (_source?.Any() == true) _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, 1, 1));
 | 
			
		||||
                await this.RawExecuteAffrowsAsync(cancellationToken);
 | 
			
		||||
                ret = _source.Count;
 | 
			
		||||
                ClearData();
 | 
			
		||||
                return ret;
 | 
			
		||||
            }
 | 
			
		||||
		protected override Task<List<TReturn>> RawExecuteUpdatedAsync<TReturn>(IEnumerable<ColumnInfo> columns, CancellationToken cancellationToken = default) => throw new NotImplementedException($"FreeSql.Provider.ClickHouse {CoreStrings.S_Not_Implemented_Feature}");
 | 
			
		||||
 | 
			
		||||
		async protected override Task SplitExecuteAsync(int valuesLimit, int parameterLimit, string traceName, Func<Task> executeAsync, CancellationToken cancellationToken = default)
 | 
			
		||||
		{
 | 
			
		||||
			var ss = SplitSource(valuesLimit, parameterLimit);
 | 
			
		||||
			if (ss.Length <= 1)
 | 
			
		||||
			{
 | 
			
		||||
				if (_source?.Any() == true) _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, 1, 1));
 | 
			
		||||
				await executeAsync();
 | 
			
		||||
				ClearData();
 | 
			
		||||
				return;
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
            var before = new Aop.TraceBeforeEventArgs("SplitExecuteAffrowsAsync", null);
 | 
			
		||||
            _orm.Aop.TraceBeforeHandler?.Invoke(this, before);
 | 
			
		||||
            Exception exception = null;
 | 
			
		||||
            try
 | 
			
		||||
            {
 | 
			
		||||
                for (var a = 0; a < ss.Length; a++)
 | 
			
		||||
                {
 | 
			
		||||
                    _source = ss[a];
 | 
			
		||||
                    _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, a + 1, ss.Length));
 | 
			
		||||
                    await this.RawExecuteAffrowsAsync(cancellationToken);
 | 
			
		||||
                    ret += _source.Count;
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            catch (Exception ex)
 | 
			
		||||
            {
 | 
			
		||||
                exception = ex;
 | 
			
		||||
                throw;
 | 
			
		||||
            }
 | 
			
		||||
            finally
 | 
			
		||||
            {
 | 
			
		||||
                var after = new Aop.TraceAfterEventArgs(before, null, exception);
 | 
			
		||||
                _orm.Aop.TraceAfterHandler?.Invoke(this, after);
 | 
			
		||||
            }
 | 
			
		||||
            ClearData();
 | 
			
		||||
            return ret;
 | 
			
		||||
        }
 | 
			
		||||
        async protected override Task<List<T1>> SplitExecuteUpdatedAsync(int valuesLimit, int parameterLimit, CancellationToken cancellationToken = default)
 | 
			
		||||
        {
 | 
			
		||||
            var ss = SplitSource(valuesLimit, parameterLimit);
 | 
			
		||||
            var ret = new List<T1>();
 | 
			
		||||
            if (ss.Length <= 1)
 | 
			
		||||
            {
 | 
			
		||||
                if (_source?.Any() == true) _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, 1, 1));
 | 
			
		||||
                ret = await this.RawExecuteUpdatedAsync(cancellationToken);
 | 
			
		||||
                ClearData();
 | 
			
		||||
                return ret;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            var before = new Aop.TraceBeforeEventArgs("SplitExecuteUpdatedAsync", null);
 | 
			
		||||
            _orm.Aop.TraceBeforeHandler?.Invoke(this, before);
 | 
			
		||||
            Exception exception = null;
 | 
			
		||||
            try
 | 
			
		||||
            {
 | 
			
		||||
                for (var a = 0; a < ss.Length; a++)
 | 
			
		||||
                {
 | 
			
		||||
                    _source = ss[a];
 | 
			
		||||
                    _batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, a + 1, ss.Length));
 | 
			
		||||
                    ret.AddRange(await this.RawExecuteUpdatedAsync(cancellationToken));
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            catch (Exception ex)
 | 
			
		||||
            {
 | 
			
		||||
                exception = ex;
 | 
			
		||||
                throw;
 | 
			
		||||
            }
 | 
			
		||||
            finally
 | 
			
		||||
            {
 | 
			
		||||
                var after = new Aop.TraceAfterEventArgs(before, null, exception);
 | 
			
		||||
                _orm.Aop.TraceAfterHandler?.Invoke(this, after);
 | 
			
		||||
            }
 | 
			
		||||
            ClearData();
 | 
			
		||||
            return ret;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
			var before = new Aop.TraceBeforeEventArgs(traceName, null);
 | 
			
		||||
			_orm.Aop.TraceBeforeHandler?.Invoke(this, before);
 | 
			
		||||
			Exception exception = null;
 | 
			
		||||
			try
 | 
			
		||||
			{
 | 
			
		||||
				for (var a = 0; a < ss.Length; a++)
 | 
			
		||||
				{
 | 
			
		||||
					_source = ss[a];
 | 
			
		||||
					_batchProgress?.Invoke(new BatchProgressStatus<T1>(_source, a + 1, ss.Length));
 | 
			
		||||
					await executeAsync();
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
			catch (Exception ex)
 | 
			
		||||
			{
 | 
			
		||||
				exception = ex;
 | 
			
		||||
				throw;
 | 
			
		||||
			}
 | 
			
		||||
			finally
 | 
			
		||||
			{
 | 
			
		||||
				var after = new Aop.TraceAfterEventArgs(before, null, exception);
 | 
			
		||||
				_orm.Aop.TraceAfterHandler?.Invoke(this, after);
 | 
			
		||||
			}
 | 
			
		||||
			ClearData();
 | 
			
		||||
		}
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user