PostgreSQL এর SQL Queries এবং Advanced Queries

পোস্টগ্রিএসকিউএল (PostgreSQL) - Database Tutorials

323

PostgreSQL এ SQL কুয়েরি ব্যবহারের মাধ্যমে আপনি ডেটাবেসের তথ্য পরিচালনা করতে পারেন। এটি একটি শক্তিশালী SQL কমান্ড ইঞ্জিন সরবরাহ করে যা ডেটা নির্বাচন, আপডেট, সন্নিবেশ এবং মুছে ফেলা, টেবিল তৈরি এবং অন্যান্য কাজগুলো করার জন্য ব্যবহৃত হয়। এই টিউটোরিয়ালে আমরা PostgreSQL এর কিছু সাধারণ এবং অ্যাডভান্সড SQL কুয়েরি সম্পর্কে আলোচনা করব।


১. বেসিক SQL Queries (মৌলিক SQL কুয়েরি)

a. ডেটা নির্বাচন (SELECT Query)

একটি টেবিল থেকে ডেটা নির্বাচন করতে SELECT কুয়েরি ব্যবহার করা হয়। এর মাধ্যমে নির্দিষ্ট কলাম বা সমস্ত কলাম থেকে ডেটা পেতে পারেন।

SELECT * FROM students;  -- সমস্ত তথ্য নির্বাচন

নির্দিষ্ট কলাম নির্বাচন:

SELECT name, age FROM students;  -- নাম এবং বয়স নির্বাচন

b. ডেটা সন্নিবেশ (INSERT INTO Query)

ডেটাবেসে নতুন ডেটা সন্নিবেশ করতে INSERT INTO কুয়েরি ব্যবহার করা হয়।

INSERT INTO students (name, age, grade) 
VALUES ('John Doe', 20, 'A');

c. ডেটা আপডেট (UPDATE Query)

টেবিলের ডেটা আপডেট করতে UPDATE কুয়েরি ব্যবহৃত হয়।

UPDATE students 
SET grade = 'B' 
WHERE student_id = 1;

d. ডেটা মুছে ফেলা (DELETE Query)

টেবিল থেকে ডেটা মুছে ফেলতে DELETE কুয়েরি ব্যবহার করা হয়।

DELETE FROM students WHERE student_id = 1;

e. শর্ত সহ নির্বাচন (SELECT with WHERE Clause)

WHERE ক্লজ ব্যবহার করে নির্দিষ্ট শর্ত পূর্ণ করা ডেটা নির্বাচন করা হয়।

SELECT * FROM students WHERE age > 20;

২. এডভান্সড SQL Queries (অ্যাডভান্সড SQL কুয়েরি)

a. জয়েন (JOIN Queries)

JOIN কমান্ডের মাধ্যমে আপনি একাধিক টেবিলের তথ্য একত্রিত করতে পারেন।

  1. INNER JOIN: দুইটি টেবিলের মধ্যে মিল থাকা রেকর্ডগুলো নির্বাচন করে।
SELECT students.name, courses.course_name
FROM students
INNER JOIN enrollments ON students.student_id = enrollments.student_id
INNER JOIN courses ON enrollments.course_id = courses.course_id;
  1. LEFT JOIN: বাম টেবিলের সমস্ত রেকর্ড এবং ডান টেবিলের মিল থাকা রেকর্ডগুলো নির্বাচন করে।
SELECT students.name, courses.course_name
FROM students
LEFT JOIN enrollments ON students.student_id = enrollments.student_id
LEFT JOIN courses ON enrollments.course_id = courses.course_id;

b. এগ্রিগেট ফাংশন (Aggregate Functions)

এগ্রিগেট ফাংশন ডেটার উপর গণনা বা বিশ্লেষণ করতে ব্যবহৃত হয়। কিছু সাধারণ এগ্রিগেট ফাংশন হলো COUNT(), SUM(), AVG(), MAX(), এবং MIN()

  1. COUNT(): সারির সংখ্যা গণনা করতে ব্যবহৃত হয়।
SELECT COUNT(*) FROM students;
  1. SUM(): একটি কলামের মানের যোগফল বের করতে ব্যবহৃত হয়।
SELECT SUM(age) FROM students;
  1. AVG(): একটি কলামের গড় মান বের করতে ব্যবহৃত হয়।
SELECT AVG(age) FROM students;
  1. MAX() এবং MIN(): একটি কলামের সর্বোচ্চ এবং সর্বনিম্ন মান বের করতে ব্যবহৃত হয়।
SELECT MAX(age), MIN(age) FROM students;

c. গ্রুপিং (GROUP BY Query)

GROUP BY ক্লজ ব্যবহার করে আপনি ডেটাকে গ্রুপ করতে পারেন এবং প্রতিটি গ্রুপের উপর এগ্রিগেট ফাংশন প্রয়োগ করতে পারেন।

SELECT grade, COUNT(*)
FROM students
GROUP BY grade;

এটি grade অনুযায়ী ছাত্রদের সংখ্যা গণনা করবে।

d. অর্ডার বাই (ORDER BY Query)

ORDER BY ক্লজ ব্যবহার করে আপনি ডেটাকে নির্দিষ্ট কলাম অনুযায়ী সাজাতে পারেন (Ascending বা Descending অর্ডারে)।

SELECT * FROM students
ORDER BY age DESC;

এটি ছাত্রদের বয়স অনুযায়ী নাম্বার সাজাবে Descending অর্ডারে।

e. সাবকুয়েরি (Subquery)

একটি কুয়েরির ভিতরে আরেকটি কুয়েরি থাকা সাবকুয়েরি (Subquery) নামে পরিচিত। এটি একটি কুয়েরির ফলাফল অন্য কুয়েরিতে ব্যবহার করতে সহায়তা করে।

SELECT name 
FROM students 
WHERE student_id IN (SELECT student_id FROM enrollments WHERE course_id = 2);

f. টেবিল এ্যালিয়াস (Table Aliases)

টেবিলের শর্ট নাম (এ্যালিয়াস) ব্যবহার করে কোড সহজ এবং পরিষ্কার করা হয়।

SELECT s.name, c.course_name
FROM students s
INNER JOIN enrollments e ON s.student_id = e.student_id
INNER JOIN courses c ON e.course_id = c.course_id;

g. কমপ্লেক্স কুয়েরি (Complex Query with Multiple Joins and Aggregate Functions)

SELECT s.name, c.course_name, COUNT(e.student_id) AS total_students
FROM students s
INNER JOIN enrollments e ON s.student_id = e.student_id
INNER JOIN courses c ON e.course_id = c.course_id
GROUP BY s.name, c.course_name
ORDER BY total_students DESC;

এটি ছাত্রদের নাম এবং কোর্সের নামের পাশাপাশি, প্রতিটি কোর্সে মোট ছাত্র সংখ্যা দেখাবে এবং মোট ছাত্র সংখ্যার ভিত্তিতে সাজানো হবে।


সারাংশ

  • মৌলিক SQL কুয়েরি যেমন SELECT, INSERT, UPDATE, এবং DELETE ডেটা পরিচালনার জন্য ব্যবহৃত হয়।
  • অ্যাডভান্সড SQL কুয়েরি যেমন JOIN, GROUP BY, ORDER BY, Subqueries, এবং Aggregate Functions ব্যবহার করে আরো জটিল ডেটা বিশ্লেষণ করা যায়।
  • PostgreSQL এ SQL কুয়েরির মাধ্যমে আপনি ডেটাবেসের সকল কার্যক্রম (ডেটা নির্বাচন, আপডেট, মুছে ফেলা, যোগ করা, এবং বিশ্লেষণ) দক্ষভাবে পরিচালনা করতে পারবেন।
Content added By

বেসিক SQL Query লেখা এবং Execute করা

363

SQL (Structured Query Language) হল ডেটাবেসে ডেটা পরিচালনা এবং অনুসন্ধান করার জন্য ব্যবহৃত একটি স্ট্যান্ডার্ড ভাষা। PostgreSQL বা অন্য যেকোনো সম্পর্কিত ডেটাবেসে SQL কুয়েরি ব্যবহার করে আপনি ডেটাবেসে ডেটা INSERT, UPDATE, DELETE বা SELECT করতে পারেন। এখানে বেসিক SQL কুয়েরি লেখা এবং এগুলি PostgreSQL ডেটাবেসে এক্সিকিউট করার পদ্ধতি আলোচনা করা হলো।


1. SQL Query Structure

একটি SQL কুয়েরি সাধারণত কমান্ড বা কিপওয়ার্ড দিয়ে শুরু হয় এবং নির্দিষ্ট টেবিল বা ডেটা সেটের সাথে কাজ করতে সাহায্য করে। সাধারণ SQL কুয়েরি কমান্ডের মধ্যে রয়েছে:

  • SELECT: ডেটা নির্বাচনের জন্য
  • INSERT: ডেটা যোগ করার জন্য
  • UPDATE: বিদ্যমান ডেটা আপডেট করার জন্য
  • DELETE: ডেটা মুছে ফেলার জন্য

2. PostgreSQL-এ SQL কুয়েরি Execute করার পদ্ধতি

a. SELECT Query (ডেটা নির্বাচন করা)

SELECT কুয়েরি ব্যবহার করে আপনি টেবিল থেকে ডেটা নির্বাচন করতে পারেন। উদাহরণ:

SELECT * FROM employees;

এই কুয়েরিটি employees টেবিলের সব রেকর্ড (রো) নির্বাচন করবে।

  • * ব্যবহার করলে সমস্ত কলাম নির্বাচন হয়। আপনি নির্দিষ্ট কলামও নির্বাচন করতে পারেন, যেমন:
SELECT first_name, last_name FROM employees;

b. INSERT Query (ডেটা যোগ করা)

INSERT কুয়েরি ব্যবহার করে নতুন রেকর্ড টেবিলে যোগ করা হয়। উদাহরণ:

INSERT INTO employees (first_name, last_name, age)
VALUES ('John', 'Doe', 30);

এটি employees টেবিলে একটি নতুন রেকর্ড যোগ করবে, যেখানে first_name "John", last_name "Doe", এবং age 30 থাকবে।

c. UPDATE Query (ডেটা আপডেট করা)

UPDATE কুয়েরি ব্যবহার করে বিদ্যমান রেকর্ড পরিবর্তন করা হয়। উদাহরণ:

UPDATE employees
SET age = 31
WHERE first_name = 'John' AND last_name = 'Doe';

এটি employees টেবিলের "John Doe"-এর বয়স 31-এ আপডেট করবে।

d. DELETE Query (ডেটা মুছে ফেলা)

DELETE কুয়েরি ব্যবহার করে টেবিল থেকে রেকর্ড মুছে ফেলা হয়। উদাহরণ:

DELETE FROM employees
WHERE first_name = 'John' AND last_name = 'Doe';

এটি "John Doe"-এর রেকর্ডটি employees টেবিল থেকে মুছে ফেলবে।


3. SQL কুয়েরি PostgreSQL-এ Execute করা

a. psql কমান্ড লাইন থেকে Execute করা

PostgreSQL-এর সাথে যোগাযোগ করতে আপনি psql কমান্ড লাইন টুল ব্যবহার করতে পারেন।

  1. PostgreSQL এ লগইন করুন:

    psql -U postgres -d your_database_name
    

    এখানে -U postgres ব্যবহার করা হয়েছে PostgreSQL এর ইউজার হিসেবে লগইন করতে এবং -d your_database_name ডেটাবেস নির্বাচন করতে।

  2. SQL কুয়েরি চালান: একবার লগইন করার পরে, আপনি যে কুয়েরি চালাতে চান, তা টাইপ করুন। উদাহরণস্বরূপ:

    SELECT * FROM employees;
    

b. pgAdmin এর মাধ্যমে Execute করা

PostgreSQL ডেটাবেসের গ্রাফিকাল ইউজার ইন্টারফেস হিসেবে pgAdmin ব্যবহার করা যেতে পারে। এটি আপনাকে SQL কুয়েরি লেখার জন্য একটি সহজ এডিটর এবং ফলাফল দেখতে সহায়তা করে।

  1. pgAdmin খুলুন এবং ডেটাবেস নির্বাচন করুন
  2. Query Tool-এ যান এবং SQL কুয়েরি লিখুন:

    SELECT * FROM employees;
    
  3. Execute বাটনে ক্লিক করুন বা F5 চাপুন কুয়েরি এক্সিকিউট করার জন্য।

c. PHP বা অন্য প্রোগ্রামিং ভাষার মাধ্যমে Execute করা

PostgreSQL কুয়েরি চালানোর জন্য আপনি প্রোগ্রামিং ভাষার মাধ্যমে SQL কুয়েরি এক্সিকিউট করতে পারেন। উদাহরণস্বরূপ, PHP ব্যবহার করে:

<?php
// PostgreSQL ডেটাবেস সংযোগ
$dbconn = pg_connect("host=localhost dbname=your_database user=postgres password=your_password");

// SQL কুয়েরি চালানো
$query = "SELECT * FROM employees";
$result = pg_query($dbconn, $query);

// ফলাফল দেখানো
while ($row = pg_fetch_assoc($result)) {
    echo $row['first_name'] . ' ' . $row['last_name'] . "\n";
}
?>

4. SQL কুয়েরি লেখার কিছু পরামর্শ

  1. কেস সেনসিটিভিটি: SQL কুয়েরি সাধারণত কেস-ইনসেন্সিটিভ হয় (যেমন SELECT এবং select একই)। তবে টেবিল এবং কলামের নাম যখন ডাবল কোটস (") দিয়ে লিখতে হয়, তখন সেগুলি কেস-সেনসিটিভ হয়।
  2. SQL ইনজেকশন থেকে নিরাপত্তা: ডেটাবেসে সুরক্ষিতভাবে কুয়েরি এক্সিকিউট করতে Prepared Statements ব্যবহার করুন। এটি SQL ইনজেকশন প্রতিরোধে সহায়তা করে।
  3. কমেন্ট করা: SQL কুয়েরির মধ্যে মন্তব্য যোগ করতে পারেন। একক লাইনের মন্তব্যে -- ব্যবহার করুন:

    -- This is a comment
    SELECT * FROM employees;
    

সারাংশ

PostgreSQL-এ SQL কুয়েরি লেখা এবং এক্সিকিউট করা সহজ, তবে আপনি যে ধরণের ডেটা পরিচালনা করতে চান, তার জন্য সঠিক কুয়েরি নির্বাচন গুরুত্বপূর্ণ। SELECT, INSERT, UPDATE, এবং DELETE কুয়েরি ব্যবহার করে ডেটাবেসের বিভিন্ন কার্যকলাপ সম্পাদন করতে পারেন। কুয়েরি এক্সিকিউট করার জন্য আপনি কমান্ড লাইন টুল (psql), গ্রাফিকাল ইউজার ইন্টারফেস (pgAdmin), বা প্রোগ্রামিং ভাষার মাধ্যমে PostgreSQL এর সাথে যোগাযোগ করতে পারেন।

Content added By

Complex Queries, Joins (INNER, OUTER, LEFT, RIGHT)

318

SQL (Structured Query Language) ব্যবহার করে ডেটাবেস থেকে তথ্য বের করার জন্য বিভিন্ন ধরনের কুয়েরি ব্যবহার করা হয়। কিছু কুয়েরি যেমন Join অপারেটর এবং Complex Queries খুবই শক্তিশালী টুল যা বিভিন্ন টেবিল থেকে ডেটা একত্রিত করে এবং আরও গভীর বিশ্লেষণ করা সম্ভব করে। এখানে Complex Queries এবং বিভিন্ন ধরনের Joins এর উপর আলোচনা করা হলো।


1. Complex Queries

Complex Queries বলতে এমন SQL কুয়েরি বোঝায়, যা একাধিক টেবিল থেকে ডেটা সংগ্রহ করে, একাধিক শর্ত প্রয়োগ করে, বিভিন্ন ফাংশন ব্যবহার করে, বা একাধিক সাবকুয়েরি (Subqueries) ব্যবহার করে। এসব কুয়েরি সাধারণত জটিল এবং বড় ডেটাসেটের মধ্যে বিস্তারিত তথ্য বের করতে ব্যবহৃত হয়।

উদাহরণ: Subquery এর ব্যবহার

SELECT first_name, last_name
FROM employees
WHERE employee_id IN (
    SELECT employee_id
    FROM departments
    WHERE department_name = 'Sales'
);

এখানে, Subquery প্রথমে departments টেবিল থেকে Sales ডিপার্টমেন্টের সমস্ত employee_id বের করবে এবং তারপর মূল কুয়েরি সেই employee_id এর ভিত্তিতে employees টেবিল থেকে নাম বের করবে।


2. Joins

SQL Join অপারেটর ব্যবহার করে একাধিক টেবিল থেকে সম্পর্কিত ডেটা একত্রিত করা যায়। বিভিন্ন ধরনের Joins এর মাধ্যমে টেবিলগুলোর মধ্যে সম্পর্ক স্থাপন এবং ডেটা একত্রিত করা হয়। মূলত ৪টি ধরনের Join রয়েছে:


a. INNER JOIN

INNER JOIN হলো সবচেয়ে সাধারণ এবং প্রচলিত ধরনের Join, যা শুধুমাত্র দুইটি টেবিলের এমন রেকর্ডগুলো ফেরত দেয় যেগুলোর মধ্যে সম্পর্কিত (matching) মান রয়েছে।

  • বৈশিষ্ট্য: INNER JOIN শুধুমাত্র সেই রেকর্ডগুলো ফেরত দেয় যেগুলো দুইটি টেবিলের মধ্যে মিলে যায়। যদি কোন রেকর্ডের মিল না থাকে, তাহলে তা রেজাল্টে অন্তর্ভুক্ত হয় না।

উদাহরণ:

SELECT employees.first_name, employees.last_name, departments.department_name
FROM employees
INNER JOIN departments ON employees.department_id = departments.department_id;

এখানে employees টেবিলের department_id কলাম এবং departments টেবিলের department_id কলামের মধ্যে সম্পর্ক রয়েছে, এবং মিল পাওয়া রেকর্ডগুলোর প্রথম নাম, শেষ নাম এবং ডিপার্টমেন্ট নাম ফেরত দেবে।


b. LEFT JOIN (LEFT OUTER JOIN)

LEFT JOIN বা LEFT OUTER JOIN একটি এমন Join যেখানে প্রথম টেবিল (বাঁ দিকের টেবিল) এর সমস্ত রেকর্ডই অন্তর্ভুক্ত থাকবে, এবং দ্বিতীয় টেবিলের সাথে সম্পর্কিত রেকর্ড থাকলে তা যুক্ত হবে। যদি দ্বিতীয় টেবিলের সাথে কোনো সম্পর্ক না থাকে, তবে সেই টেবিলের কলামগুলোর মান NULL হয়ে যাবে।

  • বৈশিষ্ট্য: এটি বাম দিকের (LEFT) টেবিলের সমস্ত রেকর্ড এবং ডান দিকের (RIGHT) টেবিলের মিলিত রেকর্ডগুলো ফিরিয়ে আনে। যদি ডান দিকের টেবিলে মিল না থাকে, তবে ডান দিকের কলামগুলো NULL হবে।

উদাহরণ:

SELECT employees.first_name, employees.last_name, departments.department_name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.department_id;

এখানে employees টেবিলের সকল রেকর্ড থাকবে, এবং departments টেবিলের সাথে সম্পর্কিত ডিপার্টমেন্ট নামও থাকবে। যদি কোনো employee এর জন্য ডিপার্টমেন্ট না থাকে, তবে সেই employee এর জন্য ডিপার্টমেন্ট কলামে NULL দেখাবে।


c. RIGHT JOIN (RIGHT OUTER JOIN)

RIGHT JOIN বা RIGHT OUTER JOIN ঠিক LEFT JOIN এর বিপরীত। এখানে, ডান (RIGHT) টেবিলের সমস্ত রেকর্ড থাকবে এবং বাম (LEFT) টেবিলের সাথে সম্পর্কিত রেকর্ড পাওয়া গেলে তা দেখাবে। যদি সম্পর্ক না পাওয়া যায়, তবে বাম টেবিলের কলামগুলো NULL হবে।

  • বৈশিষ্ট্য: এটি ডান (RIGHT) টেবিলের সমস্ত রেকর্ড এবং বাম (LEFT) টেবিলের মিলিত রেকর্ডগুলো ফিরিয়ে আনে। যদি বাম টেবিলের সাথে সম্পর্ক না থাকে, তবে বাম টেবিলের কলামগুলো NULL হবে।

উদাহরণ:

SELECT employees.first_name, employees.last_name, departments.department_name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.department_id;

এখানে departments টেবিলের সকল রেকর্ড থাকবে এবং employees টেবিলের সাথে সম্পর্কিত কর্মচারীদের নাম দেখাবে। যদি কোনো ডিপার্টমেন্টে কর্মচারী না থাকে, তবে সেই ডিপার্টমেন্টের জন্য NULL দেখাবে।


d. FULL JOIN (FULL OUTER JOIN)

FULL JOIN বা FULL OUTER JOIN হলো একটি Join যা দুইটি টেবিলের সকল রেকর্ডকে অন্তর্ভুক্ত করে, যদি সম্পর্ক পাওয়া যায় তাহলে দুটি টেবিলের তথ্য একত্রিত করে দেখাবে, অন্যথায় একটি টেবিলের জন্য NULL দেখাবে।

  • বৈশিষ্ট্য: এটি দুইটি টেবিলের সমস্ত রেকর্ড সমন্বিত করে। যেখানে মিল পাওয়া যায় সেখানে সম্পর্কিত তথ্য দেখাবে এবং যেখানেই মিল না পাওয়া যায় সেখানে NULL দেখাবে।

উদাহরণ:

SELECT employees.first_name, employees.last_name, departments.department_name
FROM employees
FULL OUTER JOIN departments ON employees.department_id = departments.department_id;

এখানে employees এবং departments টেবিলের সমস্ত রেকর্ড আনা হবে। যদি কোন employee বা department এর জন্য সম্পর্ক না থাকে, তবে তা NULL হবে।


Complex Query with Joins Example

একটি Complex Query এর উদাহরণ যেখানে INNER JOIN, LEFT JOIN এবং Subquery ব্যবহার করা হয়েছে:

SELECT employees.first_name, employees.last_name, departments.department_name,
       (SELECT COUNT(*) FROM employees e WHERE e.department_id = employees.department_id) AS department_count
FROM employees
INNER JOIN departments ON employees.department_id = departments.department_id
LEFT JOIN salaries ON employees.employee_id = salaries.employee_id
WHERE salaries.salary > 50000;

এখানে:

  • INNER JOIN ব্যবহার করা হয়েছে employees এবং departments টেবিলের মধ্যে সম্পর্ক স্থাপনের জন্য।
  • LEFT JOIN ব্যবহার করা হয়েছে employees এবং salaries টেবিলের মধ্যে সম্পর্ক স্থাপনের জন্য, যেখানে শুধুমাত্র উচ্চ বেতন (৫০০০০ এর বেশি) এর কর্মচারীদের দেখানো হয়েছে।
  • একটি Subquery ব্যবহার করা হয়েছে, যা প্রতিটি ডিপার্টমেন্টে কর্মচারীদের সংখ্যা বের করবে।

সারাংশ

  • INNER JOIN: শুধুমাত্র মিল পাওয়া রেকর্ডগুলি ফেরত দেয়।
  • LEFT JOIN: প্রথম টেবিলের সমস্ত রেকর্ড এবং মিলিত রেকর্ড দেয়, অন্যথায় NULL
  • RIGHT JOIN: দ্বিতীয় টেবিলের সমস্ত রেকর্ড এবং মিলিত রেকর্ড দেয়, অন্যথায় NULL
  • FULL JOIN: দুইটি টেবিলের সমস্ত রেকর্ডের সংমিশ্রণ দেয়, যেখানে মিল না থাকে সেখানে NULL দেখায়।
  • Complex Queries: বিভিন্ন ধরনের Join, Subquery এবং ফাংশন ব্যবহার করে আরও জটিল এবং বিশ্লেষণমূলক কুয়েরি তৈরি করা যায়।

SQL Join এবং Complex Queries ডেটাবেস থেকে তথ্য আরও গভীরভাবে বিশ্লেষণ এবং একত্রিত করতে সাহায্য করে।

Content added By

Subqueries এবং Nested Queries

357

Subqueries এবং Nested Queries উভয়ই SQL কুয়েরির এমন একটি অংশ যা একটি মূল কুয়েরি (Main Query) এর মধ্যে অন্তর্ভুক্ত থাকে এবং অন্যান্য কুয়েরি বা ডেটাবেস অপারেশনের সাথে সংযুক্ত থাকে। সাধারণভাবে, এগুলো ডেটাবেসের মধ্যে আরও জটিল বা অভ্যন্তরীণ লজিক অ্যাপ্লাই করতে ব্যবহৃত হয়। PostgreSQL এ, সেগুলি বিভিন্নভাবে ব্যবহার করা যায় এবং তাদের কার্যকারিতা নির্ভর করে কুয়েরির কাঠামো এবং সমস্যার ধরণ অনুযায়ী।


1. Subqueries (সাবকুয়েরি)

Subquery হল এমন একটি কুয়েরি যা অন্য কুয়েরির মধ্যে ব্যবহৃত হয়। এটি প্রধানত SELECT, INSERT, UPDATE, অথবা DELETE কুয়েরির অংশ হিসেবে ব্যবহার করা যায়। একটি সাবকুয়েরি সাধারণত একটি নির্দিষ্ট ফলাফল তৈরি করে যা মূল কুয়েরি দ্বারা ব্যবহার করা হয়। এটি Scalar subquery, Column subquery, Row subquery, এবং Table subquery হিসেবে থাকতে পারে।

Types of Subqueries:

  1. Scalar Subquery:
    • এটি একটি একক মান (একটি সেল) রিটার্ন করে।
    • উদাহরণ:

      SELECT name
      FROM employees
      WHERE salary = (SELECT MAX(salary) FROM employees);
      

      এখানে সাবকুয়েরিটি সর্বোচ্চ বেতন নির্বাচন করে, এবং প্রধান কুয়েরি সেই বেতন অনুযায়ী কর্মচারী নির্বাচন করে।

  2. Column Subquery:
    • এটি একটি কলাম (একাধিক মান) রিটার্ন করে।
    • উদাহরণ:

      SELECT name, salary
      FROM employees
      WHERE department_id IN (SELECT department_id FROM departments WHERE location = 'New York');
      

      এখানে সাবকুয়েরিটি নির্দিষ্ট স্থানে (New York) কর্মরত সকল ডিপার্টমেন্টের আইডি রিটার্ন করে, এবং মূল কুয়েরি সেই ডিপার্টমেন্টের কর্মচারীদের তালিকা তৈরি করে।

  3. Row Subquery:
    • এটি একাধিক কলাম এবং একাধিক রেকর্ড রিটার্ন করে।
    • উদাহরণ:

      SELECT name, department_id, salary
      FROM employees
      WHERE (department_id, salary) IN (SELECT department_id, MAX(salary) FROM employees GROUP BY department_id);
      

      এখানে সাবকুয়েরিটি প্রতিটি বিভাগের সর্বোচ্চ বেতন রিটার্ন করে এবং মূল কুয়েরি সেই বেতন অনুযায়ী কর্মচারীদের নির্বাচন করে।

  4. Table Subquery:
    • এটি একাধিক কলাম এবং একাধিক রেকর্ডের একটি টেবিল রিটার্ন করে।
    • উদাহরণ:

      SELECT name, department_id
      FROM employees
      WHERE (department_id, salary) IN (SELECT department_id, salary FROM employees WHERE salary > 50000);
      

      এখানে সাবকুয়েরি যেসব কর্মচারীর বেতন ৫০,০০০ এর বেশি, তাদের ডিপার্টমেন্ট আইডি এবং বেতন রিটার্ন করে।

Subquery Usage in WHERE, FROM, and SELECT Clauses:

  • WHERE clause: সাবকুয়েরি সাধারণত WHERE শর্তের মধ্যে ব্যবহার হয়।

    SELECT name FROM employees WHERE salary > (SELECT AVG(salary) FROM employees);
    
  • FROM clause: সাবকুয়েরি একটি টেবিলের মতো FROM ক্লজেও ব্যবহার করা যেতে পারে।

    SELECT department_id, MAX(salary) FROM (SELECT department_id, salary FROM employees) AS temp GROUP BY department_id;
    
  • SELECT clause: সাবকুয়েরি মূল কুয়েরির কলাম হিসাবে ব্যবহার করা যেতে পারে।

    SELECT name, (SELECT MAX(salary) FROM employees WHERE department_id = e.department_id) AS max_salary
    FROM employees e;
    

2. Nested Queries (নেস্টেড কুয়েরি)

Nested Query হল এমন একটি কুয়েরি যেখানে একটি কুয়েরি অন্য কুয়েরির ভিতরে থাকে। নেস্টেড কুয়েরি এবং সাবকুয়েরি প্রায় একই ধারণা, তবে নেস্টেড কুয়েরি সাধারণত অনেক গভীর স্তরে থাকতে পারে (যেমন একের মধ্যে আরেকটি কুয়েরি)।

Types of Nested Queries:

  1. Single-Level Nested Query:
    • এখানে একটি কুয়েরি অন্য কুয়েরির মধ্যে অন্তর্ভুক্ত থাকে।
    • উদাহরণ:

      SELECT name FROM employees WHERE department_id IN (SELECT department_id FROM departments WHERE location = 'Boston');
      
  2. Multi-Level Nested Query:
    • এটি একটি কুয়েরি যে একাধিক স্তরে থাকে।
    • উদাহরণ:

      SELECT name
      FROM employees
      WHERE department_id IN (
          SELECT department_id
          FROM departments
          WHERE location IN (
              SELECT location
              FROM cities
              WHERE city_name = 'Boston'
          )
      );
      

Performance Considerations for Nested Queries:

  • Nested Queries বা Subqueries সাধারণত পারফরম্যান্সে প্রভাব ফেলতে পারে, বিশেষত যদি এগুলি বড় ডেটাসেটে ব্যবহৃত হয়। এটি কুয়েরি অপটিমাইজেশন দ্বারা সমাধান করা যেতে পারে যেমন EXPLAIN ANALYZE ব্যবহার করা।

3. Correlated vs Uncorrelated Subqueries

  • Uncorrelated Subquery:
    • এটি একটি স্বাধীন সাবকুয়েরি, যা মূল কুয়েরির কোনো রেকর্ডের সাথে সম্পর্কিত নয়। একে একবারই এক্সিকিউট করা যায় এবং পরে মূল কুয়েরিতে ব্যবহার করা যায়।
    • উদাহরণ:

      SELECT name FROM employees WHERE salary > (SELECT AVG(salary) FROM employees);
      
  • Correlated Subquery:
    • এটি মূল কুয়েরির প্রতিটি রেকর্ডের সাথে সম্পর্কিত। এই ধরনের সাবকুয়েরি মূল কুয়েরির প্রতিটি রেকর্ডের জন্য আলাদাভাবে এক্সিকিউট হয়।
    • উদাহরণ:

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

4. Advantages and Disadvantages

Advantages of Subqueries and Nested Queries:

  • Readability: সাবকুয়েরি এবং নেস্টেড কুয়েরি ব্যবহার করলে কুয়েরি গঠন পরিষ্কার হতে পারে, বিশেষ করে জটিল শর্ত বা একাধিক লজিক একত্রিত করার ক্ষেত্রে।
  • Modularity: আপনি একটি বড় কুয়েরিকে ছোট ছোট অংশে ভাগ করে সাবকুয়েরির মাধ্যমে সহজে ব্যাখ্যা করতে পারেন।
  • Reusability: একাধিক কুয়েরি অংশের জন্য সাবকুয়েরি ব্যবহার করা যেতে পারে।

Disadvantages of Subqueries and Nested Queries:

  • Performance: সাবকুয়েরি বা নেস্টেড কুয়েরি যখন বৃহৎ ডেটাবেসে ব্যবহৃত হয়, তখন এটি কুয়েরির পারফরম্যান্সে নেতিবাচক প্রভাব ফেলতে পারে। বিশেষ করে যদি সাবকুয়েরি বারবার এক্সিকিউট হয়।
  • Complexity: নেস্টেড কুয়েরি অত্যধিক জটিল হয়ে উঠতে পারে, বিশেষত যখন অনেক স্তরে থাকে।

Conclusion

Subqueries এবং Nested Queries PostgreSQL এ জটিল কুয়েরি লেখার জন্য ব্যবহৃত হয়। সাবকুয়েরি একে অপরের মধ্যে ডেটা প্রক্রিয়া করতে সক্ষম করে এবং বিভিন্ন ধরণের ডেটা সম্পর্ক অনুসন্ধানে সহায়তা করে। তবে, এগুলির ব্যবহার করলে পারফরম্যান্স এবং কুয়েরি অপটিমাইজেশন বিষয়ে সতর্কতা অবলম্বন করা উচিত।

Content added By

Window Functions এবং Recursive Queries

297

PostgreSQL এর কিছু শক্তিশালী বৈশিষ্ট্য রয়েছে, যেমন Window Functions এবং Recursive Queries। এই দুটি ফিচার ডেটাবেস কুয়েরি লেখার সময় বেশ কার্যকরী। নিচে এই দুটি বৈশিষ্ট্য বিস্তারিতভাবে আলোচনা করা হলো।


1. Window Functions

Window Functions হল এমন ধরনের SQL ফাংশন যা একটি উইন্ডো বা সেট অফ রো-এর উপর কাজ করে এবং প্রতিটি রো এর সাথে পরবর্তী রো বা আগের রো-এর তথ্য যুক্ত করে। এই ফাংশনগুলি সাধারণত OVER() ক্লজের সাথে ব্যবহার করা হয়। এটি বিশেষভাবে অ্যাগ্রিগেট ফাংশনের (যেমন, SUM(), AVG(), COUNT()) মধ্যে আরও সূক্ষ্ম বিশ্লেষণ বা বিশ্লেষণী ফাংশন প্রদান করতে ব্যবহৃত হয়, যেখানে পুরো টেবিলের জন্য একত্রিত ফলাফল না দিয়ে প্রতি রো এর উপর হিসাব করা হয়।

Window Functions এর সাধারণ ব্যবহার

ধরা যাক, আমাদের একটি sales টেবিল আছে, যেখানে প্রতিটি বিক্রির তথ্য রয়েছে:

CREATE TABLE sales (
    id SERIAL PRIMARY KEY,
    salesperson_id INT,
    sale_amount DECIMAL,
    sale_date DATE
);

এখন, যদি আমরা প্রতিটি বিক্রির সাথে মোট বিক্রির পরিমাণ দেখতে চাই, তবে window function ব্যবহার করে আমরা এই কাজটি করতে পারি।

Example: Total Sales per Saleperson

SELECT 
    salesperson_id, 
    sale_amount,
    SUM(sale_amount) OVER (PARTITION BY salesperson_id) AS total_sales
FROM 
    sales;

ব্যাখ্যা:

  • এখানে, SUM(sale_amount) একটি window function যা salesperson_id অনুযায়ী পার্টিশনিং করে প্রতিটি বিক্রির জন্য মোট বিক্রির পরিমাণ হিসাব করে।
  • PARTITION BY salesperson_id নির্দেশ করে যে, প্রতিটি বিক্রির জন্য মোট বিক্রির পরিমাণ একই salesperson_id এর ভিত্তিতে হিসাব করা হবে।

Window Functions এর অন্য কিছু উদাহরণ

  • ROW_NUMBER(): রেকর্ডের জন্য একটি সিকোয়েন্সিয়াল নম্বর (Row number) প্রদান করে।

    SELECT 
        salesperson_id, 
        sale_amount, 
        ROW_NUMBER() OVER (ORDER BY sale_date) AS row_num
    FROM 
        sales;
    
  • RANK(): রেকর্ডের মধ্যে র‌্যাঙ্কিং প্রদান করে। সমান মানের রেকর্ডের জন্য সমান র‌্যাঙ্ক হয় এবং পরবর্তী র‌্যাঙ্কটি "স্কিপ" হয়।

    SELECT 
        salesperson_id, 
        sale_amount, 
        RANK() OVER (ORDER BY sale_amount DESC) AS rank
    FROM 
        sales;
    

2. Recursive Queries

Recursive Queries PostgreSQL-এ WITH RECURSIVE ব্যবহারের মাধ্যমে করা যায়। এই ধরনের কুয়েরি মূলত নিজের উপর কাজ করে এবং এটি ডেটাবেসের মধ্যে হায়ারার্কিক্যাল (পদানুসারে) সম্পর্কের জন্য খুবই উপযোগী। সাধারণত ট্রি ডাটা (যেমন, অর্গানাইজেশনাল চার্ট, ফোল্ডার স্ট্রাকচার) বা গ্রাফ সম্পর্কিত তথ্য (যেমন, পিতা-পুত্র সম্পর্ক) দেখার জন্য রিকার্সিভ কুয়েরি ব্যবহার করা হয়।

Recursive Query এর সাধারণ কাঠামো

WITH RECURSIVE recursive_cte AS (
    -- Base query (anchor member)
    SELECT 
        id, 
        parent_id, 
        name 
    FROM 
        categories
    WHERE 
        parent_id IS NULL

    UNION ALL

    -- Recursive query (recursive member)
    SELECT 
        c.id, 
        c.parent_id, 
        c.name
    FROM 
        categories c
    JOIN 
        recursive_cte r 
    ON 
        r.id = c.parent_id
)
SELECT * FROM recursive_cte;

ব্যাখ্যা:

  • Base query (anchor member): প্রথমে আপনি বেস কেস নির্বাচন করেন, যেখানে আপনি মূল বা শীর্ষ স্তরের তথ্য চান। যেমন এখানে, আমরা parent_id IS NULL শর্ত দিয়ে প্রথম স্তরের ডেটা নির্বাচন করছি।
  • Recursive query (recursive member): এরপর UNION ALL ব্যবহারের মাধ্যমে পরবর্তী স্তরের ডেটা নির্বাচন করি। এখানে, আমরা পূর্বের রেকর্ডের id কে পরবর্তী স্তরের parent_id হিসেবে ব্যবহার করছি।
  • Recursive CTE (Common Table Expression): এই অংশটি রিকার্সিভ কুয়েরি একত্রিত করার জন্য ব্যবহৃত হয়।

উদাহরণ: অর্গানাইজেশনাল চার্টের ডেটা

ধরা যাক, আমাদের একটি employees টেবিল রয়েছে যা কর্মচারীদের এবং তাদের ব্যবস্থাপকদের সম্পর্ক দেখায়:

CREATE TABLE employees (
    id SERIAL PRIMARY KEY,
    name VARCHAR(100),
    manager_id INT
);

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

WITH RECURSIVE employee_hierarchy AS (
    SELECT 
        id, 
        name, 
        manager_id
    FROM 
        employees
    WHERE 
        manager_id IS NULL   -- Starting with the top-level manager (root)

    UNION ALL

    SELECT 
        e.id, 
        e.name, 
        e.manager_id
    FROM 
        employees e
    JOIN 
        employee_hierarchy eh 
    ON 
        eh.id = e.manager_id   -- Recursively joining the manager-employee relation
)
SELECT * FROM employee_hierarchy;

ব্যাখ্যা:

  • এই কুয়েরি আমাদের কর্মচারীদের এবং তাদের ম্যানেজারের মধ্যে সম্পর্ক তৈরি করবে, যেখানে প্রথমে শীর্ষস্তরের কর্মচারী (ম্যানেজার) নির্বাচন করা হয় এবং তারপরে তার অধীনস্থ কর্মচারীদের পুনরায় নির্বাচন করা হয়।

সারাংশ

  • Window Functions PostgreSQL-এ ডেটাবেস কুয়েরি বিশ্লেষণ করার জন্য ব্যবহৃত হয়। এটি একটি উইন্ডো বা রো-এর সেটের উপর কাজ করে এবং বিশেষভাবে অ্যাগ্রিগেট ফাংশন এবং রাঙ্কিং-এর জন্য ব্যবহৃত হয়।
  • Recursive Queries PostgreSQL-এ WITH RECURSIVE কুয়েরি ব্যবহারের মাধ্যমে করা হয়, যা মূলত ডেটাবেসের মধ্যে হায়ারার্কিক্যাল সম্পর্ক (যেমন পিতা-পুত্র বা অর্গানাইজেশনাল চার্ট) বিশ্লেষণ করতে ব্যবহৃত হয়।

এই দুটি ফিচার PostgreSQL-এ শক্তিশালী কুয়েরি লেখার ক্ষমতা প্রদান করে এবং বড় এবং জটিল ডেটা সেটের জন্য কার্যকরী বিশ্লেষণ করতে সহায়তা করে।

Content added By
Promotion

Are you sure to start over?

Loading...