CTE এবং Subquery এর পার্থক্য

CTE (Common Table Expressions) এবং Recursive Queries - টি-এসকিউএল (T-SQL) - Database Tutorials

336

CTE (Common Table Expression) এবং Subquery উভয়ই SQL-এ এমন প্রযুক্তি, যা ডেটাবেসে জটিল প্রশ্ন (query) তৈরি করতে সাহায্য করে। তবে, তাদের ব্যবহার, কাঠামো এবং পারফরম্যান্সের ক্ষেত্রে কিছু পার্থক্য রয়েছে।

নিচে CTE এবং Subquery এর মধ্যে প্রধান পার্থক্যগুলি আলোচনা করা হলো:


১. সংজ্ঞা (Definition)

  • CTE (Common Table Expression):
    CTE হল একটি অস্থায়ী ফলাফল সেট যা একটি SQL কুয়েরির মধ্যে ব্যবহার করা হয়। এটি WITH কিওয়ার্ড ব্যবহার করে তৈরি হয় এবং একটি প্রাথমিক কুয়েরি ব্লক হিসেবে কাজ করে। CTE সাধারণত আরও বড় বা জটিল কুয়েরি লেখার জন্য ব্যবহার করা হয়, যা অন্যান্য কুয়েরি বা অপারেশন দ্বারা পুনরায় ব্যবহারযোগ্য হতে পারে।

    উদাহরণ:

    WITH DepartmentCTE AS (
        SELECT Department, COUNT(*) AS EmployeeCount
        FROM Employees
        GROUP BY Department
    )
    SELECT * FROM DepartmentCTE;
    
  • Subquery:
    Subquery হল একটি কুয়েরি যা অন্য একটি কুয়েরির মধ্যে অন্তর্ভুক্ত থাকে। এটি সাধারণত SELECT, INSERT, UPDATE, অথবা DELETE স্টেটমেন্টের মধ্যে অন্তর্ভুক্ত থাকে। Subquery তে আপনি একটি কুয়েরি চালাতে পারেন যেটি অন্য কুয়েরির ফলাফল হিসেবে ব্যবহৃত হয়।

    উদাহরণ:

    SELECT EmployeeName
    FROM Employees
    WHERE DepartmentID IN (SELECT DepartmentID FROM Departments WHERE DepartmentName = 'HR');
    

২. ব্যবহার (Usage)

  • CTE:
    • CTE সাধারণত WITH কিওয়ার্ডের সাথে ব্যবহার করা হয় এবং একটি কুয়েরির প্রথমে স্থাপন করা হয়।
    • এটি একাধিকবার ব্যবহার করা যেতে পারে (যেমন, JOIN, UNION ইত্যাদিতে) একই কুয়েরির মধ্যে।
    • এটি কোডটিকে আরও পরিষ্কার এবং বুঝতে সহজ করে তোলে, বিশেষ করে যখন বড় বা জটিল কুয়েরি তৈরি করতে হয়।
    • CTE ব্যবহার করার সময় আপনি আগের কুয়েরির ফলাফল ব্যবহার করে আরও কুয়েরি তৈরি করতে পারেন।
  • Subquery:
    • Subquery কুয়েরির ভিতরে এক বা একাধিক স্থানে ব্যবহার করা যেতে পারে (যেমন, SELECT, WHERE, HAVING, FROM ক্লজে)।
    • এটি কুয়েরির মধ্যে অন্তর্ভুক্ত থাকে এবং কোনও নির্দিষ্ট ফলাফল পেতে ব্যবহৃত হয়।
    • Subquery সাধারণত একটি একক ব্যবহারকারীর জন্য একক কুয়েরি হতে থাকে, যার জন্য কোডটি সাধারণত খুব পরিষ্কার থাকে না।

৩. পুনঃব্যবহারযোগ্যতা (Reusability)

  • CTE:
    • CTE পুনরায় ব্যবহারযোগ্য, অর্থাৎ আপনি একবার CTE ডিফাইন করার পর, সেটি একাধিকবার SELECT, INSERT, UPDATE, বা DELETE স্টেটমেন্টে ব্যবহার করতে পারেন।
    • CTE যখন একাধিকবার ব্যবহৃত হয়, তখন এটি কোডটি পরিষ্কার এবং কমপ্যাক্ট রাখে।
  • Subquery:
    • Subquery সাধারণত একবার ব্যবহার করা হয়। তবে, আপনি যদি একই Subquery বারবার ব্যবহার করতে চান, তাহলে আপনাকে এটি আবার লিখতে হবে।
    • Subquery প্রায়ই ইনলাইন কুয়েরি হিসাবে ব্যবহৃত হয়।

৪. পারফরম্যান্স (Performance)

  • CTE:
    • CTE সাধারণত বড় এবং জটিল কুয়েরি তৈরি করার জন্য ভালো কারণ এটি কোডটিকে পুনরায় ব্যবহারযোগ্য করে তোলে। তবে, CTE এর পারফরম্যান্স Subquery এর তুলনায় কম হতে পারে, যদি না সেগুলি সঠিকভাবে অপটিমাইজ করা হয়।
    • কিছু ক্ষেত্রে, CTE-কে উপকারী হতে পারে কারণ এটি SQL Server-কে পুনরায় ব্যবহারের জন্য একটি একক কৌশল তৈরি করতে দেয়।
  • Subquery:
    • Subquery কুয়েরি সময়ে সম্পাদন করা হয় এবং ফলাফল একবারের জন্য ব্যবহার করা হয়, যা পারফরম্যান্সে বেশি চাপ ফেলতে পারে। বড় ডেটাসেটের ক্ষেত্রে, সাবকুয়েরি কিছুটা ধীর হতে পারে।
    • তবে, Subquery সাধারণত কম জটিল এবং সহজ অপারেশনের জন্য দ্রুত হতে পারে।

৫. পাঠযোগ্যতা (Readability)

  • CTE:
    • CTE কোডটিকে পরিষ্কার এবং সহজভাবে পড়া যায় কারণ এটি অস্থায়ী টেবিল হিসেবে কাজ করে এবং তারপরে CTE কে পুনরায় ব্যবহার করা যায়।
    • CTE দীর্ঘ এবং জটিল কুয়েরি সহজে ডিবাগ করার সুযোগ দেয়।
  • Subquery:
    • Subquery কোডের মধ্যে অন্তর্ভুক্ত থাকে এবং বেশ কিছু ক্ষেত্রে কোডটি বিভ্রান্তিকর হতে পারে।
    • যখন Subquery খুব জটিল হয় এবং এটি অনেক বার ব্যবহৃত হয়, তখন কোড পড়তে সমস্যা হতে পারে।

৬. Multiple CTEs vs Subqueries

  • Multiple CTEs:

    • আপনি একাধিক CTE ডিফাইন করতে পারেন একই কুয়েরিতে। এটি কোডের পাঠযোগ্যতা বাড়ায় এবং একাধিক স্টেপে ফলাফল প্রক্রিয়া করতে সহায়ক হয়।
    • উদাহরণ:
    WITH CTE1 AS (
        SELECT EmployeeID, Department FROM Employees
    ),
    CTE2 AS (
        SELECT Department, COUNT(*) AS TotalEmployees FROM CTE1 GROUP BY Department
    )
    SELECT * FROM CTE2;
    
  • Subquery:
    • Subqueries সাধারণত একক কুয়েরিতে ব্যবহৃত হয় এবং একাধিক Subquery ব্যবহার করতে চাইলে, এটি কিছুটা জটিল এবং দুর্বল পড়তে পারে।

৭. রিস্কোপ (Scope)

  • CTE:
    • CTE শুধুমাত্র ঐ কুয়েরির জন্য কার্যকর থাকে যেখানে এটি ডিফাইন করা হয়, অর্থাৎ CTE কেবল এক কুয়েরি রানে এবং পরে অদৃশ্য হয়ে যায়।
  • Subquery:
    • Subquery সাধারণত নির্দিষ্ট ডেটা ফিল্টার করতে ব্যবহৃত হয় এবং সাধারণত নিজস্ব পরিসরে কাজ করে।

সারাংশ

ক্রাইটেরিয়াCTE (Common Table Expression)Subquery
সংজ্ঞাঅস্থায়ী ফলাফল সেট যা SQL কুয়েরি দ্বারা তৈরি হয়।একটি কুয়েরি যা অন্য একটি কুয়েরির মধ্যে ব্যবহৃত হয়।
ব্যবহারপুনরায় ব্যবহারের জন্য ডেটা সংরক্ষণ ও গ্রুপিং।একক কুয়েরি ফলাফলের মধ্যে অন্তর্ভুক্ত হওয়া।
পুনঃব্যবহারযোগ্যতাএকাধিকবার ব্যবহার করা যেতে পারে।সাধারণত একবার ব্যবহৃত হয়।
পারফরম্যান্সকিছুটা ধীর হতে পারে, যদি অপটিমাইজ না করা হয়।ছোট ডেটাসেটে দ্রুত, কিন্তু বড় ডেটাসেটে ধীর।
পাঠযোগ্যতাপরিষ্কার, বড় কুয়েরি সহজে পড়া যায়।কিছুটা জটিল হতে পারে, বিশেষত বড় কুয়েরিতে।
প্রতিবন্ধকতাএকাধিক CTE একে অপরের সাথে ব্যবহৃত হতে পারে।সাধারণত একক সাবকুয়েরি হিসাবে ব্যবহৃত হয়।

CTE ডেটা গ্রুপিং এবং পুনরায় ব্যবহারযোগ্য কোডের জন্য একটি শক্তিশালী সরঞ্জাম, তবে Subquery সাধারণত সিম্পল ডেটা ফিল্টারিং বা এক্সপ্রেশন কাজের জন্য উপযুক্ত।

Content added By
Promotion

Are you sure to start over?

Loading...