Spring Boot এর সাথে Hibernate ব্যবহার

Hibernate এবং Spring Integration - হাইবারনেট (Hibernate) - Java Technologies

386

Spring Boot এবং Hibernate একসাথে ব্যবহার করলে আপনি খুব সহজেই ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারেন, কারণ Spring Boot Hibernate কনফিগারেশন এবং সেটআপকে অনেক সহজ করে দেয়। Hibernate Spring Boot-এর মধ্যে ব্যবহৃত JPA (Java Persistence API) ইমপ্লিমেন্টেশন হিসেবে কাজ করে, যা আপনাকে ডেটাবেসের সাথে অবজেক্ট ম্যাপিং এবং CRUD (Create, Read, Update, Delete) অপারেশন সহজে করতে সাহায্য করে।

এখানে Spring Boot এর সাথে Hibernate ব্যবহারের একটি বাস্তব উদাহরণ দেয়া হলো।


Step 1: Add Dependencies to pom.xml

Spring Boot এবং Hibernate ব্যবহার করতে হলে আপনাকে Spring Data JPA এবং Hibernate এর জন্য প্রয়োজনীয় ডিপেনডেন্সি pom.xml ফাইলে যোগ করতে হবে।

<dependencies>
    <!-- Spring Boot Starter Web for REST API and basic web functionalities -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- Spring Boot Starter Data JPA for Hibernate integration with Spring Boot -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>

    <!-- MySQL Driver for connecting to MySQL Database -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>

    <!-- Spring Boot Starter Test for unit testing -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

Step 2: Configure application.properties

Spring Boot কনফিগারেশন ফাইল application.properties ব্যবহার করে ডেটাবেস সংযোগ এবং Hibernate কনফিগারেশন সেট করা হয়। নিচে একটি উদাহরণ দেয়া হলো যা MySQL ডেটাবেসে সংযোগ স্থাপন করে।

# Spring DataSource Configuration (MySQL example)
spring.datasource.url=jdbc:mysql://localhost:3306/yourdb
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# Hibernate Dialect for MySQL
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL8Dialect

# Hibernate Automatic DDL (Data Definition Language) creation
spring.jpa.hibernate.ddl-auto=update

# Show Hibernate SQL Queries
spring.jpa.show-sql=true
spring.jpa.properties.hibernate.format_sql=true

# Enable second-level caching (optional)
spring.cache.type=simple
  • spring.jpa.hibernate.ddl-auto=update: এই সেটিংটি Hibernate কে ডেটাবেস টেবিল আপডেট করতে বলে (এটি ডেভেলপমেন্ট পরিবেশে ব্যবহার করা হয়)। প্রোডাকশনে validate বা none ব্যবহার করা হয়।
  • spring.datasource.url: এখানে ডেটাবেসের URL উল্লেখ করতে হবে।
  • spring.jpa.show-sql=true: Hibernate দ্বারা চলা SQL কোয়েরি কনসোলে দেখতে সহায়তা করে।

Step 3: Create Entity Class

Hibernate ব্যবহার করতে হলে, আপনাকে ডেটাবেস টেবিলের সাথে সম্পর্কিত একটি Entity ক্লাস তৈরি করতে হবে। এখানে আমরা একটি Employee ক্লাস তৈরি করব, যা ডেটাবেস টেবিলের সাথে ম্যাপ হবে।

import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;

@Entity
public class Employee {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;

    // Constructors
    public Employee() {}

    public Employee(String name, String email) {
        this.name = name;
        this.email = email;
    }

    // Getters and Setters
    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}
  • @Entity: এই অ্যানোটেশনটি Hibernate কে জানিয়ে দেয় যে এটি একটি Entity ক্লাস এবং এটি ডেটাবেস টেবিলের সাথে ম্যাপ হবে।
  • @Id: এটি Primary Key ফিল্ড নির্ধারণ করে।
  • @GeneratedValue(strategy = GenerationType.IDENTITY): এটি Hibernate কে বলে যে id ফিল্ডটি স্বয়ংক্রিয়ভাবে বৃদ্ধি পাবে।

Step 4: Create Repository Interface

Spring Data JPA-তে, ডেটাবেস অপারেশন পরিচালনার জন্য আপনাকে একটি repository interface তৈরি করতে হবে যা Hibernate (JPA) এর সাথে ডেটাবেস কনফিগারেশন সংযোগ করবে।

import org.springframework.data.jpa.repository.JpaRepository;

public interface EmployeeRepository extends JpaRepository<Employee, Long> {
    // No need to write the implementation; Spring Data JPA will automatically implement it.
}
  • JpaRepository: এটি একটি Spring Data JPA ইন্টারফেস যা Hibernate দিয়ে ডেটাবেসে CRUD অপারেশন (Create, Read, Update, Delete) করার জন্য প্রয়োজনীয় সব মেথড সরবরাহ করে।

Step 5: Create Service Layer

এখন একটি Service ক্লাস তৈরি করুন, যেখানে আপনি EmployeeRepository এর মাধ্যমে ডেটাবেস অপারেশন করবেন।

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

@Service
public class EmployeeService {

    @Autowired
    private EmployeeRepository employeeRepository;

    // Save a new employee
    public void saveEmployee(Employee employee) {
        employeeRepository.save(employee);
    }

    // Get all employees
    public List<Employee> getAllEmployees() {
        return employeeRepository.findAll();
    }

    // Get employee by id
    public Employee getEmployeeById(Long id) {
        return employeeRepository.findById(id).orElse(null);
    }

    // Delete employee by id
    public void deleteEmployee(Long id) {
        employeeRepository.deleteById(id);
    }
}
  • @Autowired: Spring আপনাকে EmployeeRepository এর একটি instance Inject করে দিবে।
  • saveEmployee, getAllEmployees, getEmployeeById, এবং deleteEmployee মেথডগুলো ব্যবহার করে আপনি Employee টেবিলের উপর CRUD অপারেশন করতে পারবেন।

Step 6: Create Controller

Spring Boot অ্যাপ্লিকেশনকে HTTP রিকোয়েস্ট ম্যানেজ করার জন্য একটি Controller ক্লাস তৈরি করুন। এখানে আমরা EmployeeController তৈরি করব, যা RESTful API এর মাধ্যমে ডেটাবেস অপারেশন পরিচালনা করবে।

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/api/employees")
public class EmployeeController {

    @Autowired
    private EmployeeService employeeService;

    @PostMapping
    public void addEmployee(@RequestBody Employee employee) {
        employeeService.saveEmployee(employee);
    }

    @GetMapping
    public List<Employee> getAllEmployees() {
        return employeeService.getAllEmployees();
    }

    @GetMapping("/{id}")
    public Employee getEmployeeById(@PathVariable Long id) {
        return employeeService.getEmployeeById(id);
    }

    @DeleteMapping("/{id}")
    public void deleteEmployee(@PathVariable Long id) {
        employeeService.deleteEmployee(id);
    }
}
  • @RestController: এটি Spring Boot কে জানায় যে এটি একটি REST API কন্ট্রোলার।
  • @RequestMapping("/api/employees"): এই অ্যানোটেশনটি ডিফাইন করে যে সব রিকোয়েস্ট "/api/employees" URL পাথ দিয়ে আসবে।
  • @PostMapping, @GetMapping, @DeleteMapping: HTTP POST, GET, DELETE মেথডের সাথে সম্পর্কিত রিকোয়েস্ট হ্যান্ডলিং করা হয়।

Step 7: Run the Application

Spring Boot Application চালু করার জন্য @SpringBootApplication অ্যানোটেশন যুক্ত একটি ক্লাস তৈরি করুন এবং অ্যাপ্লিকেশন রান করুন।

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class EmployeeApplication {

    public static void main(String[] args) {
        SpringApplication.run(EmployeeApplication.class, args);
    }
}

এই উদাহরণের মাধ্যমে আমরা দেখলাম কিভাবে Spring Boot এবং Hibernate (JPA) একসাথে ব্যবহার করা যায়। এই প্রক্রিয়ায়:

  1. Hibernate Entity তৈরি করা হয়েছে এবং Spring Boot এর @Entity অ্যানোটেশন ব্যবহৃত হয়েছে।
  2. Spring Data JPA Repository ব্যবহৃত হয়েছে ডেটাবেস অপারেশন সম্পাদনের জন্য।
  3. Service এবং Controller লেয়ারে CRUD অপারেশন সমর্থিত API তৈরি করা হয়েছে।

এই পদ্ধতিতে Spring Boot এবং Hibernate ব্যবহার করে দ্রুত এবং কার্যকরীভাবে ডেটাবেস অপারেশন করা সম্ভব।

Content added By
Promotion

Are you sure to start over?

Loading...