Complex Data Aggregation এবং Filtering Techniques

HSQLDB এর Advanced SQL Techniques - এইচএসকিউএলডিবি (HSQLDB) - Database Tutorials

346

Complex Data Aggregation এবং Filtering Techniques ডেটাবেসে বড় এবং জটিল ডেটাসেট থেকে গুরুত্বপূর্ণ তথ্য বের করার জন্য ব্যবহৃত হয়। এগুলি কেবল ডেটা আয়ত্ত করার জন্য নয়, বরং ডেটার বিভিন্ন দিক বিশ্লেষণ এবং গভীর বিশ্লেষণ করার জন্যও প্রয়োজনীয়। SQL-এ Complex Data Aggregation এবং Filtering ফাংশনগুলি আপনাকে দ্রুত এবং কার্যকরীভাবে ডেটা প্রসেস করতে সাহায্য করে।


Complex Data Aggregation Techniques

1. GROUP BY with HAVING Clause
GROUP BY একটি SQL ক্লজ যা ডেটাকে গ্রুপ করতে ব্যবহার করা হয়, এবং HAVING ক্লজ ব্যবহার করা হয় গ্রুপ করা ডেটার উপর শর্ত নির্ধারণের জন্য। এটি সাধারণত অ্যাগ্রিগেট ফাংশনের সাথে ব্যবহার করা হয়, যেমন SUM, AVG, MAX, MIN ইত্যাদি।

  • Example:

    SELECT department, AVG(salary) AS average_salary
    FROM employees
    GROUP BY department
    HAVING AVG(salary) > 50000;
    

    এখানে, আমরা department অনুসারে ডেটাকে গ্রুপ করছি এবং তারপর সেই গ্রুপগুলোর মধ্যে গড় বেতন ৫০,০০০ এর বেশি এমন গ্রুপগুলোকে ফিল্টার করছি।

2. Multiple Aggregation Functions
একাধিক অ্যাগ্রিগেট ফাংশন একসাথে ব্যবহার করে একাধিক পরিসংখ্যান বের করা যায়, যেমন গড়, সর্বোচ্চ, সর্বনিম্ন, ইত্যাদি একই সময়ে।

  • Example:

    SELECT department, COUNT(*) AS num_employees, AVG(salary) AS average_salary, MAX(salary) AS highest_salary
    FROM employees
    GROUP BY department;
    

    এখানে, আমরা প্রতিটি department-এর জন্য মোট কর্মচারীর সংখ্যা, গড় বেতন এবং সর্বোচ্চ বেতন বের করছি।

3. Window Functions (OVER clause)
Window Functions বা Analytical Functions নির্দিষ্ট উইন্ডো বা অংশের মধ্যে অ্যাগ্রিগেট ফলাফল বের করার জন্য ব্যবহৃত হয়, যেটি সাধারণ GROUP BY এর মতো নয়, কারণ এটি ডেটার পরবর্তী রেকর্ডের উপর কোনো প্রভাব ফেলে না।

  • Example:

    SELECT employee_id, salary, 
           AVG(salary) OVER (PARTITION BY department) AS department_avg
    FROM employees;
    

    এখানে, AVG() ফাংশনটি প্রতিটি department এর মধ্যে গড় বেতন বের করছে, কিন্তু এটি পুরো টেবিলের জন্য নয়, শুধুমাত্র সেই বিভাগের জন্য।

4. Complex Subqueries with Aggregation
Subqueries বা Nested Queries ব্যবহার করে আপনি আরও জটিল অ্যাগ্রিগেশন করতে পারেন যেখানে একটি কুয়েরির ফলাফল আরেকটি কুয়েরির অংশ হিসেবে ব্যবহৃত হয়।

  • Example:

    SELECT department, MAX(salary) 
    FROM employees
    WHERE salary > (SELECT AVG(salary) FROM employees);
    GROUP BY department;
    

    এখানে, প্রথমে আমরা সকল কর্মচারীর গড় বেতন বের করছি, তারপর সেই গড় বেতনের চেয়ে বেশি বেতন পাওয়া কর্মচারীদের বিভাগ অনুযায়ী সর্বোচ্চ বেতন বের করছি।

5. Cross-Table Aggregation
একাধিক টেবিলের মধ্যে সম্পর্ক স্থাপন করে অ্যাগ্রিগেট ফাংশন ব্যবহার করা যায়, যেমন JOIN এর মাধ্যমে।

  • Example:

    SELECT departments.name, COUNT(employees.employee_id) AS num_employees
    FROM departments
    LEFT JOIN employees ON employees.department_id = departments.department_id
    GROUP BY departments.name;
    

    এখানে, departments এবং employees টেবিলের মধ্যে JOIN করে, এবং আমরা প্রতিটি বিভাগে কর্মচারীর সংখ্যা বের করছি।


Complex Data Filtering Techniques

1. Using Multiple Conditions (AND, OR, NOT)
আপনি বিভিন্ন শর্তাবলী (conditions) একসাথে ব্যবহার করতে পারেন AND, OR, এবং NOT এর মাধ্যমে। এগুলি আপনাকে আরও নির্দিষ্ট ফলাফল দিতে সহায়ক।

  • Example:

    SELECT * 
    FROM employees
    WHERE salary > 50000 AND department = 'Sales';
    

    এখানে, আমরা শুধুমাত্র সেই কর্মচারীদের নির্বাচন করছি যাদের বেতন ৫০,০০০ এর বেশি এবং বিভাগ 'Sales'।

2. BETWEEN for Range Filtering
BETWEEN ব্যবহার করে একটি নির্দিষ্ট রেঞ্জে থাকা ডেটা ফিল্টার করা যায়, যেমন একটি নির্দিষ্ট সময়কাল বা মূল্য রেঞ্জ।

  • Example:

    SELECT * 
    FROM employees
    WHERE salary BETWEEN 40000 AND 70000;
    

    এখানে, আমরা শুধুমাত্র সেই কর্মচারীদের নির্বাচন করছি যাদের বেতন ৪০,০০০ থেকে ৭০,০০০ এর মধ্যে।

3. LIKE for Pattern Matching
LIKE ফাংশনটি ব্যবহার করে আপনি একটি স্ট্রিং এর মধ্যে নির্দিষ্ট প্যাটার্ন খুঁজে পেতে পারেন, যা বিশেষত টেক্সট ডেটার ক্ষেত্রে কার্যকরী।

  • Example:

    SELECT * 
    FROM employees
    WHERE name LIKE 'A%';
    

    এখানে, আমরা এমন সকল কর্মচারীকে নির্বাচন করছি যাদের নাম 'A' দিয়ে শুরু হয়।

4. IN for Multiple Values
IN কুয়েরি ব্যবহার করে আপনি একাধিক মানের মধ্যে ফিল্টার করতে পারেন। এটি OR শর্তের তুলনায় আরও কার্যকরী এবং পরিষ্কার।

  • Example:

    SELECT * 
    FROM employees
    WHERE department IN ('HR', 'Sales', 'Marketing');
    

    এখানে, আমরা শুধু সেই কর্মচারীদের নির্বাচন করছি যারা 'HR', 'Sales', বা 'Marketing' বিভাগে কাজ করছেন।

5. EXISTS and NOT EXISTS
EXISTS এবং NOT EXISTS ব্যবহার করে আপনি সাবকুয়েরির উপস্থিতি বা অনুপস্থিতি পরীক্ষা করতে পারেন।

  • Example:

    SELECT name 
    FROM employees
    WHERE EXISTS (SELECT 1 FROM departments WHERE department_id = employees.department_id);
    

    এখানে, আমরা শুধুমাত্র সেই কর্মচারীদের নাম নির্বাচন করছি যাদের সম্পর্কিত departments টেবিলে একটি বিভাগ রয়েছে।

6. NULL Handling
ডেটাবেসে NULL মানে অপূর্ণ বা অনুপস্থিত মান। IS NULL এবং IS NOT NULL শর্ত ব্যবহার করে NULL মানের ডেটা ফিল্টার করা যায়।

  • Example:

    SELECT * 
    FROM employees
    WHERE department IS NULL;
    

    এখানে, আমরা সেই কর্মচারীদের নির্বাচন করছি যাদের বিভাগ খালি (NULL)।


সারাংশ

Complex Data Aggregation এবং Filtering Techniques আপনাকে শক্তিশালী ডেটা বিশ্লেষণ এবং প্রসেসিং করতে সাহায্য করে। GROUP BY, HAVING, Window Functions, Subqueries, এবং JOIN এর মাধ্যমে জটিল অ্যাগ্রিগেশন করা সম্ভব। একইভাবে, BETWEEN, IN, LIKE, এবং EXISTS ফাংশন ব্যবহার করে ডেটাকে আরও নির্দিষ্টভাবে ফিল্টার করা যায়। এই কৌশলগুলি বিশেষত বড় ডেটাসেটের মধ্যে গুরুত্বপূর্ণ এবং কার্যকরী ডেটা খোঁজার জন্য অপরিহার্য।

Content added By
Promotion

Are you sure to start over?

Loading...