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,一个简单的增删改查功能全部实现!
相关文章
|
3月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
7月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
1227 1
Spring boot 使用mybatis generator 自动生成代码插件
|
6月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
405 0
|
7月前
|
Java 数据库连接 API
Java 对象模型现代化实践 基于 Spring Boot 与 MyBatis Plus 的实现方案深度解析
本文介绍了基于Spring Boot与MyBatis-Plus的Java对象模型现代化实践方案。采用Spring Boot 3.1.2作为基础框架,结合MyBatis-Plus 3.5.3.1进行数据访问层实现,使用Lombok简化PO对象,MapStruct处理对象转换。文章详细讲解了数据库设计、PO对象实现、DAO层构建、业务逻辑封装以及DTO/VO转换等核心环节,提供了一个完整的现代化Java对象模型实现案例。通过分层设计和对象转换,实现了业务逻辑与数据访问的解耦,提高了代码的可维护性和扩展性。
282 1
|
6月前
|
SQL Java 数据库连接
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
182 0
|
6月前
|
JSON 前端开发 Java
第05课:Spring Boot中的MVC支持
第05课:Spring Boot中的MVC支持
292 0
|
7月前
|
SQL Java 数据库
解决Java Spring Boot应用中MyBatis-Plus查询问题的策略。
保持技能更新是侦探的重要素质。定期回顾最佳实践和新技术。比如,定期查看MyBatis-Plus的更新和社区的最佳做法,这样才能不断提升查询效率和性能。
295 1
|
10月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
782 0
|
12月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
565 2
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
641 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。