增删改查Spring+MyBatis
其实这次写这个增删改查,我的收获很大,在同学的帮助下和老师的推动下,我也是学会了很多的技能点。
1.显示数据
显示数据对我而言可以说很好做,因为我以前增删改查做了有N遍,但是我却每次都是无功而返,半途而废。
查询为什么简单,因为查询不需要传入参数,sql语句不需要进行判断,只需要把所有数据显示出来就好了。
关键代码:
servlet:
List<Book> list = null;
list = bookService.selectAll();
request.setAttribute("bookN",list);
request.getRequestDispatcher("book.jsp").forward(request,response);
页面:
<body> <table class="providerTable" >
<tr class="firstTr">
<th>图书编码</th>
<th >图书名称</th>
<th >作者</th>
<th >价钱</th>
</tr>
<%
List<Book> list2 = (List<Book>)request.getAttribute("bookN");
for (Book item:list2){%>
<tr> <td name="bid"><%=item.getBookId()%></td>
<td><%=item.getBookName()%></td>
<td><%=item.getBookPc()%></td>
<td><%=item.getBookMy()%></td>
<td> <a href="insertBook.jsp" >添加</a>
<a href="${pageContext.request.contextPath}/bookServlet?action=deleteOne&id=<%=item.getBookId()%>">删除</a>
<a href="${pageContext.request.contextPath}/bookServlet?action=updateOne&id=<%=item.getBookId()%>" >修改</a>
</td>
</tr> <%
}
%> <br>
<br>
</table> <br>
</body>
2.添加数据
添加数据返回值是一个int类型或者double类型,对我而言也是简单,不需要参数,而我也是在以前每次写完查询和添加应该就不会写了。
关键代码:
servlet:
if ("insertOne".equals(action)){
Book book=new Book();
book.setBookName(request.getParameter("NameOne"));
book.setBookPc( request.getParameter("PcOne"));
book.setBookMy(Integer.valueOf(request.getParameter("MyOne")));
int count=0;
try {
count = bookService.insertOne(book);
if (count>0){
request.getRequestDispatcher("/bookServlet?action=login").forward(request,response);
}else {
response.sendRedirect("/insertBook.jsp");
}
} catch (Exception e) {
e.printStackTrace();
}
}
页面:
<body>
<form action="/bookServlet?action=insertOne" method="post">
图书名称<input type="text" name="NameOne"><br>
图书作者<input type="text" name="PcOne"><br>
图书价格<input type="text" name="MyOne" onkeyup='this.value=this.value.replace(/\D/gi,"")'>
<input type="submit" value="提交">
</form>
</body>
3.删除数据
删除数据需要传入一个参数用于作为删除的条件,返回也是int或double,对我而言删除看似不难,其难。因为删除需要获取到页面上动态数据的某一列用来作为条件。所有怎么获取一列对我而言是个难点,但今天我明白了。
关键代码:
servlet:
if ("deleteOne".equals(action)){
System.out.println("进入删除的方法");
Book book=new Book();
int id = Integer.valueOf(request.getParameter("id"));
book.setBookId(id);
try {
int count = bookService.deleteOne(book);
if (count>0){
request.getSession().setAttribute("ids",id);
request.getRequestDispatcher("/bookServlet?action=login").forward(request,response);
}
else {
response.sendRedirect("book.jsp");
}
} catch (Exception e) {
e.printStackTrace();
}
}
页面:
<a href="${pageContext.request.contextPath}/bookServlet?action=deleteOne&id=<%=item.getBookId()%>">删除</a>//标红的代码是用来获取网页上的动态数据的关键代码。
4.修改数据
关键代码:
servlet:
if ("updateOne".equals(action)){
Book book=new Book();
idupdate= Integer.valueOf(request.getParameter("id"));
try {
Book bookId = bookService.getBookId(idupdate);
request.setAttribute("bookId", bookId);
if(bookId!=null){
request.getRequestDispatcher("updateBook.jsp").forward(request,response);
}
} catch (Exception e) {
e.printStackTrace();
}
}
if ("updateTwo".equals(action)){
Book book=new Book();
int bbid = (int)request.getSession().getAttribute("bbid");
book.setBookId(bbid);
book.setBookName(request.getParameter("NameTwo"));
book.setBookPc(request.getParameter("PcTwo"));
book.setBookMy(Integer.valueOf(request.getParameter("MyTwo")));
try {
int count = bookService.updateOne(book);
if (count>0){
request.getRequestDispatcher("/bookServlet?action=login").forward(request,response);
}
else {
response.sendRedirect("updateBook.jsp");
}
} catch (Exception e) {
e.printStackTrace();
}
}
页面:
<%@ page import="cn.happy.entity.Book" %>
<%@ page import="java.util.List" %><%--
Created by IntelliJ IDEA.
User: 秀清风
Date: 2018/12/16
Time: 20:35
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<form action="/bookServlet?action=updateTwo" method="post"> 图书名称<input type="text" name="NameTwo" value="<%=session.getAttribute("bbname")%>"><br>
图书作者<input type="text" name="PcTwo" value="<%=session.getAttribute("bbpc")%>"><br>
图书价格<input type="text" name="MyTwo" value="<%=session.getAttribute("bbmy")%>" onkeyup='this.value=this.value.replace(/\D/gi,"")'>
<input type="submit" value="提交">
</form> </body>
</html>
增删改查Spring+MyBatis的更多相关文章
- commons-dbutils实现增删改查(spring新注解)
1.maven依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="h ...
- SSM框架搭建(Spring+SpringMVC+MyBatis)与easyui集成并实现增删改查实现
一.用myEclipse初始化Web项目 新建一个web project: 二.创建包 controller //控制类 service //服务接口 service.impl //服务 ...
- Java Maven:spring boot + Mybatis连接MySQL,通用mapper的增删改查,映射实现多表查询
1. MySQL自带库test添加表user.role 角色表role 用户表user 2. 添加依赖,配置属性 相关依赖:百度即可,此处略 application.properties spring ...
- ztree使用系列三(ztree与springmvc+spring+mybatis整合实现增删改查)
在springmvc+spring+mybatis里整合ztree实现增删改查,上一篇已经写了demo,以下就仅仅贴出各层实现功能的代码: Jsp页面实现功能的js代码例如以下: <script ...
- 上手spring boot项目(三)之spring boot整合mybatis进行增删改查的三种方式。
1.引入依赖. <!--springboot的web起步依赖--><dependency> <groupId>org.springframework.boot< ...
- 上手spring boot项目(三)之spring boot整合mybatis进行增删改查
使用mybatis框架进行增删改查大致有两种基础方式,一种扩展方式.两种基础方式分别是使用xml映射文件和使用方法注解.扩展方式是使用mybatis-plus的方式,其用法类似于spring-data ...
- Spring Boot入门系列(六)如何整合Mybatis实现增删改查
前面介绍了Spring Boot 中的整合Thymeleaf前端html框架,同时也介绍了Thymeleaf 的用法.不清楚的朋友可以看看之前的文章:https://www.cnblogs.com/z ...
- Spring Boot入门系列(十八)整合mybatis,使用注解的方式实现增删改查
之前介绍了Spring Boot 整合mybatis 使用xml配置的方式实现增删改查,还介绍了自定义mapper 实现复杂多表关联查询.虽然目前 mybatis 使用xml 配置的方式 已经极大减轻 ...
- ssm框架(Spring Springmvc Mybatis框架)整合及案例增删改查
三大框架介绍 ssm框架是由Spring springmvc和Mybatis共同组成的框架.Spring和Springmvc都是spring公司开发的,因此他们之间不需要整合.也可以说是无缝整合.my ...
随机推荐
- [转]JSOUP 抓取HTTPS/HTTP网页,校验问题
针对一般的http请求是不需要的校验的.但是https安全校验过总过不去.最后找到以下方法,终于成功. 让我们的站点信任所有站点,不需要引包,系统自带ssl证书校验,话不多数,贴代码. /** * 信 ...
- 1,charles的功能能介绍和安装破解
1,charles的功能 1,截取http和https网络包 2,支持重发网络请求,方便后端调试 3,支持网络请求的截获和动态修改 4,支持模拟弱化的网络 2,安装和破解 1,进入官网下载地址:htt ...
- axios封装get方法和post方法
我们常用的ajax请求方法有get.post.put等方法,相信小伙伴都不会陌生.axios对应的也有很多类似的方法,不清楚的可以看下文档.但是为了简化我们的代码,我们还是要对其进行一个简单的封装.下 ...
- 如何为shell安装有道及更新pip.
今天尝试安装shell下的有道翻译,提示需要安装pip. [root@mestery ~]# yum install python-pip [root@mestery ~]# sudo pip ins ...
- 关于Visual Studio调试C/C++,JS,PHP,JAVA,Python等语言的方法
我在开始接触vs code后,确实对它的高颜值和小巧灵活而着迷,但是有一个非常现实的问题,相对于vs来说,vscode是一个代码编辑器,而不是一个IDE,在代码编译运行上存在着极大的问题,尤其是开始编 ...
- promise 链式
let send = (item) => Promise.resolve(`此时参数是:(${item})`) async function init(){ const arr = [1,2,3 ...
- "hello,world"———C++入门有感
刚进入这所学校时,编程对于我来说应该算得上一个既熟悉又陌生的词语.虽然曾经耳边不断有人不断提到编程语言,C语言,程序猿等词语,但是作为一个外行人在来到这所学校之前,对于其中的奥秘还是没什么特别了解,仅 ...
- web应用/路由控制/视图函数/单表多表操作
一. 1.wen应用:BS架构的应用程序,B是浏览器,S:server(实现了wsgi协议)+ application https://www.cnblogs.com/liuqingzheng/art ...
- C语言 指针基础篇 数组,函数与指针的运用 2 14
下面看看如何在函数中运用指针吧 下面是往函数传入指针的简单操作,不是传入数组的.判断一个a是否大于b是的话给,是的话对其进行操作,不是的话就直接返回. #include <stdio.h> ...
- Waiting for table metadata lock
出现下图这个现象之前是在一张事务操作频繁地表上,执行了truncate操作. mysql.sock@(none)> select user,host,db,command,time,state, ...