zoukankan      html  css  js  c++  java
  • [Spring] Spring Data JPA

    Previouly we need to define a DAO interface and a DAO impl for 'Employee', it is not so reuseable, since all the DAO has the same structure:

    package com.luv2code.springboot.cruddemo.dao;
    
    import com.luv2code.springboot.cruddemo.entity.Employee;
    import java.util.List;
    
    public interface EmployeeDAO {
        public List<Employee> findAll();
    
        public Employee findById (int theId);
    
        public void save(Employee theEmployee);
    
        public void deleteById(int theId);
    }

    Spring data jpa provids a much simple and reuseable way to do the stuff, we only need to info JPA with 'Employee' entity class and its primary id type. Then JPA will provides us all the methods we need, such ass 'findAll' & 'findById' & 'save' & 'deleteById':

    package com.luv2code.springboot.cruddemo.dao;
    
            import com.luv2code.springboot.cruddemo.entity.Employee;
            import org.springframework.data.jpa.repository.JpaRepository;
    
    public interface EmployeeRepository extends JpaRepository<Employee, Integer> {
        // NO need to write any code here
    }

    We just need to update the service to use new Data JPA:

    package com.luv2code.springboot.cruddemo.service;
    
    import com.luv2code.springboot.cruddemo.dao.EmployeeRepository;
    import com.luv2code.springboot.cruddemo.entity.Employee;
    import org.springframework.beans.factory.annotation.Autowired;
    
    import java.util.Optional;
    
    public class EmployeeServiceImpl implements EmployeeService{
    
        private EmployeeRepository employeeRepository;
    
        @Autowired
        public EmployeeServiceImpl (EmployeeRepository theEmployeeRepository) {
            employeeRepository = theEmployeeRepository;
        }
    
        @Override
        public List<Employee> findAll() {
            return employeeRepository.findAll();
        }
    
        @Override
        public Employee findById(int theId) {
    
            Optional<Employee> result=  employeeRepository.findById(theId);
            Employee theEmployee = null;
            if (result.isPresent()) {
                theEmployee = result.get();
            } else {
                throw new RuntimeException("Did not find employee id  - " + theId);
            }
    
            return theEmployee;
        }
    
        @Override
        public void save(Employee theEmployee) {
            employeeRepository.save(theEmployee);
        }
    
        @Override
        public void deleteById(int theId) {
            employeeRepository.deleteById(theId);
        }
    }
  • 相关阅读:
    专家视角 | 小荷的 Oracle Database 18c 新特性快速一瞥
    java.lang.ClassCastException: com.xx.User cannot be cast to com.xx.User
    上传单个文件
    极速体验:Oracle 18c 下载和Scalable Sequence新特性
    开工大吉:Oracle 18c已经发布及新特性介绍
    CentOS7编译安装NodeJS
    .NET 同步与异步之锁(ReaderWriterLockSlim)(八)
    .NET 同步与异步之锁(ReaderWriterLockSlim)(八)
    .NET 同步与异步之锁(ReaderWriterLockSlim)(八)
    .NET 同步与异步之锁(ReaderWriterLockSlim)(八)
  • 原文地址:https://www.cnblogs.com/Answer1215/p/11076581.html
Copyright © 2011-2022 走看看