Stored Procedures এবং Transactions

Database Programming with ADO.Net (এডিও.নেট এর মাধ্যমে ডেটাবেস প্রোগ্রামিং) - ভিজুয়াল বেসিক ডট নেট (VB.Net) - Computer Programming

209

Stored Procedures এবং Transactions

Stored Procedures এবং Transactions হল ডেটাবেস পরিচালনায় অত্যন্ত গুরুত্বপূর্ণ দুটি ধারণা। Stored Procedures হল পূর্বনির্ধারিত SQL কোডের ব্লক, যা ডেটাবেসে সংরক্ষিত থাকে এবং প্রোগ্রাম থেকে সহজেই কল করা যায়। Transactions হল একাধিক SQL স্টেটমেন্টের গ্রুপ, যা একসাথে কার্যকর করা হয়, এবং সবগুলো সফল না হলে কিছুই পরিবর্তিত হয় না। এই দুটি ধারণা ডেটাবেসের কার্যকারিতা, নিরাপত্তা, এবং পারফরম্যান্স উন্নত করতে সহায়তা করে।


১. Stored Procedures (স্টোরড প্রোসিজার)

Stored Procedure হল একটি SQL স্টেটমেন্ট বা SQL স্টেটমেন্টের ব্লক, যা ডেটাবেসে সংরক্ষিত থাকে এবং যখন প্রয়োজন হয় তখন এটি কল করা যায়। এগুলি সাধারণত কোড পুনঃব্যবহারযোগ্যতা, নিরাপত্তা এবং পারফরম্যান্স উন্নত করতে ব্যবহৃত হয়।

Stored Procedure এর সুবিধা:

  • কোড পুনঃব্যবহারযোগ্যতা: একবার স্টোরড প্রোসিজার লিখে ডেটাবেসে সংরক্ষণ করলে, একাধিক অ্যাপ্লিকেশন এবং কোড অংশ থেকে এটি ব্যবহার করা যায়।
  • নিরাপত্তা: SQL ইনজেকশন থেকে রক্ষা পেতে স্টোরড প্রোসিজার ব্যবহার করা হয়, কারণ এটি ব্যবহারকারী ইনপুট গ্রহণ না করে পূর্বনির্ধারিত কোড কার্যকর করে।
  • পারফরম্যান্স: একবার সংরক্ষিত স্টোরড প্রোসিজারগুলি ডেটাবেস সার্ভারে কার্যকরভাবে চলে, যার ফলে কোডের এক্সিকিউশন গতি বৃদ্ধি পায়।
  • ডেটাবেস লজিক কেন্দ্রীভূত করা: সমস্ত ব্যবসায়িক লজিক ডেটাবেসে রাখলে অ্যাপ্লিকেশন কোডে কমপ্লেক্সিটি কমে যায়।

Stored Procedure তৈরি এবং কল করা:

  1. Stored Procedure তৈরি করা:
CREATE PROCEDURE GetEmployeeDetails
    @EmployeeID INT
AS
BEGIN
    SELECT * FROM Employees WHERE EmployeeID = @EmployeeID
END

এখানে, GetEmployeeDetails একটি স্টোরড প্রোসিজার যা EmployeeID দিয়ে Employees টেবিল থেকে ডেটা নির্বাচন করে।

  1. Stored Procedure কল করা:
EXEC GetEmployeeDetails @EmployeeID = 1

এটি EmployeeID = 1 এর জন্য GetEmployeeDetails প্রোসিজার কল করবে এবং সংশ্লিষ্ট ডেটা ফেরত দিবে।

উদাহরণ: VB.Net থেকে Stored Procedure কল করা

Imports System.Data.SqlClient

Sub GetEmployeeInfo()
    Dim connectionString As String = "YourConnectionStringHere"
    Using conn As New SqlConnection(connectionString)
        conn.Open()

        Dim command As New SqlCommand("GetEmployeeDetails", conn)
        command.CommandType = CommandType.StoredProcedure
        command.Parameters.AddWithValue("@EmployeeID", 1)

        Using reader As SqlDataReader = command.ExecuteReader()
            While reader.Read()
                Console.WriteLine(reader("EmployeeName"))
            End While
        End Using
    End Using
End Sub

এখানে, GetEmployeeDetails স্টোরড প্রোসিজারটি VB.Net থেকে কল করা হয়েছে এবং এটি একটি SqlDataReader ব্যবহার করে ডেটা নিয়ে আসবে।


২. Transactions (ট্রানজেকশন)

Transaction হল একাধিক SQL স্টেটমেন্টের একটি গ্রুপ, যা একযোগে কার্যকর হয়। যদি কোনো একটি স্টেটমেন্ট ব্যর্থ হয়, তাহলে পুরো ট্রানজেকশনটি ব্যর্থ হয়ে যায় এবং আগের সব পরিবর্তন বাতিল হয়ে যায়। এটি ডেটাবেসের অ্যাটমিকিটি (Atomicity) নিশ্চিত করে, যা নিশ্চিত করে যে সমস্ত কাজ সফলভাবে সম্পন্ন না হলে কিছুই পরিবর্তিত হবে না।

Transactions এর মূল বৈশিষ্ট্য:

  • Atomicity: ট্রানজেকশনের সমস্ত স্টেটমেন্ট একসাথে কার্যকর হতে হবে, নতুবা কিছুই কার্যকর হবে না।
  • Consistency: ট্রানজেকশনের মাধ্যমে ডেটাবেসের অবস্থান সবসময় সঙ্গতিপূর্ণ (consistent) থাকবে।
  • Isolation: এক ট্রানজেকশন অন্য ট্রানজেকশনের কার্যক্রম থেকে বিচ্ছিন্ন থাকবে।
  • Durability: একবার ট্রানজেকশন সফল হলে, তার পরিবর্তনগুলি স্থায়ী হবে, এমনকি সিস্টেম ক্র্যাশ হলে।

Transaction শুরু, কমিট এবং রোলব্যাক:

  1. Transaction শুরু করা:
Dim conn As New SqlConnection("YourConnectionStringHere")
conn.Open()

Dim transaction As SqlTransaction = conn.BeginTransaction()

Try
    Dim command1 As New SqlCommand("UPDATE Employees SET Salary = 1000 WHERE EmployeeID = 1", conn, transaction)
    command1.ExecuteNonQuery()

    Dim command2 As New SqlCommand("UPDATE Employees SET Salary = 1500 WHERE EmployeeID = 2", conn, transaction)
    command2.ExecuteNonQuery()

    ' Transaction সফল হলে কমিট করা
    transaction.Commit()
    Console.WriteLine("Transaction completed successfully.")
Catch ex As Exception
    ' কোনো ত্রুটি হলে রোলব্যাক করা
    transaction.Rollback()
    Console.WriteLine("Transaction failed: " & ex.Message)
End Try
Finally
    conn.Close()
End Try

এখানে:

  • BeginTransaction(): ট্রানজেকশন শুরু হয়।
  • Commit(): সমস্ত স্টেটমেন্ট সফল হলে ট্রানজেকশনটি কমিট করা হয় এবং ডেটাবেসে পরিবর্তন স্থায়ী করা হয়।
  • Rollback(): যদি কোনো ত্রুটি ঘটে, তাহলে সমস্ত পরিবর্তন বাতিল করা হয় এবং পূর্ববর্তী অবস্থায় ফিরে আসা হয়।

Transaction এর সাথে Error Handling:

Dim transaction As SqlTransaction = conn.BeginTransaction()

Try
    ' কিছু SQL অপারেশন
    Dim command As New SqlCommand("UPDATE Table SET Column = 'Value' WHERE ID = 1", conn, transaction)
    command.ExecuteNonQuery()

    ' যদি কোনো ত্রুটি না ঘটে, তাহলে কমিট করা
    transaction.Commit()
Catch ex As Exception
    ' ত্রুটি ঘটলে রোলব্যাক করা
    transaction.Rollback()
    Console.WriteLine("Transaction failed: " & ex.Message)
Finally
    conn.Close()
End Try

এখানে, কোনো ত্রুটি ঘটলে সমস্ত পরিবর্তন রোলব্যাক হবে, এবং ডেটাবেসের পূর্ববর্তী অবস্থা পুনরুদ্ধার হবে।


সারাংশ

  1. Stored Procedures:
    • Stored Procedures হল পূর্বনির্ধারিত SQL কোডের ব্লক যা ডেটাবেসে সংরক্ষিত থাকে এবং পুনঃব্যবহারযোগ্য হয়।
    • এগুলি ডেটাবেস অপারেশনগুলিকে সুসংগঠিত, দ্রুত এবং নিরাপদ করে তোলে।
    • VB.Net বা অন্যান্য প্রোগ্রামিং ভাষা থেকে কল করা যায় এবং এটি কোড রিডেবিলিটি এবং পারফরম্যান্স উন্নত করে।
  2. Transactions:
    • Transactions হল একাধিক SQL স্টেটমেন্টের গ্রুপ যা একযোগে সম্পন্ন হয় এবং যদি কোনো একটি ব্যর্থ হয়, তবে সমস্ত পরিবর্তন বাতিল হয় (RollBack)।
    • এটি ডেটাবেসের অ্যাটমিকিটি, সঙ্গতিপূর্ণতা, বিচ্ছিন্নতা এবং স্থায়ীত্ব নিশ্চিত করে।
    • SQL Server, VB.Net, এবং অন্যান্য ডেটাবেস সিস্টেমে Transaction ব্যবহার করা হয় ডেটাবেসে নিরাপত্তা এবং অবিচ্ছিন্নতা নিশ্চিত করতে।

এই দুটি বৈশিষ্ট্য ডেটাবেসের কার্যকরীতা, নিরাপত্তা, এবং পারফরম্যান্স উন্নত করতে সহায়তা করে।

Content added By
Promotion

Are you sure to start over?

Loading...