JDBC কি এবং কেন এটি ব্যবহার করা হয়?

Java Database Connectivity (JDBC) - জাভা ইন্টারভিউ প্রশ্ন (Java Interview Questions) - Java Technologies

481

JDBC (Java Database Connectivity) হল একটি Java API যা Java প্রোগ্রামগুলিকে ডেটাবেসের সাথে সংযুক্ত এবং যোগাযোগ করতে সক্ষম করে। JDBC ডেটাবেস অ্যাপ্লিকেশনগুলির মধ্যে ডেটা পাঠানো, গ্রহণ করা এবং পরিচালনা করার জন্য স্ট্যান্ডার্ড ইন্টারফেস প্রদান করে। এটি Java অ্যাপ্লিকেশন এবং বিভিন্ন ডেটাবেস যেমন MySQL, Oracle, SQL Server, PostgreSQL ইত্যাদির মধ্যে ব্রিজ হিসেবে কাজ করে।

JDBC ব্যবহার করে Java অ্যাপ্লিকেশনগুলিকে ডেটাবেসে সংযোগ স্থাপন, কুয়েরি পরিচালনা, ডেটা আপডেট, ইনসার্ট বা ডিলিট করার জন্য বিভিন্ন কার্যক্রম সম্পাদন করতে পারে।

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

  1. Database Connection: JDBC API ডেটাবেসের সাথে সংযোগ স্থাপনের জন্য একটি স্ট্যান্ডার্ড ইন্টারফেস প্রদান করে। এটি বিভিন্ন ডেটাবেসে সংযোগ স্থাপন করতে ব্যবহৃত হয়।
  2. SQL Query Execution: JDBC ব্যবহার করে SQL কুয়েরি রান করা যায়, যেমন SELECT, INSERT, UPDATE, DELETE ইত্যাদি।
  3. Result Set Management: ডেটাবেস থেকে ফলাফল রিটার্ন হওয়ার পরে, ResultSet অবজেক্ট ব্যবহার করে ডেটা অ্যাক্সেস করা যায়।
  4. Transaction Management: JDBC ট্রানজেকশন পরিচালনা করার জন্য ডেটাবেসের সাথে কাজ করতে সক্ষম। এটি commit এবং rollback ফিচার প্রদান করে।
  5. Cross-Database Compatibility: JDBC ড্রাইভার বিভিন্ন ডেটাবেসের জন্য প্রস্তুত থাকে, যা একই Java কোড দিয়ে বিভিন্ন ডেটাবেসের সাথে কাজ করার সুবিধা দেয়।

JDBC এর প্রধান উপাদান:

  1. DriverManager:
    JDBC ড্রাইভার লোড এবং ডেটাবেসের সাথে সংযোগ স্থাপন করার জন্য DriverManager ক্লাস ব্যবহৃত হয়। এটি ড্রাইভার নির্বাচন করতে এবং ডাটাবেসে সংযোগ স্থাপন করতে সহায়তা করে।
  2. Connection:
    Connection অবজেক্ট ডেটাবেসের সাথে সংযোগ স্থাপন করতে ব্যবহৃত হয়। এটি কনফিগারেশন এবং ট্রানজেকশন পরিচালনা করে।
  3. Statement:
    Statement অবজেক্ট ডেটাবেসে SQL কুয়েরি পাঠানোর জন্য ব্যবহৃত হয়। এটি executeQuery() বা executeUpdate() পদ্ধতি ব্যবহার করে কুয়েরি চালায়।
  4. PreparedStatement:
    PreparedStatement SQL কুয়েরি প্রস্তুত করার জন্য ব্যবহৃত হয় যা পুনরায় ব্যবহারযোগ্য এবং এটি SQL ইনজেকশন প্রতিরোধ করে।
  5. ResultSet:
    ResultSet অবজেক্ট SQL কুয়েরি থেকে রিটার্ন হওয়া ডেটা ধারণ করে এবং ডেটাবেস থেকে ফলাফল অ্যাক্সেস করতে ব্যবহৃত হয়।
  6. SQLException:
    SQLException হল একটি এক্সসেপশন ক্লাস যা ডেটাবেস সংক্রান্ত সমস্যা, যেমন কুয়েরি এক্সিকিউশন, সংযোগ সমস্যা ইত্যাদি হ্যান্ডল করার জন্য ব্যবহৃত হয়।

JDBC ব্যবহার করার কারণ:

  1. Database Interaction:
    JDBC Java প্রোগ্রামগুলিকে ডেটাবেসের সাথে যোগাযোগ করতে সক্ষম করে, যেহেতু Java-তে সাধারণত ডেটাবেসের সাথে কাজ করার জন্য কোনও বিল্ট-ইন ফিচার নেই। JDBC একটি স্ট্যান্ডার্ড API প্রদান করে যার মাধ্যমে ডেটাবেস থেকে ডেটা অ্যাক্সেস করা যায়।
  2. Cross-Platform:
    JDBC একটি প্ল্যাটফর্ম-নিরপেক্ষ API যা Java অ্যাপ্লিকেশনকে বিভিন্ন ডেটাবেসের সাথে কাজ করার সুযোগ প্রদান করে, যেমন MySQL, Oracle, SQL Server, PostgreSQL ইত্যাদি।
  3. Standardized API:
    JDBC একটি স্ট্যান্ডার্ড API যা Java ডেভেলপারদের বিভিন্ন ডেটাবেসের সাথে একীভূতভাবে কাজ করার জন্য সাধারণ ইন্টারফেস প্রদান করে। এর মাধ্যমে ডেটাবেসের ধরণ পরিবর্তন করলেও, কোডে পরিবর্তন করার প্রয়োজন হয় না।
  4. Transaction Management:
    JDBC API এর মাধ্যমে ডেটাবেসে টানজেকশন (transaction) পরিচালনা করা যায়। ট্রানজেকশন একটি একক ইউনিট হিসেবে একাধিক SQL স্টেটমেন্ট গঠন করতে পারে, যেমন commit, rollback
  5. Simple and Flexible:
    JDBC API ব্যবহার করা সহজ এবং এটি Java ডেভেলপারদের জন্য একটি শক্তিশালী টুল সরবরাহ করে, যাতে তারা ডেটাবেসে ডেটা পাঠাতে এবং গ্রহণ করতে পারে। এটি SQL কুয়েরির মাধ্যমে ডেটাবেসে সম্পূর্ণ নিয়ন্ত্রণ প্রদান করে।
  6. Support for PreparedStatement:
    JDBC PreparedStatement সমর্থন করে যা SQL ইনজেকশন আক্রমণ রোধ করতে সহায়ক এবং কুয়েরি ইজেকিউশনের জন্য আরও বেশি কার্যকর।

JDBC এর উদাহরণ:

1. JDBC Connection Setup Example:

import java.sql.*;

public class JDBCExample {
    public static void main(String[] args) {
        try {
            // Load the JDBC driver
            Class.forName("com.mysql.cj.jdbc.Driver");

            // Establish the connection
            Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydatabase", "root", "password");

            // Create a Statement object
            Statement stmt = con.createStatement();

            // Execute SQL query
            ResultSet rs = stmt.executeQuery("SELECT * FROM students");

            // Process the ResultSet
            while (rs.next()) {
                System.out.println("ID: " + rs.getInt(1) + ", Name: " + rs.getString(2));
            }

            // Close the connection
            con.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

2. JDBC PreparedStatement Example:

import java.sql.*;

public class JDBCPreparedStatementExample {
    public static void main(String[] args) {
        try {
            // Load the JDBC driver
            Class.forName("com.mysql.cj.jdbc.Driver");

            // Establish the connection
            Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydatabase", "root", "password");

            // Create PreparedStatement object
            String query = "INSERT INTO students (id, name) VALUES (?, ?)";
            PreparedStatement pstmt = con.prepareStatement(query);
            
            // Set parameters
            pstmt.setInt(1, 1);
            pstmt.setString(2, "John Doe");
            
            // Execute update
            int rowsAffected = pstmt.executeUpdate();
            System.out.println("Rows affected: " + rowsAffected);

            // Close the connection
            con.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

JDBC এর মূল উপাদানসমূহ:

  1. DriverManager: ড্রাইভার লোড এবং ডেটাবেসের সাথে সংযোগ তৈরি করতে ব্যবহৃত হয়।
  2. Connection: ডেটাবেসের সাথে সংযোগ স্থাপন এবং পরিচালনা করা হয়।
  3. Statement/PreparedStatement: SQL কুয়েরি রান করার জন্য ব্যবহৃত হয়।
  4. ResultSet: SQL কুয়েরি থেকে পাওয়া ফলাফলগুলি ধরে রাখে এবং তা প্রসেস করতে ব্যবহৃত হয়।
  5. SQLException: ডেটাবেস সংক্রান্ত ত্রুটিগুলিকে হ্যান্ডেল করার জন্য ব্যবহৃত হয়।

JDBC (Java Database Connectivity) হল একটি শক্তিশালী API যা Java প্রোগ্রামকে ডেটাবেসের সাথে সংযোগ স্থাপন, SQL কুয়েরি ইজেকিউট করা এবং ডেটা ম্যানিপুলেট করার জন্য ব্যবহৃত হয়। এটি ডেটাবেস-নির্ভর অ্যাপ্লিকেশন তৈরি করতে সাহায্য করে এবং cross-platform compatibility প্রদান করে। JDBC ব্যবহার করার মাধ্যমে আপনি Java অ্যাপ্লিকেশন থেকে ডেটাবেসে ডেটা পাঠানো, গ্রহণ করা, আপডেট করা, এবং ডিলিট করার কাজ করতে পারেন।

Content added By
Promotion

Are you sure to start over?

Loading...