springboot增删改查
@RestController
@RequestMapping("/book")
public class BookController {
@Resource
private BookService bookService;
//查询所有图书
@GetMapping("/findAll")
public List<Book> findAll(){
return bookService.list();
}
// 根据id查询图书
@GetMapping("findById/{id}")
public Book findById(@PathVariable("id") Integer id) {
return this.bookService.getById(id);
}
// 删除图书
@DeleteMapping("/delBook/{id}")
public boolean delBook(@PathVariable("id") Integer id) {
return this.bookService.removeById(id);
}
//增加图书
@PostMapping("/addBook")
public boolean addBook(@RequestBody Book book){
return this.bookService.save(book);
}
//更新图书信息
@PutMapping("/updateBook")
public boolean updateBook(@RequestBody Book book){
return this.bookService.updateById(book);
}
}
知识点:
1、@Autowired注解与@Resource注解的区别
相同点:
@Resource的作用相当于@Autowired,均可标注在字段或属性的setter方法上。
不同点:
(1)提供方:@Autowired是由org.springframework.beans.factory.annotation.Autowired提供,换句话说就是由Spring提供;@Resource是由javax.annotation.Resource提供,即J2EE提供,需要JDK1.6及以上。
(2)注入方式:@Autowired只按照byType 注入;@Resource默认按byName自动注入,也提供按照byType 注入;
(3)属性:@Autowired按类型装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它required属性为false。如果我们想使用按名称装配,可以结合@Qualifier注解一起使用。@Resource有两个中重要的属性:name和type。name属性指定byName,如果没有指定name属性,当注解标注在字段上,即默认取字段的名称作为bean名称寻找依赖对象,当注解标注在属性的setter方法上,即默认取属性名作为bean名称寻找依赖对象。需要注意的是,@Resource如果没有指定name属性,并且按照默认的名称仍然找不到依赖对象时, @Resource注解会回退到按类型装配。但一旦指定了name属性,就只能按名称装配了。
@Resource装配顺序
1. 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常
2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常
3. 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常
4. 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;
2、相关注解用法
- @GetMapping 常用于查询业务
- @PostMapping 常用于增加业务
- @PutMapping 常用于更新业务
- @DeleteMapping 常用于删除业务
3、其他
(1)需要从前端传入参数时: 通过@XxxMapping("/XXX/{AA}")的形式,同时业务方法参数中要使用@PathVariable(“AA”)
@PathVariable可以将URL中占位符参数{xxx}绑定到处理器类的方法形参中
(2)当从前端传入的是一个Json对象是,要使用业务方法参数中要使用@RequestBody接收,将前端传入的Json对象转成java对象