Connection Interface কি এবং কিভাবে কাজ করে?

JDBC সংযোগ স্থাপন (Connection Establishment) - জেডিবিসি (JDBC) - Java Technologies

394

JDBC Connection Interface হল একটি গুরুত্বপূর্ণ উপাদান যা Java অ্যাপ্লিকেশন এবং ডেটাবেসের মধ্যে যোগাযোগ স্থাপন করে। এটি Java ডাটাবেস অ্যাক্সেসের মূল হাতিয়ার এবং ডেটাবেসে সংযোগ স্থাপন, SQL স্টেটমেন্ট এক্সিকিউট করা, এবং ডেটাবেসের সাথে ইন্টারঅ্যাকশন পরিচালনা করতে ব্যবহৃত হয়।

Connection Interface এর ভূমিকা

Connection Interface এর প্রধান উদ্দেশ্য হল ডেটাবেসের সাথে একটি সক্রিয় সংযোগ তৈরি করা, যাতে SQL কুয়েরি চালানো এবং ডেটাবেসের সাথে বিভিন্ন অপারেশন সম্পাদন করা সম্ভব হয়। এটি java.sql প্যাকেজের একটি অংশ এবং JDBC অ্যাপ্লিকেশনের সাথে ডেটাবেসের যোগাযোগের মূল মাধ্যম।

Connection Interface এর প্রধান ফাংশনালিটি:

  1. ডেটাবেসে সংযোগ তৈরি করা:
    • Connection অবজেক্ট ডেটাবেসের সাথে সংযোগ স্থাপন করতে ব্যবহৃত হয়। একটি সংযোগ তৈরির জন্য DriverManager.getConnection() অথবা DataSource.getConnection() ব্যবহার করা হয়।
  2. SQL কুয়েরি এক্সিকিউট করা:
    • একবার সংযোগ স্থাপন হলে, Statement, PreparedStatement, বা CallableStatement ব্যবহার করে SQL কুয়েরি এক্সিকিউট করা হয়।
  3. ট্রানজেকশন ম্যানেজমেন্ট:
    • Connection API ব্যবহার করে ডেটাবেস ট্রানজেকশন পরিচালনা করা হয়। যেমন commit() এবং rollback() মেথড ব্যবহার করে ডেটাবেস ট্রানজেকশন নিশ্চিত করা বা বাতিল করা হয়।
  4. সংযোগ বন্ধ করা:
    • ডেটাবেসের সাথে কাজ শেষ হলে, close() মেথড ব্যবহার করে সংযোগ বন্ধ করা হয়।

Connection Interface এর প্রধান মেথডগুলি

Connection ইন্টারফেসে অনেক গুরুত্বপূর্ণ মেথড রয়েছে, যেগুলি ডেটাবেসের সাথে সংযোগ স্থাপন এবং ম্যানিপুলেট করার জন্য ব্যবহৃত হয়। এখানে কিছু প্রধান মেথডের বর্ণনা দেওয়া হলো:

1. getConnection():

  • এই মেথডটি ডেটাবেসে সংযোগ স্থাপন করতে ব্যবহৃত হয়। এটি DriverManager বা DataSource এর মাধ্যমে ডেটাবেসের URL, ইউজারনেম, পাসওয়ার্ড এবং অন্যান্য কনফিগারেশন নিলেও সংযোগ তৈরি করতে পারে।
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "username", "password");

2. createStatement():

  • এটি একটি Statement অবজেক্ট তৈরি করে, যা SQL কুয়েরি এক্সিকিউট করতে ব্যবহৃত হয়। উদাহরণস্বরূপ, Statement ব্যবহার করে একটি SELECT কুয়েরি চালানো যায়।
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM employees");

3. prepareStatement():

  • এটি একটি PreparedStatement অবজেক্ট তৈরি করে, যা প্যারামিটারাইজড SQL কুয়েরি এক্সিকিউট করতে ব্যবহৃত হয়। এটি SQL ইনজেকশন প্রতিরোধ করতে সহায়ক।
PreparedStatement pstmt = con.prepareStatement("INSERT INTO employees (id, name) VALUES (?, ?)");
pstmt.setInt(1, 1);
pstmt.setString(2, "John");
pstmt.executeUpdate();

4. setAutoCommit():

  • ডিফল্টভাবে, JDBC সংযোগের প্রতিটি SQL স্টেটমেন্টকে একটি পৃথক ট্রানজেকশন হিসাবে বিবেচনা করা হয়। setAutoCommit(false) ব্যবহার করে ট্রানজেকশন ম্যানেজমেন্ট চালু করা যায় এবং একাধিক স্টেটমেন্ট একসাথে কমিট করা যায়।
con.setAutoCommit(false); // ট্রানজেকশন ম্যানেজমেন্ট বন্ধ

5. commit():

  • ট্রানজেকশন সম্পন্ন হলে commit() মেথড ব্যবহার করা হয়, যা পরিবর্তনগুলো ডেটাবেসে স্থায়ী করে।
con.commit();  // পরিবর্তনগুলি ডেটাবেসে স্থায়ী করা

6. rollback():

  • যদি কোনো ত্রুটি ঘটে, তবে rollback() মেথড ব্যবহার করে ট্রানজেকশন বাতিল করা যায় এবং পূর্বের অবস্থায় ফিরে যাওয়া যায়।
con.rollback();  // ট্রানজেকশন বাতিল করা

7. close():

  • সংযোগ বন্ধ করতে close() মেথড ব্যবহার করা হয়। এটি ডেটাবেস সংযোগের রিসোর্স মুক্ত করে।
con.close();  // সংযোগ বন্ধ করা

Connection Interface এর মাধ্যমে ডেটাবেসের সাথে কাজ করা

উদাহরণ: একটি SQL কুয়েরি চালানোর উদাহরণ

import java.sql.*;

public class JDBCExample {
    public static void main(String[] args) {
        // ১. Connection তৈরি করা
        try {
            Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "root", "password");
            
            // ২. Statement তৈরি করা
            Statement stmt = con.createStatement();
            
            // ৩. SQL কুয়েরি চালানো
            ResultSet rs = stmt.executeQuery("SELECT * FROM employees");
            
            // ৪. রেজাল্ট প্রদর্শন করা
            while (rs.next()) {
                System.out.println("ID: " + rs.getInt("id") + ", Name: " + rs.getString("name"));
            }
            
            // ৫. সংযোগ বন্ধ করা
            con.close();
            
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

ব্যাখ্যা:

  1. Connection অবজেক্ট তৈরি করা হয়েছে DriverManager.getConnection() মেথড দিয়ে। এখানে ডেটাবেসের URL, ইউজারনেম, এবং পাসওয়ার্ড প্রদান করা হয়েছে।
  2. একটি Statement তৈরি করা হয়েছে, যা SQL কুয়েরি চালানোর জন্য ব্যবহৃত হয়।
  3. ResultSet এর মাধ্যমে কুয়েরি থেকে প্রাপ্ত রেকর্ডগুলো প্রদর্শন করা হয়েছে।
  4. অবশেষে, সংযোগ বন্ধ করা হয়েছে।

Conclusion

Connection Interface হল JDBC এর একটি গুরুত্বপূর্ণ উপাদান, যা Java অ্যাপ্লিকেশন এবং ডেটাবেসের মধ্যে সংযোগ স্থাপন এবং ডেটাবেসে SQL স্টেটমেন্ট এক্সিকিউট করার জন্য ব্যবহৃত হয়। এটি ট্রানজেকশন ম্যানেজমেন্ট, স্টেটমেন্ট এক্সিকিউশন, এবং ডেটাবেসের সাথে সংযোগ স্থাপন করার জন্য বিভিন্ন মেথড সরবরাহ করে। JDBC-তে Connection Interface ব্যবহারের মাধ্যমে ডেটাবেসের সঙ্গে কার্যকরী যোগাযোগ এবং ডেটা ম্যানিপুলেশন করা সম্ভব হয়।

Content added By
Promotion

Are you sure to start over?

Loading...