ORM (Object-Relational Mapping) এবং iBATIS এর ভূমিকা

iBATIS এর পরিচিতি - আইবাটিস (iBATIS) - Java Technologies

390

iBATIS একটি data persistence framework যা Java অ্যাপ্লিকেশনে ডেটাবেসের সাথে যোগাযোগের জন্য ব্যবহৃত হয়। এটি Object-Relational Mapping (ORM) এর একটি বিকল্প, এবং এটি ডেটাবেসের সাথে সম্পর্কিত SQL queries এবং Java objects এর মধ্যে ম্যাপিং সরবরাহ করে।

ORM (Object-Relational Mapping) হল একটি প্রযুক্তি বা কৌশল যা object-oriented programming (OOP) ভাষায় তৈরি করা objects এবং relational databases এর মধ্যে সম্পর্ক স্থাপন এবং ডেটা ম্যানেজমেন্ট সহজ করে তোলে। ORM সিস্টেমগুলি ডেটাবেস টেবিল এবং ক্লাসগুলির মধ্যে সম্পর্ক স্থাপন করে এবং ডেটাবেস অপারেশন যেমন INSERT, UPDATE, DELETE ইত্যাদি কার্যাবলী পরিচালনা করে।


ORM (Object-Relational Mapping): ধারণা

ORM এর মাধ্যমে, আপনি object-oriented programming এ ব্যবহৃত Java objects বা classes এবং ডেটাবেস টেবিলের মধ্যে সম্পর্ক নির্ধারণ করতে পারেন। ORM সাধারণত entity mapping, query generation, transaction management, lazy loading, এবং caching এর মতো ফিচার সরবরাহ করে।

ORM এর মূল উদ্দেশ্য হল:

  • Java objects এবং database tables এর মধ্যে সম্পর্ক স্থাপন।
  • ডেটাবেস থেকে ডেটা রিটার্ন করার জন্য SQL লেখা এড়ানো।
  • ডেটাবেস অপারেশনগুলি কমপ্লেক্স হলে, সেগুলি স্বয়ংক্রিয়ভাবে পরিচালনা করা।

iBATIS এর ভূমিকা

iBATIS ORM প্রযুক্তির একটি বাস্তবায়ন হলেও, এটি full-fledged ORM এর মতো ডেটাবেস টেবিল এবং Java objects এর মধ্যে সম্পূর্ণ সম্পর্ক তৈরি করে না, বরং এটি SQL mapping framework হিসেবে কাজ করে, যেখানে আপনি SQL কোড লিখে Java objects এর সাথে সম্পর্ক স্থাপন করতে পারেন।

iBATIS, যেহেতু এটি SQL-based ORM ফ্রেমওয়ার্ক, SQL queries এবং Java objects এর মধ্যে সম্পর্ক XML configuration বা annotations ব্যবহার করে তৈরি করে।

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

  1. SQL Mapping:
    • iBATIS আপনাকে সরাসরি SQL কোড লিখতে দেয়। এটি SQL queries কে Java objects এর সাথে ম্যাপ করতে সাহায্য করে। এর ফলে, ডেটাবেস থেকে ডেটা রিটার্ন করার জন্য আপনাকে ORM-generated queries এর পরিবর্তে আপনার নিজস্ব SQL লিখতে হয়।
  2. XML-based Configuration:
    • iBATIS এ সব কনফিগারেশন XML files এর মাধ্যমে করা হয়, যেখানে SQL কোয়েরি এবং Java objects এর মধ্যে সম্পর্ক উল্লেখ করা হয়।
  3. Fine-grained Control:
    • iBATIS আপনাকে SQL কুয়েরি এবং ডেটাবেস অপারেশনগুলির উপর fine-grained control দেয়, কারণ আপনি নিজে SQL কোড লিখতে পারেন এবং সেগুলিকে parameterized queries হিসেবে ব্যবহার করতে পারেন।
  4. No Entity Manager:
    • iBATIS JPA বা Hibernate এর মতো entity manager ব্যবহার করে না, তাই এতে অনেকগুলি ডেটাবেস অপারেশন পরিচালনা করতে স্বয়ংক্রিয়ভাবে entity object লোড করার প্রক্রিয়া থাকে না।
  5. Simple and Flexible:
    • iBATIS সহজ এবং কাস্টম SQL কোড লেখা, ট্রানজেকশন ম্যানেজমেন্ট এবং সহজ ডেটাবেস অ্যাক্সেস সরবরাহ করে। এটি JDBC এর উপর ভিত্তি করে তৈরি এবং এটি সিস্টেমের উপর কম্প্লেক্সিটি কমায়।

iBATIS এবং Hibernate (ORM) এর মধ্যে পার্থক্য

FeatureiBATISHibernate (Full ORM)
Primary FocusSQL-based persistence frameworkFull ORM solution
SQL UsageRequires manual SQL queriesNo need to write SQL, automatic query generation
Entity MappingManual mapping of SQL queries to objectsAutomatic entity mapping to tables
ConfigurationXML configuration for SQL queriesAnnotations or XML configuration for entities
Level of AbstractionLow-level abstraction (SQL-centric)High-level abstraction (ORM-centric)
ComplexitySimple and lightweightMore complex with full object-relational mapping
FlexibilityGreater flexibility in writing custom SQLLess flexibility but more automation
Cache SupportNo built-in caching (though configurable)Built-in second-level cache

iBATIS Example

iBATIS এ, SQL কোয়েরি এবং Java objects এর মধ্যে সম্পর্ক XML configuration ফাইলে তৈরি করা হয়।

1. iBATIS Configuration File (SqlMapConfig.xml)

<sqlMapConfig>
    <settings useStatementNamespaces="true"/>
    
    <sqlMap resource="User.xml"/>
</sqlMapConfig>

2. SQL Mapping File (User.xml)

<sqlMap namespace="User">
    <!-- SQL for retrieving a user by ID -->
    <select id="getUserById" parameterClass="int" resultClass="User">
        SELECT id, name, email FROM users WHERE id = #id#
    </select>
</sqlMap>

3. Java Code (User.java)

public class User {
    private int id;
    private String name;
    private String email;

    // Constructors, getters, setters
}

4. Java Code for Query Execution (Main.java)

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

public class Main {
    public static void main(String[] args) {
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(Main.class.getResourceAsStream("/SqlMapConfig.xml"));
        try (SqlSession session = sqlSessionFactory.openSession()) {
            User user = session.selectOne("User.getUserById", 1);
            System.out.println(user.getName());
        }
    }
}

ব্যাখ্যা:

  • SqlMapConfig.xml: iBATIS কনফিগারেশন ফাইল, যেখানে SQL ম্যাপিং এবং সেটিংস কনফিগার করা হয়।
  • User.xml: SQL কুয়েরি এবং Java object User এর মধ্যে সম্পর্ক নির্ধারণ করা হয়।
  • User.java: একটি Java entity ক্লাস, যা ডেটাবেসের users টেবিলের সাথে সম্পর্কিত।

iBATIS vs JPA/Hibernate:

  • iBATIS হল একটি lightweight ফ্রেমওয়ার্ক যা SQL-centric এবং এটি আপনাকে SQL queries এবং Java objects এর মধ্যে সম্পর্ক ম্যাপ করতে সহায়তা করে। এর মাধ্যমে আপনি পুরোপুরি SQL কুয়েরি কাস্টমাইজ করতে পারেন।
  • JPA/Hibernate হল একটি full-fledged ORM solution, যেখানে SQL কোড লিখতে হয় না এবং এটি automatic query generation, entity mapping, এবং ডেটাবেস অপারেশনগুলি পরিচালনা করার জন্য আরও উন্নত object-relational mapping সরবরাহ করে।

  • iBATIS হল একটি SQL-centric data persistence ফ্রেমওয়ার্ক, যেখানে আপনি SQL queries লেখেন এবং সেগুলিকে Java objects এর সাথে সম্পর্কিত করেন। এটি JDBC এর উপর ভিত্তি করে কাজ করে এবং manual query mapping এর মাধ্যমে ডেটাবেস অপারেশন পরিচালনা করতে সহায়তা করে।
  • Hibernate (JPA) হল একটি full ORM solution, যেখানে ডেটাবেস টেবিলের সাথে Java entities স্বয়ংক্রিয়ভাবে সম্পর্কিত হয় এবং আপনাকে SQL queries লেখা বা নিয়ন্ত্রণ করার প্রয়োজন হয় না। Hibernate ডেটাবেস টেবিলের জন্য object-relational mapping সরবরাহ করে এবং ডেটাবেস অপারেশনগুলোকে স্বয়ংক্রিয়ভাবে সম্পাদন করে।

আপনার অ্যাপ্লিকেশনের প্রয়োজনের উপর ভিত্তি করে, আপনি iBATIS বা Hibernate/JPA এর মধ্যে যেকোনো একটি নির্বাচন করতে পারেন। iBATIS ব্যবহার করলে আপনি SQL কোডের উপর fine-grained control পাবেন, তবে Hibernate/JPA আপনাকে object-relational mapping এবং automatic query generation এর সুবিধা প্রদান করবে।

Content added By
Promotion

Are you sure to start over?

Loading...