idea实现spring + springMVC + mybatis 整合(2)

简介: idea实现spring + springMVC + mybatis 整合(2)
承接上文,在测试完成后,简单实现猴子信息的增删改查
1,编写公共页面,test.jsp,并且自带查询全部猴子信息功能
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>Title</title>
    <%--BootStrap美化界面--%>
    <link  href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"">
</head>
<body style="background: aquamarine">
<div>
    <div class="container" align="center">
        <div class="col-md-12 column">
            <div class="page-header" >
                <h1>
                    <small>猴子信息------显示列表</small>
                </h1>
            </div>
        </div>
    </div>
    <div class="container">
        <div class="col-md-4 column">
            <a href="${pageContext.request.contextPath}/t1/addMonkey">增加猴子</a>
        </div>
    </div>
    <div class="row clearfix">
        <div class="col-md-12 column">
            <table class="table table-hover table-striped">
                <thead>
                   <tr>
                       <th>猴子id</th>
                       <th>猴子姓名</th>
                       <th>猴子地址</th>
                       <th>猴子email</th>
                       <th>操作</th>
                   </tr>
                </thead>
                <tbody>
                <c:forEach var="monkey" items="${list}">
                    <tr>
                        <td>${monkey.id}</td>
                        <td>${monkey.name}</td>
                        <td>${monkey.address}</td>
                        <td>${monkey.email}</td>
                        <td>
                            <a href="/t1/toUpdate?id=${monkey.id}">修改</a> &nbsp; | &nbsp; <a href="/t1/delete?id=${monkey.id}">删除</a>
                        </td>
                    </tr>
                </c:forEach>
                </tbody>
            </table>
        </div>
    </div>
</div>
</body>
</html>
2,一个简单地页面显示出来

3,控制层中MonkeyCon类
package controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import pojo.Monkey;
import services.MonkeyServicesImpl;
import java.util.List;
@Controller
//浏览器访问的映射路径:(/t1/c1)
@RequestMapping("/t1")
public class MonkeyCon {
    @Autowired
    @Qualifier("monkeyServicesImpl")
    private MonkeyServicesImpl monkeyServices;
    //主界面
    @RequestMapping("/c1")
    public String qaq(Model model){
        List<Monkey> list = monkeyServices.select();
        model.addAttribute("list",list);
        return "test";
    }
    //跳转到增加猴子
    @RequestMapping("/addMonkey")
    public String addMonkey(){
        return "addMonkey";
    }
    //增加猴子完返回到首页,首页自带查询功能
    @RequestMapping("/returnC1")
    public String returnC1(Monkey monkey){
        //控制层调用业务层,将数据加入到数据库中
        monkeyServices.insert(monkey);
        //重定向到页面
        return "redirect:/t1/c1";
    }
    //更新界面
    @RequestMapping("/toUpdate")
    public String getMonkey(int id,Model model){
        System.out.println("修改了" + id + "几本数");
        Monkey monkey = monkeyServices.getMonkey(id);
        model.addAttribute(monkey);
        return "update";
    }
    //更新完提交事务的界面
    @RequestMapping("/updateOver")
    public String UpdateOver(Monkey monkey){
        int update = monkeyServices.update(monkey);
        System.out.println("猴子更新成功!");
        return "redirect:/t1/c1";
    }
    //删除界面,根据id删除一只猴子
    @RequestMapping("/delete")
    public String delete(int id){
        int delete = monkeyServices.delete(id);
        System.out.println("删除成功!");
        return "redirect:/t1/c1";
    }
}
4,点击增加猴子超链接后增加猴子信息的页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head style="background: deepskyblue">
    <title>增加猴子</title>
    <link  href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"">
</head>
<body>
    <div class="container" align="center">
        <div class="col-md-12 column">
            <div class="page-header" >
                <h3>更新猴子信息</h3>
            </div>
        </div>
    </div>
    <div align="center">
        <form action="/t1/returnC1" method="get">
            <div class="form-group">
                <label>猴子id</label>
                <input type="text" class="form-control" name="id" placeholder="请输入id" required><br>
                <label>猴子名称</label>
                <input type="text" class="form-control" name="name" placeholder="请输入名称" required><br>
                <label>猴子地址</label><br>
                <input type="text" class="form-control" name="address" placeholder="请输入地址" required><br>
                <label>猴子email</label><br>
                <input type="text" class="form-control" name="email" placeholder="请输入email" required><br>
                <input type="submit" value="添加">
            </div>
        </form>
    </div>
</body>
</html>
5,修改猴子信息的页面

思路:在每一个猴子信息后面中都有更新和删除键,在更新的超链接后面新增一个id参数,为猴子当前id,可以直接通过获取id获取数据库中猴子的全部信息,一次需要在业务层以及dao层中添加一个业务,即多写一个sql查询语句,通过id查询猴子所有的信息,在进行页面跳转时,交给controller中的MonkeyCon处理,然后将信息展示在页面上,供修改,在修改完成之后,再进行重定向到公共页面,公共页面自带查询功能!

    //通过id获取猴子
    //在dao接口中增加的业务
    public Monkey getMonkey(int id);

修改页面,在每个标签中加上一个value值,value值需要从MonkeyCon中通过Model携带,即可将当前要修改信息的猴子的信息展示出来,再修改完成之后,在将信息交给controller中的MonkeyCon,让修改的信息的值传给数据库中进行修改,再重定向到自带查询功能的公共页面中

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head style="background: aqua">
   <title>修改猴子</title>
   <link  href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"">
</head>
<body>
<div class="container" align="center">
   <div class="col-md-12 column">
       <div class="page-header" >
           <h3>修改猴子信息</h3>
       </div>
   </div>
</div>
<div align="center">
   <form action="/t1/updateOver" method="get">
       <div class="form-group">
           <label>猴子id</label>
           <input type="text" class="form-control" name="id" value=${monkey.id} placeholder="请输入id" required><br>
           <label>猴子名称</label>
           <input type="text" class="form-control" name="name" value=${monkey.name} placeholder="请输入名称" required><br>
           <label>猴子地址</label><br>
           <input type="text" class="form-control" name="address" value=${monkey.address} placeholder="请输入地址" required><br>
           <label>猴子email</label><br>
           <input type="text" class="form-control" name="email" value=${monkey.email} placeholder="请输入email" required><br>
           <input type="submit" value="修改">
       </div>
   </form>
</div>
</body>
</html>
6,删除猴子

只需在猴子的超链接后携带参数id,再交给controller中的MonkeyCon处理,通过id删除数据库这的信息

7,一个简单的增删改查功能全部实现!
相关文章
|
10天前
|
Java Spring
【Spring配置】idea编码格式导致注解汉字无法保存
问题一:对于同一个项目,我们在使用idea的过程中,使用汉字注解完后,再打开该项目,汉字变成乱码问题二:本来a项目中,汉字注解调试好了,没有乱码了,但是创建出来的新的项目,写的注解又成乱码了。
|
18天前
|
设计模式 前端开发 Java
步步深入SpringMvc DispatcherServlet源码掌握springmvc全流程原理
通过对 `DispatcherServlet`源码的深入剖析,我们了解了SpringMVC请求处理的全流程。`DispatcherServlet`作为前端控制器,负责请求的接收和分发,处理器映射和适配负责将请求分派到具体的处理器方法,视图解析器负责生成和渲染视图。理解这些核心组件及其交互原理,有助于开发者更好地使用和扩展SpringMVC框架。
30 4
|
16天前
|
前端开发 Java 开发者
这款免费 IDEA 插件让你开发 Spring 程序更简单
Feign-Helper 是一款支持 Spring 框架的 IDEA 免费插件,提供 URL 快速搜索、Spring Web Controller 路径一键复制及 Feign 与 Controller 接口互相导航等功能,极大提升了开发效率。
|
1月前
|
缓存 Java 数据库连接
深入探讨:Spring与MyBatis中的连接池与缓存机制
Spring 与 MyBatis 提供了强大的连接池和缓存机制,通过合理配置和使用这些机制,可以显著提升应用的性能和可扩展性。连接池通过复用数据库连接减少了连接创建和销毁的开销,而 MyBatis 的一级缓存和二级缓存则通过缓存查询结果减少了数据库访问次数。在实际应用中,结合具体的业务需求和系统架构,优化连接池和缓存的配置,是提升系统性能的重要手段。
57 4
|
1月前
|
SQL Java 数据库连接
spring和Mybatis的各种查询
Spring 和 MyBatis 的结合使得数据访问层的开发变得更加简洁和高效。通过以上各种查询操作的详细讲解,我们可以看到 MyBatis 在处理简单查询、条件查询、分页查询、联合查询和动态 SQL 查询方面的强大功能。熟练掌握这些操作,可以极大提升开发效率和代码质量。
64 3
|
2月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
142 2
|
2月前
|
Java 数据库连接 数据库
spring和Mybatis的逆向工程
通过本文的介绍,我们了解了如何使用Spring和MyBatis进行逆向工程,包括环境配置、MyBatis Generator配置、Spring和MyBatis整合以及业务逻辑的编写。逆向工程极大地提高了开发效率,减少了重复劳动,保证了代码的一致性和可维护性。希望这篇文章能帮助你在项目中高效地使用Spring和MyBatis。
33 1
|
3月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
347 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
SQL Java 数据库连接
MyBatis3.x Idea搭建
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。
1427 0
|
6月前
|
IDE Oracle Java
day4:JDK、IntelliJ IDEA的安装和环境变量配置
【7月更文挑战第4天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
242 0