> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-mintlify-8c05c8a2.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

> توثيق نوع البيانات SimpleAggregateFunction

# نوع البيانات SimpleAggregateFunction

<div id="description">
  ## الوصف
</div>

يخزّن نوع البيانات `SimpleAggregateFunction` الحالة الوسيطة لدالة
تجميع، ولكن ليس حالتها الكاملة كما يفعل النوع [`AggregateFunction`](/ar/reference/data-types/aggregatefunction).

يمكن تطبيق هذا التحسين على الدوال التي تتحقق فيها الخاصية التالية:

> يمكن الحصول على نتيجة تطبيق الدالة `f` على مجموعة الصفوف `S1 UNION ALL S2`
> بتطبيق `f` على أجزاء مجموعة الصفوف كلٌّ على حدة، ثم
> بتطبيق `f` مرة أخرى على النتائج: `f(S1 UNION ALL S2) = f(f(S1) UNION ALL f(S2))`.

تضمن هذه الخاصية أن نتائج التجميع الجزئية تكفي لحساب
النتيجة المجمّعة، لذلك لا نحتاج إلى تخزين أو معالجة أي بيانات إضافية. على
سبيل المثال، لا تتطلب نتيجة الدالتين `min` أو `max` أي خطوات إضافية
لحساب النتيجة النهائية انطلاقًا من الخطوات الوسيطة، بينما تتطلب الدالة `avg`
الاحتفاظ بالمجموع والعدد، ثم قسمة الأول على الثاني للحصول على
المتوسط في خطوة `Merge` نهائية تجمع الحالات الوسيطة.

تُنتَج قيم دوال التجميع عادةً باستدعاء دالة تجميع
مع إلحاق المُركِّب [`-SimpleState`](/ar/reference/functions/aggregate-functions/combinators#-simplestate) باسم الدالة.

<div id="syntax">
  ## الصياغة
</div>

```sql theme={null}
SimpleAggregateFunction(aggregate_function_name, types_of_arguments...)
```

**المعلمات**

* `aggregate_function_name` - اسم دالة تجميعية.
* `Type` - أنواع وسيطات الدالة التجميعية.

<div id="supported-functions">
  ## الدوال المدعومة
</div>

الدوال التجميعية التالية مدعومة:

* [`any`](/ar/reference/functions/aggregate-functions/any)
* [`any_respect_nulls`](/ar/reference/functions/aggregate-functions/any)
* [`anyLast`](/ar/reference/functions/aggregate-functions/anyLast)
* [`anyLast_respect_nulls`](/ar/reference/functions/aggregate-functions/anyLast)
* [`min`](/ar/reference/functions/aggregate-functions/min)
* [`max`](/ar/reference/functions/aggregate-functions/max)
* [`sum`](/ar/reference/functions/aggregate-functions/sum)
* [`sumWithOverflow`](/ar/reference/functions/aggregate-functions/sumWithOverflow)
* [`groupBitAnd`](/ar/reference/functions/aggregate-functions/groupBitAnd)
* [`groupBitOr`](/ar/reference/functions/aggregate-functions/groupBitOr)
* [`groupBitXor`](/ar/reference/functions/aggregate-functions/groupBitXor)
* [`groupArrayArray`](/ar/reference/functions/aggregate-functions/groupArrayArray)
* [`groupUniqArrayArray`](/ar/reference/functions/aggregate-functions/groupUniqArray)
* [`groupUniqArrayArrayMap`](/ar/reference/functions/aggregate-functions/combinators#-map)
* [`sumMap` (`sumMappedArrays`)](/ar/reference/functions/aggregate-functions/sumMap)
* [`minMap` (`minMappedArrays`)](/ar/reference/functions/aggregate-functions/minMap)
* [`maxMap` (`maxMappedArrays`)](/ar/reference/functions/aggregate-functions/maxMap)

<Note>
  تكون قيم `SimpleAggregateFunction(func, Type)` من نفس `Type`،
  لذلك، بخلاف النوع `AggregateFunction`، لا حاجة إلى تطبيق
  المُركِّبات `-Merge`/`-State`.

  يوفّر النوع `SimpleAggregateFunction` أداءً أفضل من `AggregateFunction`
  للدوال التجميعية نفسها.
</Note>

<div id="example">
  ## مثال
</div>

```sql theme={null}
CREATE TABLE simple (id UInt64, val SimpleAggregateFunction(sum, Double)) ENGINE=AggregatingMergeTree ORDER BY id;
```

<div id="related-content">
  ## محتوى ذو صلة
</div>

* مدونة: [استخدام مُركِّبات التجميع في ClickHouse](https://clickhouse.com/blog/aggregate-functions-combinators-in-clickhouse-for-arrays-maps-and-states)    - مدونة: [استخدام مُركِّبات التجميع في ClickHouse](https://clickhouse.com/blog/aggregate-functions-combinators-in-clickhouse-for-arrays-maps-and-states)
* النوع [AggregateFunction](/ar/reference/data-types/aggregatefunction).
