SpringMvc+Spring+MyBatis+Maven+Ajax+Json注解开发 利用Maven的依赖导入不使用架包模式 (实操十一)

简介: SpringMvc+Spring+MyBatis+Maven+Ajax+Json注解开发 利用Maven的依赖导入不使用架包模式 (实操十一)

SpringMvc+Spring+MyBatis+Maven+Ajax+Json注解开发 利用Maven的依赖导入不使用架包模式 (实操十)_星辰镜的博客-CSDN博客

上面的博客是环境配置和Mysql的操作

本文章的目标 完成对数据库中表的数据查序

MySql查序语句:SELECT *  FROM orders

分析表中的数据用java的方式如何存放


原始的三层架构没有写代码的情况没有写查询的功能代码的情况下

控制层

@Autowired定义:

@Autowired是一种注解,可以对成员变量、方法和构造函数进行标注,来完成自动装配的工作,@Autowired标注可以放在成员变量上,也可以放在成员变量的set方法上,也可以放在任意方法上表示,自动执行当前方法,如果方法有参数,会在IOC容器中自动寻找同类型参数为其传值

   IOrderService service;

上面的作用相当于在控制层中注入Service层的数据

package Com.Orders.Controller;
/**
 * SpringMvc 控制层 部分代码省略
 */
@Controller
public class OrderController {
    @Autowired
    IOrderService service;
}

业务逻辑层

@Autowired定义:

@Autowired是一种注解,可以对成员变量、方法和构造函数进行标注,来完成自动装配的工作,@Autowired标注可以放在成员变量上,也可以放在成员变量的set方法上,也可以放在任意方法上表示,自动执行当前方法,如果方法有参数,会在IOC容器中自动寻找同类型参数为其传值

IOrderDao dao;  

上面的作用相当于Service层中注入Dao层的数据

ackage Com.Orders.Service;
import java.util.List;
import java.util.Map;
/**
 * 业务逻辑层的接口
 */
public interface IOrderService {
}
package Com.Orders.Service;
/**
 * 业务逻辑层接口的实现类去实现接口未实现的方法
 */
@Service(value = "sService")
public class OrderServiceImp implements IOrderService {
    @Autowired
    IOrderDao dao;
}

数据访问层

对数据库的数据进行查序

package Com.Orders.Dao;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;
import java.util.List;
import java.util.Map;
/**
 * 数据反问层操作数据的增删改查
 */
public interface IOrderDao {
}

查询数据库的表中数据的代码

定义一个页面为首页

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>首页内容</title>
</head>
<body>
<div align="center">
        <h1>2022/9/19商品管理系统</h1>
    <a href="Service.html" style="font-size: 20px">点击这里进入查询页面的信息</a>
</div>
</body>
</html>

查询功能的数据跳到Service.html页面:

<a href="Service.html" style="font-size: 20px">点击这里进入查询页面的信息</a>

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>查询页面信息</title>
    <style type="text/css">
        *{
            font-family: 楷体;
            font-size: 30px;
        }
        input{
            background-color: beige;
            color: red;
            border-radius: 12px;
        }
    </style>
    <script src="js/jquery-3.2.1.min.js"></script>
</head>
<body>
<div align="center">
    <h1>查询数据库中的信息页面</h1>
    <table>
        <tr>
            <th>订单编号</th>
            <th>用户名</th>
            <th>商品名称</th>
            <th>订单时间</th>
            <th>数量</th>
            <th>单价</th>
            <th>金额</th>
            <th>操作</th>
        </tr>
    </table>
</div>
</body>
</html>


当我们点击超链接的时候跳转到查序功能的页面

查询数据库中的信息页面结果


思考:以上面的两张图的跳转要用几行代码可以实现?

查询数据库表中的数据信息

在Service.html中定义Ajax请求

  <script>
        //Ajax请求访问
        $(function () {
            $.ajax({
                url: "list.do",
                type: "GET",
                data: "",
                success: function (json) {
                     parsTale(json);
                },
                error: function () {
                    alert("用户已经连接失败")
                },
                dataType: "json"
            })
        })
</script>

控制层

@RequestMapping("list.do")
    @ResponseBody
    public Object list() {
//因为查询的数据信息是多条记录 
//所以 在Java中用 List<Map<String, String>>
        List<Map<String, String>> list = service.getList();
    }

业务逻辑层

//Java存放的方式 方法名
List<Map<String, String>> getList();

数据访问层

    // @Select("SELECT * FROM orders") 数据库的Sql语句
     @Select("SELECT * FROM orders")
    List<Map<String, String>> getList();

查询书籍的信息结果返回到页面显示 使用Json解析

 @RequestMapping("list.do")
    @ResponseBody
    public Object list() {
        List<Map<String, String>> list = service.getList();
        return list;
    }

在Service.html中解析数据

   //    定义方解析页面
        function parsTale(jsons) {
            for (var i = 0; i < jsons.length; i++) {
                $("table").append("<tr>" +
                    "<td>" + jsons[i].id + "</td>" +
                    "<td>" + jsons[i].name + "</td>" +
                    "<td>" + jsons[i].foondname + "</td>" +
                    "<td>" + jsons[i].ordertime + "</td>" +
                    "<td>" + jsons[i].count + "</td>" +
                    "<td>" + jsons[i].price + "</td>" +
                    "<td>" + jsons[i].amount + "</td>" +
                    "<td><input type='button' onclick='update(" + jsons[i].id + ")' value='修改按钮'>&nbsp;" +
                    "<input value='增加' type='button' onclick='add()'>&nbsp;" +
                    "<input value='删除' type='button'></td>" +
                    "</tr>")
            }


查询数据库中的信息页面结果

 

总结:为什么要使用框架:最重要的一点是方便

                   

相关文章
|
2月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于 xml 的整合
本教程介绍了基于XML的MyBatis整合方式。首先在`application.yml`中配置XML路径,如`classpath:mapper/*.xml`,然后创建`UserMapper.xml`文件定义SQL映射,包括`resultMap`和查询语句。通过设置`namespace`关联Mapper接口,实现如`getUserByName`的方法。Controller层调用Service完成测试,访问`/getUserByName/{name}`即可返回用户信息。为简化Mapper扫描,推荐在Spring Boot启动类用`@MapperScan`注解指定包路径避免逐个添加`@Mapper`
72 0
|
1月前
|
前端开发 IDE Java
Spring MVC 中因导入错误的 Model 类报错问题解析
在 Spring MVC 或 Spring Boot 开发中,若导入错误的 `Model` 类(如 `ch.qos.logback.core.model.Model`),会导致无法解析 `addAttribute` 方法的错误。正确类应为 `org.springframework.ui.Model`。此问题通常因 IDE 自动导入错误类引起。解决方法包括:删除错误导入、添加正确包路径、验证依赖及清理缓存。确保代码中正确使用 Spring 提供的 `Model` 接口以实现前后端数据传递。
68 0
|
2月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
50 0
|
2月前
|
Java 数据库连接 数据库
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——MyBatis 介绍和配置
本文介绍了Spring Boot集成MyBatis的方法,重点讲解基于注解的方式。首先简述MyBatis作为持久层框架的特点,接着说明集成时的依赖导入,包括`mybatis-spring-boot-starter`和MySQL连接器。随后详细展示了`properties.yml`配置文件的内容,涵盖数据库连接、驼峰命名规范及Mapper文件路径等关键设置,帮助开发者快速上手Spring Boot与MyBatis的整合开发。
129 0
|
2月前
|
前端开发 Java 数据库
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——Thymeleaf 介绍
本课介绍Spring Boot集成Thymeleaf模板引擎。Thymeleaf是一款现代服务器端Java模板引擎,支持Web和独立环境,可实现自然模板开发,便于团队协作。与传统JSP不同,Thymeleaf模板可以直接在浏览器中打开,方便前端人员查看静态原型。通过在HTML标签中添加扩展属性(如`th:text`),Thymeleaf能够在服务运行时动态替换内容,展示数据库中的数据,同时兼容静态页面展示,为开发带来灵活性和便利性。
74 0
|
2月前
|
Java 测试技术 微服务
微服务——SpringBoot使用归纳——Spring Boot中的项目属性配置——少量配置信息的情形
本课主要讲解Spring Boot项目中的属性配置方法。在实际开发中,测试与生产环境的配置往往不同,因此不应将配置信息硬编码在代码中,而应使用配置文件管理,如`application.yml`。例如,在微服务架构下,可通过配置文件设置调用其他服务的地址(如订单服务端口8002),并利用`@Value`注解在代码中读取这些配置值。这种方式使项目更灵活,便于后续修改和维护。
37 0
|
2月前
|
SQL Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— application.yml 中对日志的配置
在 Spring Boot 项目中,`application.yml` 文件用于配置日志。通过 `logging.config` 指定日志配置文件(如 `logback.xml`),实现日志详细设置。`logging.level` 可定义包的日志输出级别,例如将 `com.itcodai.course03.dao` 包设为 `trace` 级别,便于开发时查看 SQL 操作。日志级别从高到低为 ERROR、WARN、INFO、DEBUG,生产环境建议调整为较高级别以减少日志量。本课程采用 yml 格式,因其层次清晰,但需注意格式要求。
165 0
|
2月前
|
缓存 NoSQL Java
基于SpringBoot的Redis开发实战教程
Redis在Spring Boot中的应用非常广泛,其高性能和灵活性使其成为构建高效分布式系统的理想选择。通过深入理解本文的内容,您可以更好地利用Redis的特性,为应用程序提供高效的缓存和消息处理能力。
182 79
|
2月前
|
Java Spring
SpringBoot自动配置原理
本文深入解析了SpringBoot的核心功能——自动配置,重点探讨了`org.springframework.boot.autoconfigure`及相关注解的工作机制。通过分析`@SpringBootApplication`、`@EnableAutoConfiguration`等注解,揭示了SpringBoot如何基于类路径和条件自动装配Bean
92 7
|
2月前
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——Thymeleaf 的使用
本文介绍了 Thymeleaf 在 Spring Boot 项目中的使用方法,包括访问静态页面、处理对象和 List 数据、常用标签操作等内容。通过示例代码展示了如何配置 404 和 500 错误页面,以及如何在模板中渲染对象属性和列表数据。同时总结了常用的 Thymeleaf 标签,如 `th:value`、`th:if`、`th:each` 等,并提供了官方文档链接以供进一步学习。
104 0
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——Thymeleaf 的使用

推荐镜像

更多