اذهب إلى المحتوى
  • 0

ماهي وظيفة over(partition) في لغة sql

خالد مرتضى

السؤال

Recommended Posts

  • 0

جملة over(partition)  تقوم بتوزيع ناتج دالة الaggregate طبقاً للحقل الموضوع بعد كلمة by 

على سبيل المثال إن كان لدينا البيانات التالية 

{
name:sharaf, age:21
}
{
name:ashraf, age: 49
}
{
name: mohamed, age:21
}
{
name:ahmed, age:25
}
{
name:saad, age:49
}

إن قمت بتنفيذ الجملة 

select * , count(*) over(partition by st_age ) from table_name

سيقوم بإرجاع البيانات , وسيقوم بحساب عدد العناصر حسب العمر فسنجد ناتج الجملة كالتالي

name	age		count
sharaf	21		2
ashraf	49		1
mohamed 49		2
ahmed	25		1
saad	21		2

ستﻻحظ جلب البيانات وبجانبها الحقل count الذي يحدد كم عدد البيانات المنتمية لنفس الage, حيث أن في العادي إن إستخدمت الaggregate functions تقوم بتحويل عدد من الصفوف إلى صف واحد, ولكن صيغة ال over partition والتي يتم أيضاً تسميتها بالwindow functions تقوم بإرجاع مجموعة الصفوف إلى مجموعة صفوف أيضاً وليس صف واحد

رابط هذا التعليق
شارك على الشبكات الإجتماعية

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...