当前位置:Gxlcms > 数据库问题 > Vue+Spring Data JPA+MySQL 增查改删

Vue+Spring Data JPA+MySQL 增查改删

时间:2021-07-01 10:21:17 帮助过:11人阅读

https://www.bilibili.com/video/BV16i4y1G7i2/

需要完成以下步骤:

  1. 前后端分离,进行简单增查改删(CRUD)
  2. 前端使用VUE
  3. 后端使用Spring Data JPA
  4. 数据库使用MySQL

技术图片

#EmployeeController.java

package com.deepincoding.springdatajpamysqlcrud.controller;

import com.deepincoding.springdatajpamysqlcrud.entity.Employee;
import com.deepincoding.springdatajpamysqlcrud.model.BaseResponse;
import com.deepincoding.springdatajpamysqlcrud.service.EmployeeService;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
import org.springframework.data.web.PageableDefault;
import org.springframework.web.bind.annotation.*;

import java.util.Optional;

@RestController
@RequestMapping("/api/employee")
@Log4j2
public class EmployeeController extends BaseController {

    @Autowired
    private EmployeeService employeeService;

    @PostMapping
    public BaseResponse<String> save(@RequestBody Employee employee){
          employeeService.save(employee);
          return new BaseResponse<>(SUCCESS,"保存成功");
    }

    @GetMapping("/{id}")
    public BaseResponse<Optional<Employee>> findById(@PathVariable Long id){
        Optional<Employee> employee = employeeService.findById(id);
        return new BaseResponse<>(SUCCESS,"获取成功",employee);
    }

    @GetMapping
    public BaseResponse<Page<Employee>> findAll(@PageableDefault(sort = {"id"},direction = Sort.Direction.DESC ,size = 3) Pageable pageable){
        log.info("pageable:{}",pageable.getPageNumber());
        Page<Employee> employees = employeeService.findAll(pageable);
        return new BaseResponse<>(SUCCESS,"获取成功",employees);
    }

    @PutMapping
    public BaseResponse<String> update(@RequestBody Employee employee){
        employeeService.save(employee);
        return new BaseResponse<>(SUCCESS,"修改成功");
    }

    @DeleteMapping("/{id}")
    public BaseResponse<String> delete(@PathVariable Long id){
        employeeService.delete(id);
        return new BaseResponse<>(SUCCESS,"删除成功");
    }

}


#CorsConfig.java

package com.deepincoding.springdatajpamysqlcrud.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class CorsConfig implements WebMvcConfigurer {
    /**
     * 跨域配置
     * @param registry
     */
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowedMethods("*");
    }
}

#Employee.java

package com.deepincoding.springdatajpamysqlcrud.entity;

import com.deepincoding.springdatajpamysqlcrud.enums.Gender;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;


import javax.persistence.*;

@Entity
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Employee {
    @Id
    @GeneratedValue(strategy= GenerationType.AUTO)
    private long id;
    private String name;
    @Enumerated(EnumType.STRING)
    private Gender gender;
    private Integer age;
    private String introduce;

}

#EmployeeServiceImpl.java

package com.deepincoding.springdatajpamysqlcrud.service;

import com.deepincoding.springdatajpamysqlcrud.entity.Employee;
import com.deepincoding.springdatajpamysqlcrud.repositories.EmployeeRep;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.stereotype.Service;
import org.springframework.data.domain.Pageable;

import java.util.Optional;


@Service
public class EmployeeServiceImpl implements  EmployeeService{

    @Autowired
    private EmployeeRep employeeRep;

    @Override
    public void save(Employee employee) {
        employeeRep.save(employee);
    }

    @Override
    public Optional<Employee> findById(Long id) {
        return employeeRep.findById(id);
    }

    @Override
    public void update(Employee employee) {
        employeeRep.save(employee);
    }

    @Override
    public void delete(Long id) { employeeRep.deleteById(id); }

    @Override
    public Page<Employee> findAll(Pageable pageable) {
        return employeeRep.findAll(pageable);
    }
}

 

Vue+Spring Data JPA+MySQL 增查改删

标签:步骤   var   ack   repos   20px   strategy   href   err   radius   

人气教程排行