উদাহরণ সহ Exception Handling

Spring JDBC এবং Exception Handling - স্প্রিং জেডিবিসি (Spring JDBC) - Java Technologies

248

Spring JDBC তে Exception Handling গুরুত্বপূর্ণ, কারণ ডেটাবেস অপারেশন চলাকালে যেকোনো ধরনের ব্যতিক্রম (Exception) ঘটতে পারে যেমন SQLException, DataAccessException ইত্যাদি। Spring JDBC এই ব্যতিক্রমগুলি সহজে পরিচালনা করার জন্য একটি DataAccessException শ্রেণী প্রদান করে, যা RuntimeException এর একটি সাবক্লাস। এটি ডেটাবেস সংক্রান্ত ব্যতিক্রমগুলি আরও সরল এবং পরিষ্কারভাবে পরিচালনা করতে সাহায্য করে।

Exception Handling in Spring JDBC

Spring JDBC ব্যতিক্রম ব্যবস্থাপনা (Exception Handling) এমনভাবে ডিজাইন করা হয়েছে যাতে ডেভেলপাররা ডেটাবেসের সঙ্গে কাজ করার সময় ব্যতিক্রমগুলি বুঝতে এবং মোকাবিলা করতে সহজে পারে। Spring বিভিন্ন ধরনের ব্যতিক্রম ফেলে, যেমন:

  • DataAccessException: এটি RuntimeException এর সাবক্লাস এবং সমস্ত JDBC ব্যতিক্রমগুলির জন্য একটি সাধারণ শ্রেণী।
  • SQLException: এটি DataAccessException এর অধীনে থাকে এবং সাধারণ SQL সম্পর্কিত ত্রুটি রেপ্রেজেন্ট করে।

Spring JDBC-তে ব্যতিক্রম পরিচালনা করার জন্য try-catch ব্লক ব্যবহার করা হয়, তবে DataAccessException সাধারণত ডিরেক্টলি ক্যাচ করা হয় না, কারণ Spring তা স্বয়ংক্রিয়ভাবে রূপান্তর করে থাকে।

Spring JDBC Exception Handling Example:

ধরা যাক, আমাদের একটি Employee টেবিল আছে এবং আমরা কিছু ডেটাবেস অপারেশন করব। যদি কোনো ত্রুটি ঘটে, তবে আমরা সেই ত্রুটির ব্যতিক্রমটি ধরা এবং প্রক্রিয়া করব।

১. Maven ডিপেনডেন্সি:

প্রথমে, আপনাকে Spring JDBC এর জন্য ডিপেনডেন্সি যুক্ত করতে হবে।

<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-jdbc</artifactId>
    <version>5.3.24</version> <!-- সর্বশেষ সংস্করণ নিশ্চিত করতে Maven Repository থেকে চেক করুন -->
</dependency>
<dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.3.24</version>
</dependency>

২. Spring JDBC Exception Handling Example:

২.১ DataSource কনফিগারেশন:

HikariCP বা Tomcat Connection Pool ব্যবহার করে DataSource কনফিগারেশন করতে হবে।

import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import javax.sql.DataSource;

@Configuration
public class DataSourceConfig {

    @Bean
    public DataSource dataSource() {
        HikariConfig hikariConfig = new HikariConfig();
        hikariConfig.setJdbcUrl("jdbc:mysql://localhost:3306/your_database");
        hikariConfig.setUsername("your_username");
        hikariConfig.setPassword("your_password");
        hikariConfig.setDriverClassName("com.mysql.cj.jdbc.Driver");

        return new HikariDataSource(hikariConfig);
    }
}
২.২ Exception Handling সহ JdbcTemplate ব্যবহার:

এখন, আমরা JdbcTemplate এর মাধ্যমে ডেটাবেস অপারেশন করব এবং যদি কোনো ব্যতিক্রম ঘটে, আমরা তা try-catch ব্লকের মাধ্যমে ধরি।

import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

@Component
public class EmployeeDAO {

    private final JdbcTemplate jdbcTemplate;

    @Autowired
    public EmployeeDAO(DataSource dataSource) {
        this.jdbcTemplate = new JdbcTemplate(dataSource);
    }

    // Employee ইনসার্ট করার জন্য
    public void addEmployee(int id, String name, double salary) {
        String sql = "INSERT INTO Employee (id, name, salary) VALUES (?, ?, ?)";

        try {
            jdbcTemplate.update(sql, id, name, salary);
            System.out.println("Employee added successfully");
        } catch (DataAccessException e) {
            // SQLException বা অন্য ব্যতিক্রম DataAccessException এ রূপান্তরিত হবে
            System.err.println("Error occurred while inserting employee: " + e.getMessage());
            // আরও স্পেসিফিক ব্যতিক্রম প্রক্রিয়া করা যেতে পারে
        }
    }

    // Employee পড়ার জন্য
    public void getEmployeeById(int id) {
        String sql = "SELECT * FROM Employee WHERE id = ?";

        try {
            Employee employee = jdbcTemplate.queryForObject(sql, new Object[]{id}, new EmployeeRowMapper());
            System.out.println("Employee: " + employee.getName());
        } catch (DataAccessException e) {
            System.err.println("Error occurred while fetching employee: " + e.getMessage());
        }
    }
}
২.৩ RowMapper ব্যবহার:

এখানে EmployeeRowMapper ক্লাসটি ব্যবহার করা হয়েছে যা SQL রেজাল্ট সেট থেকে Employee অবজেক্ট তৈরি করবে।

import org.springframework.jdbc.core.RowMapper;
import java.sql.ResultSet;
import java.sql.SQLException;

public class EmployeeRowMapper implements RowMapper<Employee> {

    @Override
    public Employee mapRow(ResultSet rs, int rowNum) throws SQLException {
        Employee employee = new Employee();
        employee.setId(rs.getInt("id"));
        employee.setName(rs.getString("name"));
        employee.setSalary(rs.getDouble("salary"));
        return employee;
    }
}
২.৪ ব্যবহার:

এখন, আমরা EmployeeDAO ক্লাসটি ব্যবহার করে ডেটাবেস অপারেশন করব এবং ব্যতিক্রম হ্যান্ডলিং করব।

import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class Main {

    public static void main(String[] args) {
        // Spring কনটেক্সট ইনিশিয়ালাইজ করা
        AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(DataSourceConfig.class);

        EmployeeDAO employeeDAO = context.getBean(EmployeeDAO.class);

        // Employee ইনসার্ট করা
        employeeDAO.addEmployee(1, "John Doe", 50000);

        // Employee পড়া
        employeeDAO.getEmployeeById(1);

        context.close();
    }
}

ব্যতিক্রমের ধরন:

  1. DataAccessException: Spring JDBC তে সব ধরনের ব্যতিক্রম স্বয়ংক্রিয়ভাবে DataAccessException এ রূপান্তরিত হয়। এটি সাধারণত SQLException থেকে রূপান্তরিত হয়।
  2. SQLException: এই ব্যতিক্রমটি Spring এর মাধ্যমে DataAccessException এ রূপান্তরিত হয়ে যায়, তবে আপনি যদি চাচ্ছেন, আপনি এটি ক্যাচ করতে পারেন।
  3. Duplication or Integrity Constraint Violations: যেমন, SQLIntegrityConstraintViolationException ক্যাচ করা হতে পারে যদি আপনি ডুপ্লিকেট কনস্ট্রেইন্ট লঙ্ঘন করেন (যেমন UNIQUE constraint)।

উপসংহার:

  • Spring JDBC তে Exception Handling স্বয়ংক্রিয়ভাবে DataAccessException এর মাধ্যমে করা হয়।
  • আপনি try-catch ব্লক ব্যবহার করে ডেটাবেস অপারেশনের মধ্যে ব্যতিক্রমগুলি সঠিকভাবে ধরতে এবং প্রক্রিয়া করতে পারেন।
  • আপনি DataAccessException ক্যাচ করে ব্যতিক্রমগুলি হ্যান্ডল করতে পারেন এবং সেগুলিকে আরও স্পষ্ট করে পরিচালনা করতে পারেন।
Content added By
Promotion

Are you sure to start over?

Loading...