Exception Handling

Database Tutorials - টি-এসকিউএল (T-SQL)
298

Exception Handling T-SQL-এ ত্রুটি বা সমস্যা সমাধানের জন্য ব্যবহৃত একটি কৌশল। যখন SQL Server-এ কোনো ত্রুটি বা অপ্রত্যাশিত পরিস্থিতি ঘটে, তখন সেগুলি গ্রহন করার জন্য এবং সঠিক পদক্ষেপ নেওয়ার জন্য TRY...CATCH ব্লক ব্যবহৃত হয়। এটি ত্রুটির নির্দিষ্ট তথ্য ধরতে এবং তা সঠিকভাবে সমাধান করতে সাহায্য করে।

১. TRY...CATCH ব্লক

T-SQL এ TRY...CATCH ব্লক ব্যবহার করে আপনি ত্রুটি শনাক্ত করতে এবং সেগুলির উপর নির্দিষ্ট অ্যাকশন নিতে পারেন। যখন TRY ব্লক এর মধ্যে কোনো ত্রুটি ঘটে, তখন তা CATCH ব্লকে চলে যায় এবং সেখানে সেই ত্রুটির উপর কাজ করা হয়।

সাধারণ সিনট্যাক্স:

BEGIN TRY
    -- T-SQL স্টেটমেন্ট যা ত্রুটি তৈরি করতে পারে
END TRY
BEGIN CATCH
    -- T-SQL স্টেটমেন্ট যা ত্রুটি হ্যান্ডলিং এর জন্য ব্যবহৃত হয়
END CATCH

২. Error Handling উদাহরণ

ধরা যাক, আমাদের একটি Employees টেবিল আছে এবং আমরা একটি আপডেট অপারেশন করার চেষ্টা করছি। কিন্তু যদি কোনো ত্রুটি ঘটে, যেমন ডিভাইড বাই জিরো, তখন তা CATCH ব্লকে ধরা যাবে।

BEGIN TRY
    -- একটি আপডেট স্টেটমেন্ট
    UPDATE Employees
    SET Salary = Salary / 0  -- ডিভাইড বাই জিরো ত্রুটি
    WHERE EmployeeID = 1;
END TRY
BEGIN CATCH
    -- ত্রুটি হলে এখানে তা হ্যান্ডল করা হবে
    PRINT 'Error: ' + ERROR_MESSAGE();
END CATCH

এখানে:

  • TRY ব্লকে আমরা Salary ফিল্ডে 0 দিয়ে ভাগ করার চেষ্টা করেছি, যা একটি ত্রুটি সৃষ্টি করবে।
  • CATCH ব্লকে ERROR_MESSAGE() ফাংশন ব্যবহার করে ত্রুটির বার্তা মুদ্রিত হবে।

৩. Error Functions

CATCH ব্লক এ আপনি কিছু বিশেষ error functions ব্যবহার করতে পারেন যা ত্রুটির বিস্তারিত তথ্য প্রদান করবে। কিছু গুরুত্বপূর্ণ error functions হল:

  1. ERROR_MESSAGE(): ত্রুটির বার্তা রিটার্ন করে।
  2. ERROR_SEVERITY(): ত্রুটির গম্ভীরতা (Severity) রিটার্ন করে।
  3. ERROR_STATE(): ত্রুটির অবস্থান (State) রিটার্ন করে।
  4. ERROR_NUMBER(): ত্রুটির নম্বর (Error Code) রিটার্ন করে।

উদাহরণ:

BEGIN TRY
    -- কিছু অপারেশন যা ত্রুটি সৃষ্টি করতে পারে
    INSERT INTO Employees (EmployeeID, Name, Salary)
    VALUES (NULL, 'John Doe', 5000);  -- NULL ভ্যালু দেওয়ার কারণে ত্রুটি হতে পারে
END TRY
BEGIN CATCH
    PRINT 'Error Number: ' + CAST(ERROR_NUMBER() AS VARCHAR);
    PRINT 'Error Message: ' + ERROR_MESSAGE();
    PRINT 'Error Severity: ' + CAST(ERROR_SEVERITY() AS VARCHAR);
    PRINT 'Error State: ' + CAST(ERROR_STATE() AS VARCHAR);
END CATCH

এখানে:

  • ERROR_NUMBER(): ত্রুটির নম্বর রিটার্ন করবে (যেমন 515 - Cannot insert the value NULL into column 'EmployeeID').
  • ERROR_MESSAGE(): ত্রুটির বার্তা রিটার্ন করবে।
  • ERROR_SEVERITY(): ত্রুটির গম্ভীরতা নির্ধারণ করবে (1 থেকে 25 পর্যন্ত)।
  • ERROR_STATE(): ত্রুটির অবস্থান (State) রিটার্ন করবে।

৪. Transaction এবং Error Handling

ত্রুটির কারণে আপনি Transaction রোলব্যাক করতে পারেন, যাতে ডেটাবেসে কোনো অপূর্ণ ডেটা বা অসম্পূর্ণ পরিবর্তন না ঘটে।

উদাহরণ:

BEGIN TRY
    BEGIN TRANSACTION;  -- ট্রানজ্যাকশন শুরু করা

    -- কিছু SQL স্টেটমেন্ট
    UPDATE Employees SET Salary = Salary + 500 WHERE EmployeeID = 1;

    -- যদি সবকিছু ঠিক থাকে, ট্রানজ্যাকশন কমিট করা হবে
    COMMIT TRANSACTION;
END TRY
BEGIN CATCH
    -- যদি ত্রুটি ঘটে, ট্রানজ্যাকশন রোলব্যাক করা হবে
    ROLLBACK TRANSACTION;
    
    PRINT 'Error Message: ' + ERROR_MESSAGE();
END CATCH

এখানে:

  • BEGIN TRANSACTION: ট্রানজ্যাকশন শুরু করা হয়েছে।
  • COMMIT TRANSACTION: যদি কোনো ত্রুটি না ঘটে, তবে সমস্ত পরিবর্তন সঞ্চয় করা হবে।
  • ROLLBACK TRANSACTION: যদি কোনো ত্রুটি ঘটে, তাহলে সবকিছু রোলব্যাক হবে এবং পূর্বের অবস্থা পুনরুদ্ধার হবে।

৫. Nested TRY...CATCH

T-SQL তে একাধিক TRY...CATCH ব্লক থাকতে পারে, যেগুলি একে অপরের মধ্যে অবস্থান করতে পারে, যেমন এক ব্লকের মধ্যে আরেকটি ব্লক। তবে, এটি সাধারণত জটিল হয়ে পড়ে, তাই সাবধানতার সাথে ব্যবহৃত হওয়া উচিত।

উদাহরণ:

BEGIN TRY
    -- প্রথম TRY ব্লক
    BEGIN TRY
        -- কিছু অপারেশন যা ত্রুটি সৃষ্টি করতে পারে
        SELECT 1 / 0;  -- ডিভাইড বাই জিরো ত্রুটি
    END TRY
    BEGIN CATCH
        PRINT 'Inner CATCH: ' + ERROR_MESSAGE();
    END CATCH
END TRY
BEGIN CATCH
    -- বাইরের CATCH ব্লক
    PRINT 'Outer CATCH: ' + ERROR_MESSAGE();
END CATCH

এখানে, প্রথম TRY ব্লকে CATCH ব্লক রয়েছে এবং দ্বিতীয় TRY ব্লকেও একটি CATCH ব্লক রয়েছে।


সারাংশ

  • T-SQL Exception Handling ত্রুটিগুলিকে ক্যাপচার করার জন্য TRY...CATCH ব্লক ব্যবহার করে।
  • ERROR_MESSAGE(), ERROR_NUMBER(), ERROR_SEVERITY(), এবং ERROR_STATE() সহ বিভিন্ন ত্রুটি ফাংশন ব্যবহার করা যায়।
  • Transaction এর সাথে ত্রুটি হ্যান্ডলিং ব্যবহার করা হয় যাতে ডেটাবেসে অপর্যাপ্ত পরিবর্তন না ঘটে।
  • Nested TRY...CATCH ব্যবহার করা যেতে পারে, তবে তা সাবধানে ব্যবহৃত হওয়া উচিত।

T-SQL Exception Handling উন্নত ডেটাবেস ব্যবস্থাপনায় সহায়ক এবং ডেটাবেসের স্বচ্ছতা ও নিরাপত্তা নিশ্চিত করতে সাহায্য করে।

Content added By

TRY...CATCH ব্লক ব্যবহার

323

T-SQL এ TRY...CATCH ব্লক ব্যবহার করা হয় ত্রুটি (error) পরিচালনার জন্য। এটি ত্রুটি ঘটলে কোডের নির্বাহ বন্ধ না করে ত্রুটির বিবরণ ধরা এবং একটি নির্দিষ্ট একশন গ্রহণ করার সুযোগ দেয়। TRY ব্লকটি কোডের যে অংশে ত্রুটি ঘটতে পারে, সেখানেই লেখা হয়, আর CATCH ব্লকটি ত্রুটি ঘটলে চালু হয় এবং ত্রুটির সংক্রান্ত তথ্য রিটার্ন করে।

TRY...CATCH ব্লক এর সাধারণ কাঠামো:

BEGIN TRY
    -- এই অংশে যে কোড ত্রুটি ঘটাতে পারে, তা লেখা হয়
    -- যেমন ডেটাবেস অপারেশন
END TRY
BEGIN CATCH
    -- এই অংশে ত্রুটি হলে যে কোড এক্সিকিউট হবে, তা লেখা হয়
    -- যেমন ত্রুটির বিস্তারিত তথ্য দেখানো
    PRINT 'Error Message: ' + ERROR_MESSAGE();
    PRINT 'Error Number: ' + CAST(ERROR_NUMBER() AS NVARCHAR(50));
    PRINT 'Error Severity: ' + CAST(ERROR_SEVERITY() AS NVARCHAR(50));
    PRINT 'Error State: ' + CAST(ERROR_STATE() AS NVARCHAR(50));
END CATCH

তিনটি মূল ফাংশন:

  • ERROR_MESSAGE(): ত্রুটির বার্তা বা বর্ণনা রিটার্ন করে।
  • ERROR_NUMBER(): ত্রুটির নম্বর রিটার্ন করে।
  • ERROR_SEVERITY(): ত্রুটির গম্ভীরতার স্তর রিটার্ন করে (1-25 মধ্যে একটি সংখ্যা)।
  • ERROR_STATE(): ত্রুটির অবস্থার কোড রিটার্ন করে।

TRY...CATCH ব্লক ব্যবহার উদাহরণ

উদাহরণ ১: একটি ভুল ইনসার্ট স্টেটমেন্ট এবং ত্রুটি পরিচালনা

BEGIN TRY
    -- ভুল ইনসার্ট স্টেটমেন্ট (প্রাথমিকভাবে একটি ভুল কমান্ড যা ত্রুটি তৈরি করবে)
    INSERT INTO Employees (EmployeeID, EmployeeName)
    VALUES (NULL, 'John Doe'); -- EmployeeID NULL হতে পারে না
END TRY
BEGIN CATCH
    -- ত্রুটি হলে এখানে কোড চলে আসবে
    PRINT 'Error Message: ' + ERROR_MESSAGE();
    PRINT 'Error Number: ' + CAST(ERROR_NUMBER() AS NVARCHAR(50));
    PRINT 'Error Severity: ' + CAST(ERROR_SEVERITY() AS NVARCHAR(50));
    PRINT 'Error State: ' + CAST(ERROR_STATE() AS NVARCHAR(50));
END CATCH

ব্যাখ্যা:

  • উপরের কোডে, EmployeeID কলামে NULL ইনপুট করা হবে যা ত্রুটি সৃষ্টি করবে কারণ EmployeeID কলামে NULL অনুমোদিত নয়।
  • TRY ব্লকের মধ্যে ত্রুটি ঘটলে তা CATCH ব্লকে চলে যাবে এবং ত্রুটির তথ্য দেখানো হবে।

আউটপুট:

Error Message: Cannot insert the value NULL into column 'EmployeeID', table 'Database.dbo.Employees'; column does not allow nulls. INSERT fails.
Error Number: 515
Error Severity: 16
Error State: 2

উদাহরণ ২: একাধিক SQL অপারেশনের মধ্যে ত্রুটি পরিচালনা

BEGIN TRY
    -- প্রথমে সঠিক SQL অপারেশন
    PRINT 'Executing first operation...';
    INSERT INTO Employees (EmployeeID, EmployeeName) VALUES (101, 'Alice');
    
    -- দ্বিতীয় অপারেশন যেখানে ত্রুটি ঘটবে
    PRINT 'Executing second operation...';
    INSERT INTO Employees (EmployeeID, EmployeeName) VALUES (NULL, 'Bob'); -- এটি ত্রুটি ঘটাবে
END TRY
BEGIN CATCH
    -- ত্রুটি ঘটলে এখানে কোড চালু হবে
    PRINT 'Error Message: ' + ERROR_MESSAGE();
    PRINT 'Error Number: ' + CAST(ERROR_NUMBER() AS NVARCHAR(50));
    PRINT 'Error Severity: ' + CAST(ERROR_SEVERITY() AS NVARCHAR(50));
    PRINT 'Error State: ' + CAST(ERROR_STATE() AS NVARCHAR(50));
END CATCH

ব্যাখ্যা:

  • প্রথমে একটি সঠিক INSERT অপারেশন সম্পাদন হবে। তারপর দ্বিতীয় INSERT স্টেটমেন্টে NULL ইনপুট দেওয়ার কারণে ত্রুটি ঘটবে, যা CATCH ব্লক দ্বারা পরিচালিত হবে।

আউটপুট:

Executing first operation...
Executing second operation...
Error Message: Cannot insert the value NULL into column 'EmployeeID', table 'Database.dbo.Employees'; column does not allow nulls. INSERT fails.
Error Number: 515
Error Severity: 16
Error State: 2

TRANSACTION এর সাথে TRY...CATCH ব্লক

TRANSACTION এর সঙ্গে TRY...CATCH ব্লক ব্যবহার করে আপনি ডেটাবেসে একাধিক কার্যক্রম পরিচালনা করতে পারেন এবং যদি কোনো ত্রুটি ঘটে, তবে ROLLBACK করে ডেটাবেস পরিবর্তন বাতিল করতে পারেন।

উদাহরণ ৩: ট্রানজেকশনের সাথে T-SQL ত্রুটি পরিচালনা

BEGIN TRY
    BEGIN TRANSACTION;
    
    -- প্রথম অপারেশন
    INSERT INTO Employees (EmployeeID, EmployeeName) VALUES (102, 'David');
    
    -- দ্বিতীয় অপারেশন (ত্রুটি ঘটবে)
    INSERT INTO Employees (EmployeeID, EmployeeName) VALUES (NULL, 'Eva'); -- ত্রুটি
    
    COMMIT; -- যদি কোন ত্রুটি না ঘটে, তাহলে COMMIT হবে
END TRY
BEGIN CATCH
    -- ত্রুটি হলে ROLLBACK করা হবে
    ROLLBACK;
    
    PRINT 'Error Message: ' + ERROR_MESSAGE();
    PRINT 'Error Number: ' + CAST(ERROR_NUMBER() AS NVARCHAR(50));
    PRINT 'Error Severity: ' + CAST(ERROR_SEVERITY() AS NVARCHAR(50));
    PRINT 'Error State: ' + CAST(ERROR_STATE() AS NVARCHAR(50));
END CATCH

ব্যাখ্যা:

  • এখানে একটি TRANSACTION শুরু করা হয়েছে।
  • প্রথম INSERT অপারেশন সফলভাবে সম্পন্ন হলে দ্বিতীয় INSERT অপারেশন ত্রুটি তৈরি করবে কারণ EmployeeID কলামে NULL ইনপুট অনুমোদিত নয়।
  • ত্রুটি হলে CATCH ব্লকটি ROLLBACK চালাবে এবং সমস্ত পরিবর্তন বাতিল করবে।

আউটপুট:

Error Message: Cannot insert the value NULL into column 'EmployeeID', table 'Database.dbo.Employees'; column does not allow nulls. INSERT fails.
Error Number: 515
Error Severity: 16
Error State: 2

সারাংশ

T-SQL তে TRY...CATCH ব্লক ব্যবহার করে আপনি ত্রুটি হ্যান্ডলিং করতে পারেন। এটি ত্রুটির ঘটনার পর ডেটাবেস পরিবর্তন রক্ষা এবং বিস্তারিত ত্রুটির বার্তা প্রাপ্ত করতে সহায়তা করে। TRANSACTION এর সাথে TRY...CATCH ব্লক ব্যবহার করলে একাধিক কার্যক্রমের মাঝে ত্রুটি ঘটলে ROLLBACK করে ডেটাবেস পরিবর্তন বাতিল করা যায়।

Content added By

Error Handling এবং RAISERROR ফাংশন

271

T-SQL (Transact-SQL) তে Error Handling গুরুত্বপূর্ণ একটি অংশ, কারণ এটি ডেটাবেসের ত্রুটির মোকাবিলা এবং সেগুলোর সঠিক সমাধান নিশ্চিত করতে সাহায্য করে। RAISERROR ফাংশন ব্যবহার করে আপনি কাস্টম ত্রুটি বার্তা তৈরি করতে এবং সেগুলি ডাটাবেসে ফিরিয়ে দিতে পারেন, যা পরে প্রোগ্রাম বা ব্যবহারকারী দ্বারা হ্যান্ডল করা যায়।

T-SQL তে Error Handling এবং RAISERROR ফাংশন সম্পর্কে বিস্তারিত আলোচনা করা হলো:


১. Error Handling in T-SQL

T-SQL তে ত্রুটি বা Error Handling করার জন্য TRY...CATCH ব্লক ব্যবহৃত হয়। এটি SQL কোডের মধ্যে ত্রুটি ধরা এবং প্রক্রিয়া করার জন্য ব্যবহৃত হয়। যখন TRY ব্লকের মধ্যে কোনো ত্রুটি ঘটে, তখন CATCH ব্লকটি কার্যকর হয় এবং ত্রুটির তথ্য হ্যান্ডেল করা হয়।

TRY...CATCH স্টেটমেন্ট

TRY...CATCH স্টেটমেন্ট দুটি ব্লক দিয়ে গঠিত:

  1. TRY ব্লক: যেখানে আপনি কোড লিখবেন এবং যদি সেখানে কোনো ত্রুটি ঘটে, তাহলে তা CATCH ব্লকে চলে যাবে।
  2. CATCH ব্লক: এই ব্লকে ত্রুটি সম্পর্কে তথ্য প্রাপ্তি এবং সেগুলোর সমাধান বা লগ করা হয়।

সিনট্যাক্স:

BEGIN TRY
    -- আপনার T-SQL কোড
END TRY
BEGIN CATCH
    -- ত্রুটি হ্যান্ডলিং কোড
    PRINT ERROR_MESSAGE(); -- ত্রুটির বার্তা প্রিন্ট করা
END CATCH;

ERROR_MESSAGE() ফাংশন

  • ERROR_MESSAGE() ফাংশনটি CATCH ব্লকে ব্যবহৃত হয় এবং এটি ত্রুটির বিস্তারিত বার্তা প্রদান করে।

২. RAISERROR ফাংশন

RAISERROR ফাংশন ব্যবহার করে আপনি কাস্টম ত্রুটি বার্তা তৈরি করতে পারেন এবং তা ডাটাবেসে বা অ্যাপ্লিকেশনে রিটার্ন করতে পারেন। এটি ডেটাবেসের মধ্যে একটি ত্রুটি সৃষ্টি করে, যাতে SQL Server ত্রুটির বার্তা জেনারেট করে এবং সেটা ব্যবহারকারী বা অ্যাপ্লিকেশনের কাছে পাঠায়।

RAISERROR সিনট্যাক্স:

RAISERROR (message_string, severity, state);
  • message_string: ত্রুটি বার্তা বা মেসেজ যা আপনি তৈরি করবেন।
  • severity: ত্রুটির গুরুত্ব (০ থেকে ২৫ পর্যন্ত মান).
  • state: ত্রুটির অবস্থা (০ থেকে ২৫ পর্যন্ত মান).

Severity:

  • 0-18: সাধারণ ত্রুটি।
  • 19-25: গুরুতর ত্রুটি, যা ডেটাবেস অ্যাডমিনিস্ট্রেটর বা টেকনিক্যাল সাপোর্ট দ্বারা সমাধান করতে হতে পারে।

RAISERROR উদাহরণ:

RAISERROR('This is a custom error message', 16, 1);

এটি একটি কাস্টম ত্রুটি বার্তা তৈরি করবে এবং severity 16 এবং state 1 সহ ত্রুটির বার্তা ফিরিয়ে দেবে।


৩. RAISERROR এর ব্যবহার

RAISERROR ফাংশনটি Error Handling এর মধ্যে কাস্টম ত্রুটি বার্তা এবং লগিং প্রক্রিয়া তৈরি করতে ব্যবহৃত হয়। আপনি এটি সঠিক ত্রুটির বার্তা ফেলে SQL কোডে ত্রুটি পরিস্থিতি নির্দেশ করার জন্য ব্যবহার করতে পারেন।

উদাহরণ ১: কাস্টম ত্রুটি বার্তা

BEGIN TRY
    -- কিছু ত্রুটিপূর্ণ কোড
    DECLARE @Age INT = -1;
    IF @Age < 0
        RAISERROR('Age cannot be negative!', 16, 1);
END TRY
BEGIN CATCH
    PRINT ERROR_MESSAGE();  -- ত্রুটি বার্তা প্রিন্ট করা
END CATCH;

এখানে, যদি Age নেগেটিভ হয়, তাহলে RAISERROR একটি কাস্টম ত্রুটি বার্তা তৈরি করবে এবং সেটি CATCH ব্লকে ধরা হবে।


উদাহরণ ২: RAISERROR সহ একটি ট্রানজ্যাকশন

BEGIN TRY
    BEGIN TRANSACTION;

    -- কিছু অপারেশন
    UPDATE Accounts SET Balance = Balance - 100 WHERE AccountID = 1;
    
    -- কাস্টম ত্রুটি বার্তা
    IF @@ERROR <> 0
        RAISERROR('Error occurred during transaction, rolling back!', 16, 1);
    
    COMMIT TRANSACTION;
END TRY
BEGIN CATCH
    -- রোলব্যাক এবং ত্রুটি বার্তা প্রিন্ট করা
    ROLLBACK TRANSACTION;
    PRINT ERROR_MESSAGE();
END CATCH;

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


৪. RAISERROR এবং THROW এর মধ্যে পার্থক্য

  • RAISERROR এবং THROW উভয়ই ত্রুটি তৈরি করতে ব্যবহৃত হয়, তবে কিছু পার্থক্য রয়েছে:
    • RAISERROR: আপনি কাস্টম ত্রুটি বার্তা এবং severity level উল্লেখ করতে পারেন এবং এটি প্রোগ্রাম ফ্লো চালিয়ে যেতে সাহায্য করে। তবে, RAISERROR ত্রুটির পরে কোড চালানো অব্যাহত থাকে (যদি আপনি TRY...CATCH না ব্যবহার করেন)।
    • THROW: এটি SQL Server 2012 এবং পরবর্তী সংস্করণে পরিচিত এবং এটি সোজাসুজি ত্রুটি তৈরি করে এবং তখনই ট্রানজ্যাকশনটি থামিয়ে দেয়। এটি CATCH ব্লকের মাধ্যমে পুনরায় ত্রুটি থ্রো করতে সহায়ক।

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

BEGIN TRY
    THROW 50000, 'Custom error using THROW', 1;
END TRY
BEGIN CATCH
    PRINT ERROR_MESSAGE();
END CATCH;

এটি একটি ত্রুটি তৈরি করবে এবং ত্রুটি বার্তা প্রিন্ট করবে।


সারাংশ

  • Error Handling T-SQL এর একটি গুরুত্বপূর্ণ অংশ যা ত্রুটি থেকে প্রোগ্রামের কার্যকারিতা বজায় রাখতে সাহায্য করে।
  • RAISERROR ফাংশন ব্যবহার করে আপনি কাস্টম ত্রুটি বার্তা তৈরি করতে পারেন এবং প্রয়োজনে SQL কোডে তা থ্রো করতে পারেন।
  • TRY...CATCH ব্লক ব্যবহার করে T-SQL-এ ত্রুটি হ্যান্ডলিং করা যায় এবং ত্রুটির সঠিক বার্তা এবং লগিং পরিচালনা করা যায়।
  • RAISERROR ত্রুটি সৃষ্টির জন্য ব্যবহৃত হয়, তবে THROW নতুন ত্রুটি তৈরি করার জন্য একটি বিকল্প ফাংশন যা আরো সরলভাবে কাজ করে।

Error Handling এবং RAISERROR ফাংশনটি কার্যকরভাবে ত্রুটি পরিচালনা এবং সিস্টেমের স্থিতিশীলতা নিশ্চিত করার জন্য ব্যবহৃত হয়।

Content added By

THROW ফাংশনের ব্যবহার

286

T-SQL এর THROW স্টেটমেন্টটি ডাটাবেসের মধ্যে ত্রুটি বা এক্সেপশন তৈরি করতে ব্যবহৃত হয়। এটি একটি নির্দিষ্ট ত্রুটি বার্তা প্রেরণ করতে বা একটি বিদ্যমান ত্রুটি পুনরায় ফেলে দিতে সক্ষম। THROW সাধারণত TRY...CATCH ব্লকের মধ্যে ব্যবহৃত হয় এবং ত্রুটি হ্যান্ডলিং করতে সহায়তা করে।

THROW দুটি প্রধান ব্যবহারের ক্ষেত্রে ব্যবহার করা যেতে পারে:

  1. নতুন ত্রুটি তৈরি করা: একটি কাস্টম ত্রুটি বার্তা তৈরি এবং ফেলা।
  2. বিদ্যমান ত্রুটি পুনরায় ফেলা: কোনো বিদ্যমান ত্রুটি পুনরায় নিক্ষেপ করা।

১. নতুন ত্রুটি তৈরি করা

আপনি THROW স্টেটমেন্ট ব্যবহার করে একটি নতুন ত্রুটি তৈরি করতে পারেন এবং একটি কাস্টম ত্রুটি বার্তা প্রদর্শন করতে পারেন। যখন একটি ত্রুটি তৈরি করা হয়, তখন Error Number, Message, এবং State নির্দিষ্ট করা হয়।

সিনট্যাক্স:

THROW error_number, message, state;
  • error_number: ত্রুটির জন্য একটি নির্দিষ্ট ত্রুটি কোড (১ থেকে ২৫৫ এর মধ্যে হতে পারে)।
  • message: ত্রুটি বার্তা যা ব্যবহারকারীকে দেখানো হবে।
  • state: একটি ইনটিজার মান যা ত্রুটির অবস্থাকে চিহ্নিত করে (এটি 0 থেকে 255 এর মধ্যে হতে পারে, সাধারণত 0 ব্যবহৃত হয়)।

উদাহরণ:

BEGIN TRY
    -- কোনো কনডিশন চেক করতে হবে
    IF (1 = 1) -- শর্ত মিথ্যা হলে ত্রুটি তৈরি
    BEGIN
        THROW 50000, 'Custom error message: Something went wrong!', 1;
    END
END TRY
BEGIN CATCH
    PRINT 'Error occurred: ' + ERROR_MESSAGE();
END CATCH;

এখানে:

  • THROW স্টেটমেন্টটি ত্রুটি কোড 50000 এবং কাস্টম বার্তা 'Custom error message: Something went wrong!' তৈরি করে।
  • BEGIN TRY...END TRY ব্লকে যদি কোনো ত্রুটি ঘটে, তবে তা BEGIN CATCH...END CATCH ব্লকে ধরা হবে এবং ত্রুটির বার্তা প্রিন্ট হবে।

২. বিদ্যমান ত্রুটি পুনরায় ফেলা

আপনি যদি একটি CATCH ব্লকে কোনো ত্রুটি ধরা এবং পরে সেটি পুনরায় পুনরাবৃত্তি করতে চান, তাহলে THROW ব্যবহার করতে পারেন। এটি মূলত আগের ত্রুটির পুনঃব্যবহার করে এবং ত্রুটি বার্তাটি সেই অবস্থায় রেখে দেয়।

সিনট্যাক্স:

THROW;

এটি পূর্ববর্তী CATCH ব্লকে ধরা ত্রুটিকে পুনরায় ছুঁড়ে ফেলে।

উদাহরণ:

BEGIN TRY
    -- কিছু কোড যা ত্রুটি সৃষ্টি করবে
    DECLARE @x INT = 1 / 0; -- Division by zero error
END TRY
BEGIN CATCH
    PRINT 'Error: ' + ERROR_MESSAGE();
    THROW;  -- পুনরায় আগের ত্রুটি ছুঁড়ে ফেলা হবে
END CATCH;

এখানে:

  • THROW কোনো ত্রুটি কোড বা বার্তা ছাড়াই পূর্বের ত্রুটি পুনরায় ছুঁড়ে ফেলে। এতে ত্রুটির তথ্য (যেমন Error Number, Message, এবং State) কেবল আগের অবস্থায় ফেরত পাওয়া যাবে।

THROW এর সুবিধাসমূহ

  1. কাস্টম ত্রুটি বার্তা প্রদান: THROW ব্যবহার করে আপনি ব্যবহারকারীদের জন্য কাস্টম ত্রুটি বার্তা তৈরি করতে পারেন, যা সমস্যাটি স্পষ্টভাবে ব্যাখ্যা করে।
  2. ত্রুটি হ্যান্ডলিং: TRY...CATCH ব্লক ব্যবহার করে ত্রুটি হ্যান্ডলিং আরও কার্যকরী হয়। THROW ব্যবহার করে আপনি ধরা পড়া ত্রুটিকে পুনরায় ছুঁড়ে ফেলতে পারেন বা নতুন ত্রুটি তৈরি করতে পারেন।
  3. ত্রুটি প্রক্রিয়াকরণ এবং লগিং: ত্রুটি গুলি লোগ বা নির্দিষ্ট ডেটাবেস টেবিলেও সংরক্ষণ করা যেতে পারে এবং এভাবে আরও উন্নত ত্রুটি ট্র্যাকিং করা সম্ভব।

সারাংশ

THROW স্টেটমেন্ট T-SQL তে একটি গুরুত্বপূর্ণ কমান্ড যা ত্রুটি তৈরি এবং হ্যান্ডলিং প্রক্রিয়া সহজ করে। আপনি এটি ব্যবহার করতে পারেন:

  • নতুন ত্রুটি তৈরি: কাস্টম ত্রুটি বার্তা এবং কোড প্রদান করার জন্য।
  • বিদ্যমান ত্রুটি পুনরায় ফেলা: CATCH ব্লকে ধরা ত্রুটিকে পুনরায় ফেলার জন্য।

এটি আপনার ডেটাবেস অ্যাপ্লিকেশনে উন্নত ত্রুটি হ্যান্ডলিং এবং ডিবাগিং করতে সহায়ক।

Content added By

Exception Handling এর সেরা পদ্ধতি

295

T-SQL তে Exception Handling এমন একটি প্রক্রিয়া যা ত্রুটি বা সমস্যা সনাক্ত এবং প্রক্রিয়া করার জন্য ব্যবহৃত হয়। এটি ডেটাবেসের কার্যক্রম পরিচালনার সময় কোনো ত্রুটি বা সমস্যা ঘটলে সেগুলো ধরা এবং সেগুলোর উপর নির্দিষ্ট কর্ম চালানোর সুযোগ প্রদান করে। T-SQL তে TRY...CATCH ব্লক ব্যবহার করে Exception Handling করা হয়। এই পদ্ধতি ত্রুটির কারণে প্রোগ্রাম ক্র্যাশ হওয়ার ঝুঁকি কমায় এবং সঠিকভাবে পরিচালনা করতে সাহায্য করে।

এখানে Exception Handling এর সেরা পদ্ধতিগুলি আলোচনা করা হলো:


1. TRY...CATCH ব্লক ব্যবহার

TRY...CATCH স্টেটমেন্ট T-SQL তে ত্রুটি হ্যান্ডলিং করার জন্য ব্যবহৃত হয়। এই পদ্ধতিতে, আপনি প্রথমে TRY ব্লকে আপনার কোডটি লিখেন এবং যদি কোনো ত্রুটি ঘটে, তাহলে তা CATCH ব্লকে ধরা হয়।

TRY...CATCH সিনট্যাক্স:

BEGIN TRY
    -- কোড যা ত্রুটি ঘটতে পারে
    -- উদাহরণস্বরূপ, ডেটাবেসে ডেটা ইনসার্ট করা
    INSERT INTO Employees (EmployeeID, FirstName, LastName) 
    VALUES (1, 'John', 'Doe');
END TRY
BEGIN CATCH
    -- ত্রুটি হ্যান্ডলিং কোড
    PRINT 'Error occurred: ' + ERROR_MESSAGE();
END CATCH
  • BEGIN TRY: এখানে আপনি সেই কোডটি লিখবেন যা ত্রুটি ঘটাতে পারে।
  • BEGIN CATCH: যদি TRY ব্লকে কোনো ত্রুটি ঘটে, তাহলে CATCH ব্লক কার্যকর হবে এবং ত্রুটির তথ্য প্রিন্ট বা রেকর্ড করা যাবে।

2. ERROR_MESSAGE(), ERROR_NUMBER(), ERROR_SEVERITY() ব্যবহার

ERROR_MESSAGE(), ERROR_NUMBER(), ERROR_SEVERITY(), ERROR_STATE() ইত্যাদি ফাংশন ব্যবহার করে আপনি ত্রুটির বিস্তারিত তথ্য পেতে পারেন এবং সেগুলি রেকর্ড বা লগ করতে পারেন।

উদাহরণ:

BEGIN TRY
    -- এমন কিছু কোড লিখুন যা ত্রুটি ঘটাতে পারে
    SELECT 1 / 0;  -- Divide by zero error
END TRY
BEGIN CATCH
    -- ত্রুটি তথ্য বের করা
    PRINT 'Error Number: ' + CAST(ERROR_NUMBER() AS VARCHAR(10));
    PRINT 'Error Message: ' + ERROR_MESSAGE();
    PRINT 'Error Severity: ' + CAST(ERROR_SEVERITY() AS VARCHAR(10));
    PRINT 'Error State: ' + CAST(ERROR_STATE() AS VARCHAR(10));
END CATCH

এখানে:

  • ERROR_NUMBER(): ত্রুটির কোড দেয়।
  • ERROR_MESSAGE(): ত্রুটির বর্ণনা প্রদান করে।
  • ERROR_SEVERITY(): ত্রুটির গুরুত্ব স্তর প্রদান করে।
  • ERROR_STATE(): ত্রুটির অবস্থান (State) দেয়।

3. Transaction Handling with TRY...CATCH

Transaction ব্যবস্থাপনার সময় TRY...CATCH ব্যবহার করা অত্যন্ত গুরুত্বপূর্ণ। যখন আপনি কোনো ট্রানজ্যাকশন চালান এবং তা যদি সফল না হয়, তাহলে ROLLBACK ব্যবহার করে আপনার পরিবর্তনগুলো বাতিল করা যেতে পারে। এবং সফল হলে COMMIT করতে হবে।

উদাহরণ:

BEGIN TRY
    BEGIN TRANSACTION;
    
    -- প্রথম অপারেশন
    INSERT INTO Employees (EmployeeID, FirstName, LastName)
    VALUES (1, 'John', 'Doe');
    
    -- দ্বিতীয় অপারেশন
    INSERT INTO Employees (EmployeeID, FirstName, LastName)
    VALUES (2, 'Jane', 'Smith');
    
    -- যদি সবকিছু ঠিক থাকে, তাহলে ট্রানজ্যাকশন কমিট করুন
    COMMIT;
END TRY
BEGIN CATCH
    -- ত্রুটি হলে রোলব্যাক করুন
    ROLLBACK;
    
    -- ত্রুটির বার্তা প্রিন্ট করুন
    PRINT 'Error occurred: ' + ERROR_MESSAGE();
END CATCH

এখানে:

  • BEGIN TRANSACTION: ট্রানজ্যাকশন শুরু হয়।
  • COMMIT: সফল হলে সমস্ত পরিবর্তন সঞ্চয় করা হয়।
  • ROLLBACK: কোনো ত্রুটি ঘটলে সব পরিবর্তন বাতিল করা হয়।

4. Nested TRY...CATCH Blocks

Nested TRY...CATCH ব্যবহারের মাধ্যমে আপনি একাধিক স্তরের ত্রুটি হ্যান্ডলিং করতে পারেন। এটি তখন কার্যকরী হয় যখন একটি TRY...CATCH ব্লকের মধ্যে আরেকটি TRY...CATCH ব্লক থাকতে পারে।

উদাহরণ:

BEGIN TRY
    BEGIN TRY
        -- অভ্যন্তরীণ ত্রুটি
        SELECT 1 / 0;  -- Divide by zero error
    END TRY
    BEGIN CATCH
        PRINT 'Inner TRY-CATCH Error: ' + ERROR_MESSAGE();
    END CATCH
    
    -- বাহ্যিক ত্রুটি
    SELECT 'Outer TRY-CATCH Works';  -- No error here
END TRY
BEGIN CATCH
    PRINT 'Outer TRY-CATCH Error: ' + ERROR_MESSAGE();
END CATCH

এখানে:

  • বাহ্যিক এবং অভ্যন্তরীণ TRY...CATCH ব্লক ব্যবহার করা হয়েছে এবং দুটোর মধ্যে পৃথকভাবে ত্রুটির হ্যান্ডলিং করা হয়েছে।

5. T-SQL Error Logging

তথ্য লগ করার জন্য TRY...CATCH এর মধ্যে INSERT ব্যবহার করে ত্রুটি লগ করা যেতে পারে। এটি লগ টেবিলের মাধ্যমে ত্রুটির বিস্তারিত ডেটা সংরক্ষণ করার একটি ভালো পদ্ধতি।

উদাহরণ:

BEGIN TRY
    -- কোড যেখানে ত্রুটি ঘটতে পারে
    INSERT INTO Employees (EmployeeID, FirstName, LastName)
    VALUES (NULL, 'John', 'Doe');  -- Primary Key violation
END TRY
BEGIN CATCH
    -- ত্রুটি লগ করা
    INSERT INTO ErrorLog (ErrorNumber, ErrorMessage, ErrorDate)
    VALUES (ERROR_NUMBER(), ERROR_MESSAGE(), GETDATE());
    
    PRINT 'Error logged successfully';
END CATCH

এখানে:

  • ErrorLog টেবিলটি ত্রুটির তথ্য সংরক্ষণ করে, যেমন ত্রুটির কোড, বার্তা এবং সময়।

6. Best Practices for Exception Handling

  • ব্যাপক ত্রুটি হ্যান্ডলিং: আপনার কোডে সর্বদা TRY...CATCH ব্যবহার করুন, যাতে সব ধরনের ত্রুটি সঠিকভাবে ধরা যায়।
  • লগিং: ত্রুটি ঘটলে তথ্য লগ করা গুরুত্বপূর্ণ, যেন ভবিষ্যতে সমস্যা বিশ্লেষণ করা সহজ হয়।
  • Transaction Handling: টেবিল পরিবর্তন করার সময় COMMIT এবং ROLLBACK ব্যবহার করুন যাতে ডেটাবেস সঠিক অবস্থায় থাকে।
  • বাড়তি ত্রুটি মেসেজ: ত্রুটি মেসেজে যতটা সম্ভব বিশদ তথ্য দিন, যেমন ত্রুটির কোড, বার্তা এবং প্রাসঙ্গিক স্কোপের তথ্য।

সারাংশ

T-SQL তে Exception Handling নিশ্চিত করে যে, ডেটাবেসে কোনো ত্রুটি ঘটলে তা যথাযথভাবে প্রক্রিয়া করা যায়। TRY...CATCH ব্লক ব্যবহার করে আপনি ত্রুটি ধরা, তা পরিচালনা এবং প্রয়োজনে লগ করার ব্যবস্থা করতে পারেন। একাধিক স্তরের ত্রুটি হ্যান্ডলিং, ট্রানজ্যাকশন ব্যবস্থাপনা এবং ত্রুটি লগিং করার মাধ্যমে আপনি আপনার ডেটাবেসের কার্যকারিতা এবং স্থিতিশীলতা উন্নত করতে পারবেন।

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

Are you sure to start over?

Loading...