1.引入依赖jar包
<dependencies>
<dependency>
<groupId>com.java1234.springcloud</groupId>
<artifactId>microservice-common</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
</dependency>
<!-- 修改后立即生效,热部署 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>springloaded</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
</dependencies>
2.加入连接池配置文件application.yml:
server:
port: 1001
context-path: /
# 数据源配置
spring:
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/db_springcloud
username: root
password: 123456
jpa:
hibernate:
ddl-auto: update
show-sql: true
3.创建dao层:
package com.java1234.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import com.java1234.entity.Student;
/**
* 学生Repository接口
* @author Administrator
*
*/
public interface StudentRepository extends JpaRepository<Student, Integer>,JpaSpecificationExecutor<Student>{
}
4.service层:
package com.java1234.service;
import java.util.List;
import com.java1234.entity.Student;
/**
* 学生信息Service接口
* @author Administrator
*
*/
public interface StudentService {
/**
* 添加或者修改学生信息
* @param student
*/
public void save(Student student);
/**
* 根据id查找学生信息
* @param id
* @return
*/
public Student findById(Integer id);
/**
* 查询学生信息
* @return
*/
public List<Student> list();
/**
* 根据id删除学生信息
* @param id
*/
public void delete(Integer id);
}
package com.java1234.service.impl;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import com.java1234.entity.Student;
import com.java1234.repository.StudentRepository;
import com.java1234.service.StudentService;
/**
* 学生信息Service实现类
* @author Administrator
*
*/
@Service("studentService")
public class StudentServiceImpl implements StudentService{
@Resource
private StudentRepository studentRepository;
@Override
public void save(Student student) {
studentRepository.save(student);
}
@Override
public Student findById(Integer id) {
return studentRepository.findOne(id);
}
@Override
public List<Student> list() {
return studentRepository.findAll();
}
@Override
public void delete(Integer id) {
studentRepository.delete(id);
}
}
5.controller层:
package com.java1234.controller;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.java1234.entity.Student;
import com.java1234.service.StudentService;
/**
* 服务提供者-学生信息控制器
* @author Administrator
*
*/
@RestController
@RequestMapping("/student")
public class StudentProviderController {
@Resource
private StudentService studentService;
/**
* 添加或者修改学生信息
* @param student
* @return
*/
@PostMapping(value="/save")
// 自定义实体类需要加上@RequestBody,否则收到数据为null
public boolean save(@RequestBody Student student){
try{
studentService.save(student);
return true;
}catch(Exception e){
return false;
}
}
/**
* 查询学生信息
* @return
*/
@GetMapping(value="/list")
public List<Student> list(){
return studentService.list();
}
/**
* 根据id查询学生信息
* @return
*/
@GetMapping(value="/get/{id}")
public Student get(@PathVariable("id") Integer id){
return studentService.findById(id);
}
/**
* 根据id删除学生信息
* @return
*/
@GetMapping(value="/delete/{id}")
public boolean delete(@PathVariable("id") Integer id){
try{
studentService.delete(id);
return true;
}catch(Exception e){
return false;
}
}
}
6.最后创建启动类:
package com.java1234;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class StudentProviderApplication_1001 {
public static void main(String[] args) {
SpringApplication.run(StudentProviderApplication_1001.class, args);
}
}