Spring Data JDBC, Spring Framework’ün bir modülü olup, JDBC tabanlı veritabanı erişimini daha modern ve basit bir şekilde gerçekleştirmek için kullanılır. Spring Data JDBC, Spring Data’nın prensiplerini kullanarak veri erişimini daha kolay ve yönetilebilir hale getirir, ancak ORM araçlarının aksine doğrudan JDBC ile çalışır.
Spring Data JDBC’nin Temel Özellikleri
Basit ve Doğrudan Erişim: Spring Data JDBC, ORM (Object-Relational Mapping) araçlarının karmaşıklığından kaçınarak doğrudan veritabanı işlemlerini gerçekleştirir.
Repository Temelli: Spring Data’nın sunduğu CrudRepository ve PagingAndSortingRepository arayüzlerini kullanarak veri erişim katmanını oluşturur.
Anotasyonlar: Entity tanımları için basit anotasyonlar kullanır (@Table, @Id, @Column, vb.).
Kolay Konfigürasyon: Spring Boot ile entegre çalışarak otomatik konfigürasyon sağlar.
Spring Data JDBC Kullanarak Veritabanı İşlemleri
Aşağıda, Spring Data JDBC kullanarak bir veritabanı bağlantısının nasıl kurulacağını ve veri işlemlerinin nasıl yapılacağını gösteren bir örnek bulunmaktadır.
Maven Bağımlılıkları
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>
</dependencies>
Uygulama Özellikleri (application.properties)
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.datasource.password=password
spring.h2.console.enabled=true
spring.datasource.initialize=true
spring.jpa.hibernate.ddl-auto=update
Entity Sınıfı (Employee.java)
import org.springframework.data.relational.core.mapping.Table;
@Table(“employees”)
public class Employee {
@Id
private Long id;
private String name;
private int age;
// Getter ve Setter metodları
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 int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
Repository Arayüzü (EmployeeRepository.java)
public interface EmployeeRepository extends CrudRepository<Employee, Long> {
}
Service Sınıfı (EmployeeService.java)
import org.springframework.stereotype.Service;
@Service
public class EmployeeService {
@Autowired
private EmployeeRepository employeeRepository;
public Employee saveEmployee(Employee employee) {
return employeeRepository.save(employee);
}
public Iterable<Employee> getAllEmployees() {
return employeeRepository.findAll();
}
}
Controller Sınıfı (EmployeeController.java)
import org.springframework.web.bind.annotation.*;
@RestController
@RequestMapping(“/employees”)
public class EmployeeController {
@Autowired
private EmployeeService employeeService;
@PostMapping
public Employee createEmployee(@RequestBody Employee employee) {
return employeeService.saveEmployee(employee);
}
@GetMapping
public Iterable<Employee> getAllEmployees() {
return employeeService.getAllEmployees();
}
}
Spring Boot Uygulaması (SpringDataJdbcApplication.java)
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class SpringDataJdbcApplication {
public static void main(String[] args) {
SpringApplication.run(SpringDataJdbcApplication.class, args);
}
}
Açıklamalar
Bağımlılıklar: Spring Boot starter’ları ve H2 veritabanı bağımlılıkları tanımlanmıştır.
Uygulama Özellikleri: H2 veritabanı için bağlantı bilgileri ve diğer yapılandırmalar yapılmıştır.
Entity Sınıfı: Employee sınıfı, veritabanı tablosu ile eşleştirilmiştir. @Table ve @Id anotasyonları kullanılmıştır.
Repository Arayüzü: EmployeeRepository arayüzü, Spring Data’nın CrudRepository arayüzünü genişleterek temel CRUD işlemlerini sağlar.
Service Sınıfı: EmployeeService sınıfı, iş mantığını içerir ve EmployeeRepository’i kullanarak veri işlemlerini gerçekleştirir.
Controller Sınıfı: EmployeeController sınıfı, RESTful API uç noktalarını tanımlar.
Spring Boot Uygulaması: SpringDataJdbcApplication sınıfı, Spring Boot uygulamasını başlatır.
Bu yapı, Spring Data JDBC kullanarak basit ve etkili bir veri erişim katmanı oluşturmanızı sağlar. CRUD işlemleri için gereken kod miktarını azaltır ve veri erişimini daha yönetilebilir hale getirir.