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);
        }
    }
  • 相关阅读:
    教育网玩QQ游戏解决办法
    国家重点实验室分布<转>
    MySQL存储过程错误No data zero rows fetched, selected, or processed
    安装Oracle Developer后 pl sql无法使用
    Jsp开发入门
    开源项目MiniOA协同办公系统介绍
    JavaScript实现网页单击事件
    (转)普及基础知识一
    “人脸识别程序”总结
    (转)如何加速Altera的EDA工具? (IC Design) (Quartus II) (Nios II) (SOPC Builder)
  • 原文地址:https://www.cnblogs.com/Answer1215/p/11076581.html
Copyright © 2011-2022 走看看