Joins, Subqueries, এবং Set Operations

Big Data and Analytics - স্নোফ্লেক (Snowflake) - Snowflake Querying এবং SQL ব্যবহার
292

Snowflake SQL-এ ডেটা বিশ্লেষণের জন্য Joins, Subqueries, এবং Set Operations ব্যবহার করা হয়। এই সব কৌশল ডেটাকে একত্রিত করার, ফিল্টার করার এবং বিভিন্ন ধরনের বিশ্লেষণ পরিচালনা করার জন্য অত্যন্ত গুরুত্বপূর্ণ। এই আর্টিকেলে আমরা Snowflake-এ Joins, Subqueries, এবং Set Operations-এর বিভিন্ন ধরনের কৌশল সম্পর্কে আলোচনা করব।

Joins

Joins ডেটাবেসের দুটি বা তার বেশি টেবিলের মধ্যে সম্পর্ক তৈরি করে এবং একসাথে ডেটা ফেরত দেয়। Snowflake SQL-এ বিভিন্ন ধরনের Joins ব্যবহার করা যায়, যা ডেটার বিশ্লেষণ এবং বিভিন্ন টেবিলের মধ্যে সম্পর্ক স্থাপনে সহায়ক।

Joins-এর প্রকারভেদ:

  1. INNER JOIN: INNER JOIN দুটি টেবিলের মধ্যে এমন রেকর্ডগুলো নির্বাচন করে যেগুলোর মধ্যে মিল রয়েছে। যদি একটি টেবিলের রেকর্ড অন্য টেবিলের সাথে মিল না খায়, তবে সেই রেকর্ডটি আউটপুটে আসবে না।

    উদাহরণ:

    SELECT A.column1, B.column2
    FROM table1 A
    INNER JOIN table2 B
    ON A.id = B.id;
    
  2. LEFT JOIN (LEFT OUTER JOIN): LEFT JOIN টেবিলের বামদিকের (LEFT) সমস্ত রেকর্ড নির্বাচন করে এবং ডানদিকের (RIGHT) টেবিলের মিল থাকা রেকর্ডগুলোর সাথে সম্পর্কিত তথ্য প্রদান করে। যদি ডানদিকের টেবিলে মিল না পাওয়া যায়, তবে NULL মান প্রদর্শিত হবে।

    উদাহরণ:

    SELECT A.column1, B.column2
    FROM table1 A
    LEFT JOIN table2 B
    ON A.id = B.id;
    
  3. RIGHT JOIN (RIGHT OUTER JOIN): RIGHT JOIN LEFT JOIN এর বিপরীত। এটি ডানদিকের টেবিলের সমস্ত রেকর্ড নির্বাচন করে এবং বামদিকের টেবিলের সাথে মিল খুঁজে সম্পর্কিত তথ্য দেখায়।

    উদাহরণ:

    SELECT A.column1, B.column2
    FROM table1 A
    RIGHT JOIN table2 B
    ON A.id = B.id;
    
  4. FULL OUTER JOIN: FULL OUTER JOIN উভয় টেবিলের সমস্ত রেকর্ড নির্বাচন করে। মিল না থাকলে NULL প্রদান করে।

    উদাহরণ:

    SELECT A.column1, B.column2
    FROM table1 A
    FULL OUTER JOIN table2 B
    ON A.id = B.id;
    

Subqueries

Subqueries হল এমন SQL কোয়েরি যা আরেকটি SQL কোয়েরির মধ্যে嵧ে থাকে। এটি মূল কোয়েরির আউটপুটের উপর নির্ভর করে এবং সাধারণত ডেটা ফিল্টার বা প্রক্রিয়া করতে ব্যবহার করা হয়।

Subquery-এর প্রকারভেদ:

  1. Scalar Subquery: এটি একটি একক মান ফেরত দেয়, যেমন একটি সিঙ্গেল ভ্যালু বা সিঙ্গেল রেকর্ড। এটি সাধারণত WHERE বা SELECT ক্লজে ব্যবহার হয়।

    উদাহরণ:

    SELECT name, salary
    FROM employees
    WHERE salary > (SELECT AVG(salary) FROM employees);
    
  2. IN Subquery: এটি একটি সাবকোয়্যারি যা একাধিক মান ফিরিয়ে দেয় এবং মূল কোয়েরির WHERE ক্লজে ইনক্লুড করতে ব্যবহৃত হয়।

    উদাহরণ:

    SELECT name
    FROM employees
    WHERE department_id IN (SELECT department_id FROM departments WHERE location = 'New York');
    
  3. EXISTS Subquery: EXISTS সাবকোয়্যারি মূল কোয়েরির ফলাফল কেবল তখনই ফেরত দেয় যখন সাবকোয়্যারি সত্য হয়। এটি সাধারণত ডেটার উপস্থিতি যাচাই করতে ব্যবহৃত হয়।

    উদাহরণ:

    SELECT name
    FROM employees E
    WHERE EXISTS (SELECT 1 FROM departments D WHERE E.department_id = D.department_id);
    
  4. Correlated Subquery: এটি একটি সাবকোয়্যারি যা মূল কোয়েরির প্রতিটি রেকর্ডের জন্য পুনরায় রান হয় এবং মূল কোয়েরির কলামের সাথে সম্পর্কিত থাকে।

    উদাহরণ:

    SELECT name, salary
    FROM employees E
    WHERE salary > (SELECT AVG(salary) FROM employees WHERE department_id = E.department_id);
    

Set Operations

Set Operations SQL-এ ব্যবহৃত হয় দুটি বা তার বেশি কোয়েরির ফলাফল একত্রিত করার জন্য। Snowflake SQL-এ তিনটি প্রধান Set Operation আছে: UNION, INTERSECT, এবং EXCEPT

Set Operations-এর প্রকারভেদ:

  1. UNION: UNION দুটি বা তার বেশি কোয়েরির ফলাফল একত্রিত করে এবং ডুপ্লিকেট রেকর্ডগুলি সরিয়ে ফেলে। এটি সাধারণত একাধিক টেবিল থেকে একত্রিত ডেটা দেখতে ব্যবহৃত হয়।

    উদাহরণ:

    SELECT name FROM employees WHERE department_id = 1
    UNION
    SELECT name FROM employees WHERE department_id = 2;
    
  2. INTERSECT: INTERSECT দুটি কোয়েরির এমন রেকর্ডগুলো ফেরত দেয় যা উভয় কোয়েরির মধ্যে সাধারণ। এটি শুধুমাত্র মিল থাকা রেকর্ডগুলি ফেরত দেয়।

    উদাহরণ:

    SELECT name FROM employees WHERE department_id = 1
    INTERSECT
    SELECT name FROM employees WHERE department_id = 2;
    
  3. EXCEPT: EXCEPT প্রথম কোয়েরির এমন রেকর্ডগুলো ফেরত দেয় যা দ্বিতীয় কোয়েরিতে নেই। এটি দ্বিতীয় কোয়েরির ডেটা প্রথম কোয়েরির থেকে বাদ দেয়।

    উদাহরণ:

    SELECT name FROM employees WHERE department_id = 1
    EXCEPT
    SELECT name FROM employees WHERE department_id = 2;
    

Joins, Subqueries, এবং Set Operations-এর প্রয়োজনীয়তা

১. Joins:

  • একাধিক টেবিলের মধ্যে সম্পর্ক তৈরি করতে ব্যবহৃত হয়।
  • একত্রিত তথ্য পাওয়ার জন্য এবং সম্পর্কিত ডেটা বিশ্লেষণ করতে অত্যন্ত প্রয়োজনীয়।

২. Subqueries:

  • একটি কোয়েরির আউটপুট অন্য একটি কোয়েরিতে ব্যবহার করা হয়।
  • বিশেষ করে নির্দিষ্ট ফিল্টারিং বা গণনা করার জন্য।

৩. Set Operations:

  • একাধিক কোয়েরি থেকে ডেটা একত্রিত বা কমপেয়ার করা হয়।
  • এটি ব্যবহারকারীদের একাধিক টেবিল বা ফলাফল সেটের মধ্যে সম্পর্কিত ডেটা তুলনা ও একত্রিত করার সুবিধা দেয়।

এই সব কৌশলগুলি Snowflake-এ ডেটা বিশ্লেষণ এবং প্রক্রিয়াকরণের জন্য অত্যন্ত গুরুত্বপূর্ণ, এবং ডেটাবেসের কার্যকারিতা এবং নমনীয়তা বাড়ানোর জন্য এগুলি ব্যবহার করা হয়।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...