一、数据的修改
1、根据id对信息进行修改:
先在展示页面添加一个修改链接,可以跳转修改页面
<a href="/getBookById?id=${item.id}">修改</a>
2、创建一个修改页面updata.jsp:
<body>
<form method="post" action="/updata">
编号:<input type="text" name="id" value="${book.id}" readonly="readonly"><br>
书名:<input type="text" name="name" value="${book.name}"><br>
价格:<input type="text" name="price" value="${book.price}"><br>
<input type="submit">
</form>
</body>
修改页面的每个框中应该展示出旧信息,即value="${book.?}"
编号不能进行修改,不然会影响业务逻辑。因此让它只读。readonly="readonly"
3、获取要修改的数据:
(1)dao层
先要获取想要修改的那一行的数据信息(那一行的图书对象信息):
public BookBean getBookById(int id){
//id为几,在list中的角标就是几减一
//例如id为3,则这一行数据在list中角标为2
return list.get(id-1);
}
(2)service层
public BookBean getBookById(int id){
return bookDao.getBookById(id);
}
(3)Controller控制层
@RequestMapping("/getBookById")
public String getBookById(HttpSession session, HttpServletRequest request){
String bid = request.getParameter("id");
int id = bid==null ? -1:Integer.parseInt(bid);
BookBean book = bookService.getBookById(id);
session.setAttribute("book",book);
return "updata.jsp";
}
获取到这一行信息后跳转到修改页面updata.jsp
效果图如下:
updata.jsp.png
4、信息修改之后进行提交,更新到数据库中(list集合)
(1)dao层
public boolean updataBook(BookBean bookBean){
list.set(bookBean.getId()-1,bookBean);
return true;
}
(2)service层
public boolean updataBook(BookBean bookBean){
return bookDao.updataBook(bookBean);
}
(3)Controller控制层
@PostMapping("/updata")
public String updataBook(BookBean bookBean) {
Boolean flg = bookService.updataBook(bookBean);
if (flg) {
return "redirect:/book";
}
return "";
}
form表单进行提交,是post请求,因此用@PostMapping注解进行处理
提交修改成功跳转到展示界面,因此 return "redirect:/book"
二、数据的删除
1、问号传参(传id)删除
问号传参,需要使用问号来拼接参数,在接受方,使用request.getParameter(“key”)来获取问号所传递过来的值,如果数据类型为String,还需要手动转换。如传的值为id,则要将其强转为int类型。可以传递多个值,如果使用多个值,使用&来拼接,不会改变路径级别
<a href="/deleteById?id=${item.id}">删除(问号传参)</a>
@RequestMapping("/deleteById")
public String deleteBookById(HttpServletRequest request){
String bid = request.getParameter("id");
int id = bid==null ? -1:Integer.parseInt(bid);
Boolean flg = bookService.deleteBookId(id);
if(flg){
return "redirect:/book";
}
return "";
}
2、路径传参
路径传参,使用路径符号来传递参数。优点,可以不用做类型转换来直接获取其值。
<a href="/deleteById/${item.id}">删除(路径传参)</a>
//路径传参
@GetMapping("/deleteById/{id}")
public String deleteBookById(@PathVariable int id){
Boolean flg = bookService.deleteBookId(id);
if (flg){
return "redirect:/book";
}
return "";
}
路径传参是get请求,所以用@GetMapping注解,("/deleteById/{id}")把获得的id拼接到路径中。
@PostMapping,专门用来处理post请求
@GETMapping,专门用来处理get请求
@PathVariable路径传参的注解,可以实现路径传参。