Hibernate Filter এর ধারণা এবং প্রয়োগ

Hibernate Filter এবং Global Query - হাইবারনেট (Hibernate) - Java Technologies

330

Hibernate Filter হল Hibernate ফ্রেমওয়ার্কের একটি শক্তিশালী বৈশিষ্ট্য যা query results বা fetching strategies-এ ফিল্টার অ্যাপ্লাই করার জন্য ব্যবহৃত হয়। এটি ডেটা রিট্রিভ করার সময় ডেটার ওপর শর্ত নির্ধারণ করে, যার মাধ্যমে আপনি query বা criteria অনুযায়ী নির্দিষ্ট ডেটা এক্সেস করতে পারেন।

Hibernate Filter ব্যবহার করলে, আপনি খুব সহজে ডেটাবেসের উপর যুক্ত শর্ত প্রয়োগ করতে পারবেন এবং সেই শর্ত অনুসারে select query বা entity fetching পরিচালনা করতে পারবেন। এটি ডেটাবেসের কর্মক্ষমতা উন্নত করতে সহায়ক হতে পারে, কারণ এটি নির্দিষ্ট রেকর্ডগুলির উপর ফিল্টার করে প্রয়োজনীয় ডেটা আনার অনুমতি দেয়।


Hibernate Filter এর সুবিধা

  1. Dynamic Querying: Hibernate Filter আপনাকে ডাইনামিকভাবে কুয়েরি তৈরি করতে দেয়, যা runtime-এ filtering conditions অ্যাড করতে সহায়ক।
  2. Flexible: কোনো SQL কুয়েরি না লেখেই জাভা কোডের মাধ্যমে ডেটা ফিল্টার করা যায়।
  3. Improved Performance: Filter ব্যবহার করে আপনি অপ্রয়োজনীয় ডেটা লোড করার পরিবর্তে শুধু প্রয়োজনীয় ডেটাই লোড করতে পারবেন, যা কর্মক্ষমতা উন্নত করতে সাহায্য করে।
  4. Reusability: Filter সহজেই পুনঃব্যবহারযোগ্য এবং একাধিক জায়গায় প্রয়োগ করা যেতে পারে।

Hibernate Filter এর ধাপসমূহ

  1. Define a Filter: প্রথমে Hibernate এর Filter কনফিগার করতে হবে। আপনি @Filter অ্যানোটেশন ব্যবহার করে এটি ডিফাইন করতে পারেন।
  2. Enable the Filter: Session.enableFilter() মেথড ব্যবহার করে Filter অ্যাকটিভেট করতে হয়।
  3. Apply the Filter: কুয়েরির সময় setParameter() মেথড দিয়ে Filter এর জন্য মান নির্ধারণ করা হয়।

Hibernate Filter এর উদাহরণ

ধরা যাক আমাদের দুটি ক্লাস Employee এবং Department রয়েছে। আমরা Employee ক্লাসের জন্য একটি Filter তৈরি করব, যার মাধ্যমে আমরা salary এর ওপর একটি শর্ত প্রয়োগ করব (যেমন, শুধু যে সকল কর্মচারীর salary > 50000 তাদের তথ্য আনব)।

Step 1: Hibernate Filter কনফিগারেশন

প্রথমে আমাদের Employee ক্লাসে Filter এবং FilterDef অ্যানোটেশন ব্যবহার করতে হবে।

Employee Class (Filter Definition)

import org.hibernate.annotations.Filter;
import org.hibernate.annotations.FilterDef;
import org.hibernate.annotations.ParamDef;
import javax.persistence.Entity;
import javax.persistence.Id;

@Entity
@FilterDef(name = "salaryFilter", parameters = @ParamDef(name = "minSalary", type = "double"))
@Filter(name = "salaryFilter", condition = "salary > :minSalary")
public class Employee {

    @Id
    private Long id;
    private String name;
    private double salary;

    // Getters and Setters
}

এখানে, @FilterDef দিয়ে একটি filter definition তৈরি করা হয়েছে, যার মাধ্যমে আমরা salary > :minSalary শর্ত ফিল্টার হিসেবে প্রয়োগ করব। @ParamDef দিয়ে minSalary নামক প্যারামিটার ডিফাইন করা হয়েছে।

Step 2: Filter Enable করা

Session.enableFilter() মেথড ব্যবহার করে Filter সক্রিয় করতে হবে।

Main Application (Enable and Apply Filter)

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.query.Query;
import java.util.List;

public class FilterExample {
    public static void main(String[] args) {
        // Step 1: Create SessionFactory
        SessionFactory factory = new Configuration().configure("hibernate.cfg.xml")
                .addAnnotatedClass(Employee.class)
                .buildSessionFactory();

        // Step 2: Create session
        Session session = factory.getCurrentSession();

        try {
            // Step 3: Start a transaction
            session.beginTransaction();

            // Step 4: Enable the filter
            session.enableFilter("salaryFilter").setParameter("minSalary", 50000);

            // Step 5: Execute the query with the filter applied
            Query<Employee> query = session.createQuery("from Employee", Employee.class);
            List<Employee> employees = query.getResultList();

            // Step 6: Display the results
            for (Employee employee : employees) {
                System.out.println(employee);
            }

            // Step 7: Commit the transaction
            session.getTransaction().commit();
        } finally {
            factory.close();
        }
    }
}

Explanation:

  1. session.enableFilter("salaryFilter"): এখানে salaryFilter নামের Filter সক্রিয় করা হয়েছে এবং setParameter("minSalary", 50000) দিয়ে তার মান সেট করা হয়েছে। এর ফলে কেবলমাত্র সেগুলি লোড হবে, যাদের স্যালারি ৫০,০০০ এর বেশি।
  2. Query Execution: পরবর্তীতে createQuery ব্যবহার করে Employee টেবিলের সমস্ত ডেটা লোড করা হচ্ছে, তবে ফিল্টারটি প্রয়োগ হবে।

Hibernate Filter এর সাথে Multiple Filters

একাধিক Filter ব্যবহার করা খুবই সহজ। যদি আপনার multiple filters প্রয়োজন হয়, তবে আপনি @Filters অ্যানোটেশন ব্যবহার করতে পারেন।

Example: Using Multiple Filters

Employee Class (Multiple Filters)

import org.hibernate.annotations.Filters;
import org.hibernate.annotations.Filter;
import org.hibernate.annotations.FilterDef;
import org.hibernate.annotations.ParamDef;

@Entity
@Filters({
    @Filter(name = "salaryFilter", condition = "salary > :minSalary"),
    @Filter(name = "departmentFilter", condition = "department_id = :departmentId")
})
public class Employee {
    @Id
    private Long id;
    private String name;
    private double salary;
    private Long departmentId;

    // Getters and Setters
}

এখানে, দুটি ফিল্টার—salaryFilter এবং departmentFilter একসাথে ব্যবহার করা হয়েছে।

Main Application with Multiple Filters

session.enableFilter("salaryFilter").setParameter("minSalary", 50000);
session.enableFilter("departmentFilter").setParameter("departmentId", 1);

এখানে, প্রথম Filter salaryFilter স্যালারি ৫০,০০০ এর বেশি থাকা কর্মচারীদের নির্বাচন করবে, এবং দ্বিতীয় Filter departmentFilter departmentId = 1 শর্ত অনুসারে কর্মচারীদের নির্বাচন করবে।


Hibernate Filter এর ব্যবহার ক্ষেত্র

  1. Dynamic Queries: যখন ডেটার মধ্যে বিভিন্ন শর্ত অনুযায়ী ডেটা ফিল্টার করার প্রয়োজন হয়, তখন Filter ব্যবহার করা যেতে পারে। উদাহরণস্বরূপ, রিপোর্টিং সিস্টেমে ফিল্টারিং প্রয়োগ করা যেতে পারে।
  2. Performance Optimization: Filter ব্যবহার করলে শুধুমাত্র প্রয়োজনীয় ডেটাই লোড হয়, ফলে অ্যাপ্লিকেশন পারফরম্যান্স উন্নত হয় এবং ডেটাবেস অপারেশন দ্রুত হয়।
  3. Conditional Fetching: Filter ব্যবহার করে ডেটা ফেচিংয়ের সময় শর্ত যোগ করা যায়, যা ডেটাবেস থেকে নির্দিষ্ট রেকর্ডগুলি দ্রুত এক্সেস করতে সাহায্য করে।

Hibernate Filter হল একটি শক্তিশালী বৈশিষ্ট্য যা ডেটা ফিল্টারিং এবং ডেটাবেস অপারেশনকে আরও কার্যকর এবং নমনীয় করে তোলে। Lazy এবং Eager লোডিং-এর মতো অন্য স্ট্র্যাটেজির পাশাপাশি Hibernate Filter ব্যবহার করলে আপনি ডেটার উপর আরও নির্দিষ্ট শর্ত প্রয়োগ করতে পারবেন। এটি ডাইনামিক কুয়েরি নির্মাণ, পারফরম্যান্স অপটিমাইজেশন এবং ডেটা ফেচিংয়ে সাহায্য করে, বিশেষত যখন আপনি ডেটাবেসের কিছু নির্দিষ্ট রেকর্ড অ্যাক্সেস করতে চান।

Content added By
Promotion

Are you sure to start over?

Loading...