Table, Column, এবং Primary Key Metadata রিট্রাইভ করা

JDBC এর সাথে Metadata - জেডিবিসি (JDBC) - Java Technologies

246

JDBC (Java Database Connectivity) আপনাকে ডেটাবেসের সাথে যোগাযোগ করতে এবং বিভিন্ন তথ্য রিট্রাইভ করার সুবিধা প্রদান করে। Metadata হল ডেটাবেস সম্পর্কিত তথ্য যা ডেটাবেসের কাঠামো (structure), টেবিল, কলাম, প্রাইমারি কী, এবং অন্যান্য বৈশিষ্ট্য সম্পর্কে জানায়। JDBC API ব্যবহার করে আপনি ডেটাবেসের মেটাডেটা রিট্রাইভ করতে পারেন, যা ডেটাবেস ডিজাইন সম্পর্কে মূল্যবান তথ্য সরবরাহ করে।

JDBC Metadata রিট্রাইভ করতে তিনটি প্রধান উপাদান ব্যবহার করা হয়:

  1. DatabaseMetaData: ডেটাবেসের সম্পর্কিত তথ্য রিট্রাইভ করতে ব্যবহৃত।
  2. ResultSetMetaData: SQL কুয়েরির ফলাফল সম্পর্কিত তথ্য রিট্রাইভ করতে ব্যবহৃত।
  3. DatabaseTables, Columns, Primary Keys: টেবিল, কলাম এবং প্রাইমারি কী সম্পর্কিত মেটাডেটা রিট্রাইভ করতে ব্যবহৃত।

1. DatabaseMetaData Interface

DatabaseMetaData ইন্টারফেসটি ডেটাবেস সম্পর্কে বিভিন্ন ধরণের তথ্য সরবরাহ করে, যেমন:

  • টেবিলের নাম, কলামের নাম
  • প্রাইমারি কী, ফরেন কী সম্পর্ক
  • ডেটাবেসের বৈশিষ্ট্য
  • ডেটাবেসের টাইপ

DatabaseMetaData ব্যবহার করে Table, Column, এবং Primary Key মেটাডেটা রিট্রাইভ করার উদাহরণ:

1.1 Database Connection Setup

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
import java.sql.SQLException;

public class JdbcMetadataExample {
    public static void main(String[] args) {
        Connection conn = null;
        try {
            // ডেটাবেস সংযোগ স্থাপন
            conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "username", "password");

            // DatabaseMetaData ব্যবহার
            DatabaseMetaData metaData = conn.getMetaData();

            // টেবিলের তথ্য রিট্রাইভ করা
            retrieveTables(metaData);

            // কলাম তথ্য রিট্রাইভ করা
            retrieveColumns(metaData);

            // প্রাইমারি কী তথ্য রিট্রাইভ করা
            retrievePrimaryKeys(metaData);

        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            try {
                if (conn != null) conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    // টেবিলের তথ্য রিট্রাইভ করার জন্য ফাংশন
    public static void retrieveTables(DatabaseMetaData metaData) throws SQLException {
        ResultSet rs = metaData.getTables(null, null, "%", new String[]{"TABLE"});
        while (rs.next()) {
            String tableName = rs.getString("TABLE_NAME");
            System.out.println("Table: " + tableName);
        }
    }

    // কলামের তথ্য রিট্রাইভ করার জন্য ফাংশন
    public static void retrieveColumns(DatabaseMetaData metaData) throws SQLException {
        ResultSet rs = metaData.getColumns(null, null, "employees", "%");
        while (rs.next()) {
            String columnName = rs.getString("COLUMN_NAME");
            System.out.println("Column: " + columnName);
        }
    }

    // প্রাইমারি কী তথ্য রিট্রাইভ করার জন্য ফাংশন
    public static void retrievePrimaryKeys(DatabaseMetaData metaData) throws SQLException {
        ResultSet rs = metaData.getPrimaryKeys(null, null, "employees");
        while (rs.next()) {
            String pkName = rs.getString("COLUMN_NAME");
            System.out.println("Primary Key Column: " + pkName);
        }
    }
}

Explanation of the Code:

  1. Database Connection:
    • প্রথমে DriverManager.getConnection() মেথড ব্যবহার করে ডেটাবেসে সংযোগ স্থাপন করা হয়।
  2. DatabaseMetaData:
    • conn.getMetaData() মেথড ব্যবহার করে DatabaseMetaData অবজেক্ট প্রাপ্ত করা হয়।
  3. getTables():
    • এটি ডেটাবেসের সমস্ত টেবিলের নাম রিট্রাইভ করে। এখানে "%" দেওয়া হয়েছে যা সমস্ত টেবিলের নাম পেতে সাহায্য করে।
  4. getColumns():
    • এটি একটি নির্দিষ্ট টেবিলের কলামসমূহের নাম এবং অন্যান্য তথ্য রিট্রাইভ করে। উদাহরণস্বরূপ, employees টেবিলের কলামসমূহ।
  5. getPrimaryKeys():
    • এটি একটি নির্দিষ্ট টেবিলের প্রাইমারি কী কলামের নাম রিট্রাইভ করে।

2. getColumns() Method

getColumns() মেথডটি টেবিলের কলামগুলোর তথ্য রিট্রাইভ করতে ব্যবহৃত হয়। এটি কলামের নাম, ডেটাটাইপ, কলামের আকার, এবং অন্যান্য বৈশিষ্ট্য প্রদান করে।

উদাহরণ:

ResultSet rs = metaData.getColumns(null, null, "employees", "%");
while (rs.next()) {
    String columnName = rs.getString("COLUMN_NAME");
    String columnType = rs.getString("TYPE_NAME");
    System.out.println("Column: " + columnName + ", Type: " + columnType);
}

এখানে, "employees" টেবিলের সব কলামের নাম এবং তাদের ডেটাটাইপ রিট্রাইভ করা হবে।


3. getPrimaryKeys() Method

getPrimaryKeys() মেথডটি একটি নির্দিষ্ট টেবিলের প্রাইমারি কী কলামের নাম রিট্রাইভ করতে ব্যবহৃত হয়। এটি একটি টেবিলের প্রাইমারি কী সম্পর্কে তথ্য প্রদান করে।

উদাহরণ:

ResultSet rs = metaData.getPrimaryKeys(null, null, "employees");
while (rs.next()) {
    String pkColumn = rs.getString("COLUMN_NAME");
    System.out.println("Primary Key Column: " + pkColumn);
}

এখানে, "employees" টেবিলের প্রাইমারি কী কলামের নাম রিট্রাইভ করা হচ্ছে।


Conclusion

JDBC এর মাধ্যমে DatabaseMetaData ব্যবহার করে আপনি ডেটাবেসের কাঠামো, টেবিলের কলাম, এবং প্রাইমারি কী সম্পর্কিত মেটাডেটা সহজেই রিট্রাইভ করতে পারেন। getTables(), getColumns(), এবং getPrimaryKeys() মেথডগুলি ব্যবহার করে আপনি টেবিল, কলাম এবং প্রাইমারি কী সম্পর্কে তথ্য পাবেন যা ডেটাবেসের কাঠামো বিশ্লেষণ করতে সহায়তা করে। JDBC মেটাডেটা রিট্রাইভ করার মাধ্যমে আপনি ডেটাবেসের ভেতরের স্ট্রাকচার সম্পর্কে বিস্তারিত জানার সুযোগ পেয়ে থাকেন।

Content added By
Promotion

Are you sure to start over?

Loading...