ما هي الـ Functions في SQL؟

الـ Functions في SQL هي أدوات برمجية تُستخدم لإنشاء أوامر مُعدة مسبقًا يمكن إعادة استخدامها. الهدف منها هو تنفيذ عمليات معينة على البيانات وإرجاع نتائج بشكل ديناميكي. الـ Functions تشبه الفيوز من حيث التسهيل وإعادة الاستخدام، لكنها تتفوق في القدرة على التعامل مع Parameters وتنفيذ منطق ديناميكي.


لماذا نستخدم الـ Functions؟

  1. التعامل مع الـ Parameters:
    • الـ Functions تحل مشكلة الثبات الموجودة في الفيوز لأنها تقبل Parameters، مما يجعلها أكثر ديناميكية لتلبية متطلبات متنوعة.
  2. إعادة الاستخدام:
    • الـ Functions تُكتب مرة واحدة وتُستخدم في أماكن متعددة، مما يُقلل من تكرار الكود.
  3. المرونة:
    • يمكن للـ Function أن تُعيد قيمة واحدة (Single value) أو جدول كامل (Table-valued).
  4. أتمتة العمليات:
    • بدلاً من كتابة استعلامات طويلة ومعقدة، يمكن وضع العمليات المنطقية داخل Function وتنفيذها بسهولة.

أنواع الـ Functions في SQL:

1. Scalar Functions:

  • تُعيد قيمة واحدة فقط (مثل عدد، نص، تاريخ…إلخ).
  • زي الـ Aggregate functions
  • مثال:
CREATE FUNCTION GetEmployeeAge(@employee_id INT)
RETURNS INT
AS
BEGIN
	DECLARE @age INT;
	SELECT @age = DATEDIFF(YEAR, birth_date, GETDATE())
	FROM employees
	WHERE employee_id = @employee_id;
	RETURN @age;
END;
  • الاستخدام:
SELECT dbo.GetEmployeeAge(101);

2. Table-Valued Functions:

  • تُعيد جدول يمكن استخدامه كأنّه جدول عادي.
  • مثال:
CREATE FUNCTION GetActiveEmployees(@department_id INT)
RETURNS TABLE
AS
RETURN
(
	SELECT employee_id, employee_name
	FROM employees
	WHERE department_id = @department_id AND active = 1
);
  • الاستخدام:
SELECT * FROM dbo.GetActiveEmployees(5);

مقارنة بين الـ Functions والـ Aggregate Functions:

  • الـAggregate Functions (مثل SUM، AVG، MAX، MIN) هي وظائف مدمجة في SQL تُستخدم للقيام بعمليات حسابية على مجموعة بيانات.
  • الـCustom Functions تُنشأ بواسطة المستخدم لتلبية احتياجات مخصصة، مثل العمليات المنطقية المعقدة أو التعامل مع الـ Parameters.

مميزات الـ Functions:

  1. مرونة في التعامل مع البيانات:
    • بفضل قبول الـ Parameters، يمكن تخصيص النتائج بناءً على المدخلات.
  2. إعادة الاستخدام:
    • تُستخدم في الاستعلامات أو داخل العمليات المخزنة (Stored Procedures).
  3. تنظيم الكود:
    • تساعد في تقسيم العمليات المعقدة إلى وحدات أصغر وأكثر قابلية للفهم.
  4. توفير وقت وجهد:
    • بدلاً من إعادة كتابة نفس المنطق في أماكن متعددة، يتم استدعاء الـ Function ببساطة.

أمثلة على استخدام الـ Functions:

1. استخدام Scalar Function لحساب خصم:

CREATE FUNCTION CalculateDiscount(@price DECIMAL(10, 2), @discount_rate DECIMAL(5, 2))
RETURNS DECIMAL(10, 2)
AS
BEGIN
    RETURN @price - (@price * @discount_rate / 100);
END;
  • الاستخدام:

    SELECT dbo.CalculateDiscount(1000, 10); -- النتيجة: 900

2. استخدام Table-Valued Function لعرض المنتجات المتاحة:

CREATE FUNCTION GetAvailableProducts(@category_id INT)
RETURNS TABLE
AS
RETURN
(
    SELECT product_id, product_name, stock
    FROM products
    WHERE category_id = @category_id AND stock > 0
);
  • الاستخدام:

    SELECT * FROM dbo.GetAvailableProducts(3);

الفرق بين الـ Functions وViews:

الميزةFunctionsViews
الغرض الأساسيإعادة قيمة واحدة (Scalar) أو جدول (Table-Valued) بناءً على منطق مخصص باستخدام المدخلات (Parameters).جدول وهمي (Virtual Table) يعتمد على استعلام ثابت يتم استدعاؤه عند الحاجة.
قبول Parametersنعم، يمكنها قبول Parameters لتخصيص النتائج.لا، ثابتة ولا تدعم المدخلات.
إعادة الاستخدامنعم، تُكتب مرة واحدة وتُستخدم في أماكن متعددة.نعم، يمكن استدعاؤها كجدول في استعلامات أخرى.
نوع العمليات (DDL/DML/DQL)تدعم DQL فقط (SELECT). لا تدعم DML (INSERT, UPDATE, DELETE) أو DDL (CREATE, DROP).تدعم DQL (SELECT) فقط، ولكن يمكن إجراء DML على بعض الفيوز البسيطة.
نوع النتائج- Scalar: قيمة واحدة (مثل عدد أو نص). - Table-Valued: جدول كامل بناءً على منطق الاستعلام.جدول يعرض البيانات بناءً على الاستعلام المُخزن (SELECT).
أداء العمليات DMLلا يمكن تنفيذ DML داخل Functions.يمكن تنفيذ INSERT, UPDATE, DELETE على Views البسيطة بشرط توافق الشروط.
إخفاء التعقيديمكنها إخفاء العمليات المعقدة داخل الكود مع مرونة تخصيص النتائج.تستخدم لإخفاء تعقيدات استعلامات SELECT عن المستخدمين النهائيين.
إمكانية التخزين (Data Storage)لا تخزن بيانات فعلية، فقط منطق تنفيذ الاستعلام.لا تخزن بيانات فعلية، تعرض البيانات مباشرة من الجداول الأساسية عند استدعائها.
التعامل مع البيانات الحساسةيمكن التحكم في نوع البيانات المُرجعة باستخدام المنطق المكتوب.تُستخدم لإظهار أعمدة محددة أو بيانات مختارة من الجدول الأساسي.
الأداءأسرع مع العمليات الديناميكية بسبب قبول Parameters وتخصيص النتائج.أسرع مع الاستعلامات الثابتة التي لا تحتاج إلى تخصيص أو تغيير أثناء التنفيذ.
التعديل والصيانةالتعديل يتم مرة واحدة على السيرفر، ويؤثر على جميع الأماكن التي تستخدم الـ Function.التعديل يتم مرة واحدة على الاستعلام المُخزن، ويؤثر على جميع المستخدمين المرتبطين بالفيو.
سهولة الاستخدامتُستخدم داخل الاستعلامات أو في العمليات المخزنة (Stored Procedures).تُستخدم كأنها جدول في استعلامات SELECT فقط.
إمكانية الاستدعاء داخل استعلاميمكن استدعاء الـ Function داخل استعلام (SELECT) أو في عبارات مثل WHERE و JOIN.تُستدعى كجدول داخل جملة SELECT أو الاستعلامات الأخرى.
القيود- لا تدعم DML أو DDL. - محدودة بتقديم بيانات منطقية فقط (Deterministic).- لا تدعم Parameters. - تتأثر قيود DML بطبيعة الاستعلام الأساسي للفيو.

متى تستخدم Functions؟

  • عندما تحتاج إلى منطق ديناميكي يقبل Parameters.
  • عند تنفيذ عمليات معقدة على البيانات تُعيد نتيجة محددة أو جدول.
  • عند الحاجة إلى استخدام العمليات بشكل متكرر في عدة أماكن.

متى تستخدم Views؟

  • عندما تحتاج إلى إخفاء تعقيد الاستعلامات أو تبسيط عرض البيانات.
  • إذا كنت لا تحتاج إلى تخصيص النتائج باستخدام Parameters.
  • عندما تريد تحسين الصيانة، خاصةً مع البيانات الثابتة التي لا تتغير ديناميكيًا.

الخلاصة:

الـ Functions في SQL أداة قوية ومميزة لحل مشاكل الديناميكية في التعامل مع البيانات، خاصةً عند الحاجة لتخصيص النتائج بناءً على المدخلات. تُسهّل العمل على المطورين من خلال إعادة الاستخدام وتنظيم الأكواد، مما يجعلها عنصرًا أساسيًا في تصميم قواعد البيانات المتطورة.