多平台统一管理软件接口,如何实现多平台统一管理软件接口
308
2022-09-04
教你如何写springboot接口
首先要明白数据的流通方向:
数据的触发是前端请求后端引起的,遵循传统的mvc规范的话 我们需要pojo mapper service controller 四个层次,Pojo 是于数据库中字段直接对应的
在线搭建一个springboot项目
https://start.spring.io/
其中需要加入的四个依赖
点击确定 把没有用的文件删除 最后保留一下两个:
在此处添加jdk的版本:
开始编写接口实现
pon.xml
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
application.yml
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/test?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=Asia/Shanghai
username: root
password: 123456
server:
port: 8001
持久层:
package com.example.demo.entity;
import lombok.Data;
@Data
public class User {
private Integer id;
private String name;
private String address;
private Integer age;
private String sex;
private String phone;
}
这里我们引入了 lombok 不需要写get和set方法简化代码
mapper层
package com.example.demo.mapper;
import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import java.util.List;
public interface UserMapper {
@Select("select * from user")
List
@Update("INSERT INTO `user` (`name`, `address`, `age`, `sex`, `phone`) VALUES (#{name},#{address},#{age},#{sex},#{phone});")
@Transactional
void save(User user);
@Update("update user set name=#{name} , address=#{address}, age=#{age}, sex=#{sex},phone=#{phone} where id =#{id}")
@Transactional
void updateById(User user);
@Delete("delete from user where id =#{id}")
@Transactional
void deleteById(Long id);
@Select("select * from user where id =#{id}")
User findById(Long id);
@Select("select * from user limit #{offset},#{pageSize}")
List
@Select("select count(id) from user")
Integer countUser();
}
controller
package com.example.demo.controller;
import com.example.demo.entity.User;
import com.example.demo.mapper.UserMapper;
import com.example.demo.vo.Page;
import org.apache.ibatis.annotations.Delete;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.util.List;
@RestController
@RequestMapping("/user")
public class UserController {
@Resource
UserMapper userMapper;
@GetMapping
public List
return userMapper.findAll();
}
@PostMapping
public String addUser(@RequestBody User user){
//把前端传过来的数据转化为user实体类的对象插入到数据库中
userMapper.save(user);
return "success";
}
@PutMapping
public String updateUser(@RequestBody User user){
userMapper.updateById(user);
return "success";
}
@DeleteMapping("/{id}") //一一对相应的关系
public String deleteUser(@PathVariable("id") Long id){
//注解是循序json回传带有id
userMapper.deleteById(id);
return "success";
}
@GetMapping("/{id}") //把返回的结果 返回出来 包装成一个user对象
public User findById(@PathVariable("id") Long id){
//注解是循序json回传带有id
return userMapper.findById(id);
}
@GetMapping("/page")
public Page
@RequestParam(defaultValue = "10") Integer pageSize) {
Integer offset = (pageNum - 1) * pageSize;
List
Page
page.setData(userData);
Integer total = userMapper.countUser();
page.setTotal(total);
page.setPageNum(pageNum);
page.setPageSize(pageSize);
return page;
}
}
注意 :在实现过程中需要抓启动类中添加 扫描mapper的注解
以前就是对接口的增删改查 和分页查询的实现
实现过程:
快速写出插入语句
插入实现 模拟前端想后端发送json数据
更新测试:
删除实现:
删除是要注意 id的一一对应
分页查询:
分页查询 参数1 第几页 参数2 一页有多少个数据
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~