Java SSM 项目实战 day03 功能介绍,订单的操作,订单的增删改查

2.1 订单查询页面 order-page-list.jsp,创建该页面

在这里插入图片描述

<%@ page language=“java” contentType=“text/html; charset=UTF-8”

pageEncoding=“UTF-8”%>

<%@taglib uri=“http://java.sun.com/jsp/jstl/core” prefix=“c”%>

数据 - AdminLTE2定制版

<meta

content=“width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no”

name=“viewport”>

href=“${pageContext.request.contextPath}/plugins/bootstrap/css/bootstrap.min.css”>

href=“${pageContext.request.contextPath}/plugins/font-awesome/css/font-awesome.min.css”>

href=“${pageContext.request.contextPath}/plugins/ionicons/css/ionicons.min.css”>

href=“${pageContext.request.contextPath}/plugins/iCheck/square/blue.css”>

href=“${pageContext.request.contextPath}/plugins/morris/morris.css”>

href=“${pageContext.request.contextPath}/plugins/jvectormap/jquery-jvectormap-1.2.2.css”>

href=“${pageContext.request.contextPath}/plugins/datepicker/datepicker3.css”>

href=“${pageContext.request.contextPath}/plugins/daterangepicker/daterangepicker.css”>

href=“${pageContext.request.contextPath}/plugins/bootstrap-wysihtml5/bootstrap3-wysihtml5.min.css”>

href=“${pageContext.request.contextPath}/plugins/datatables/dataTables.bootstrap.css”>

href=“${pageContext.request.contextPath}/plugins/treeTable/jquery.treetable.css”>

href=“${pageContext.request.contextPath}/plugins/treeTable/jquery.treetable.theme.default.css”>

href=“${pageContext.request.contextPath}/plugins/select2/select2.css”>

href=“${pageContext.request.contextPath}/plugins/colorpicker/bootstrap-colorpicker.min.css”>

href=“${pageContext.request.contextPath}/plugins/bootstrap-markdown/css/bootstrap-markdown.min.css”>

href=“${pageContext.request.contextPath}/plugins/adminLTE/css/AdminLTE.css”>

href=“${pageContext.request.contextPath}/plugins/adminLTE/css/skins/_all-skins.min.css”>

href=“${pageContext.request.contextPath}/css/style.css”>

href=“${pageContext.request.contextPath}/plugins/ionslider/ion.rangeSlider.css”>

href=“${pageContext.request.contextPath}/plugins/ionslider/ion.rangeSlider.skinNice.css”>

href=“${pageContext.request.contextPath}/plugins/bootstrap-slider/slider.css”>

href=“${pageContext.request.contextPath}/plugins/bootstrap-datetimepicker/bootstrap-datetimepicker.css”>

<jsp:include page=“header.jsp”></jsp:include>

<jsp:include page=“aside.jsp”></jsp:include>

数据管理 数据列表

  • 首页
  • 数据管理
  • 数据列表
  • 列表

    <button type=“button” class=“btn btn-default” title=“新建”

    οnclick=“location.href=‘${pageContext.request.contextPath}/pages/product-add.jsp’”>

    新建

    删除

    开启

    屏蔽

    刷新

    <input type=“text” class=“form-control input-sm”

    placeholder=“搜索”> <span

    class=“glyphicon glyphicon-search form-control-feedback”>

    class=“table table-bordered table-striped table-hover dataTable”>

    id=“selall” type=“checkbox” class=“icheckbox_square-blue”>

    ID 订单编号 产品名称 金额 下单时间 订单状态 操作

    <c:forEach items=“${pageInfo.list}” var=“orders”>

    ${orders.id } ${orders.orderNum } ${orders.product.productName } ${orders.product.productPrice } ${orders.orderTimeStr } ${orders.orderStatusStr }

    订单

    详情

    编辑

    </c:forEach>

    新建

    删除

    开启

    屏蔽

    刷新

    <input type=“text” class=“form-control input-sm”

    placeholder=“搜索”> <span

    class=“glyphicon glyphicon-search form-control-feedback”>

    总共2 页,共14 条数据。 每页

    1 2 3 4 5

    • 首页

    • 上一页
    • <c:forEach begin=“1” end=“${pageInfo.pages}” var=“pageNum”>

    • ${pageNum}
    • </c:forEach>

    • 下一页
    • 尾页

      Version 1.0.8

      Copyright © 2014-2017 <a

      href=“http://www.itcast.cn”>研究院研发部.

      All rights reserved.

      2.2 创建IOrdersDao接口

      在这里插入图片描述

      在这里插入图片描述

      package com.itzheng.ssm.dao;

      import com.itzheng.ssm.domain.Orders;

      import org.apache.ibatis.annotations.One;

      import org.apache.ibatis.annotations.Result;

      import org.apache.ibatis.annotations.Results;

      import org.apache.ibatis.annotations.Select;

      import java.util.List;

      public interface IOrdersDao {

      @Select(“select * from orders”)

      @Results({

      @Result(id=true,column = “id”,property = “id”),

      @Result(column = “orderNum”,property = “orderNum”),

      @Result(column = “orderTime”,property = “orderTime”),

      @Result(column = “orderStatus”,property = “orderStatus”),

      @Result(column = “peopleCount”,property = “peopleCount”),

      @Result(column = “payType”,property = “payType”),

      @Result(column = “orderDesc”,property = “orderDesc”),

      @Result(column = “productId”,property = “product”,one = @One(select =

      “com.itzheng.ssm.dao.IProductDao.findById”))

      })

      List findAll() throws Exception;

      }

      在这里插入图片描述

      2.3 修改IProductDao,添加通过i查询的方法

      在这里插入图片描述

      //根据id查询产品

      @Select(“select * from product where id=#{id}”)

      public Product findById(String id) throws Exception;

      3.订单分页查询

      3.1 PageHelper介绍

      PageHelper是国内非常优秀的一款开源的mybatis分页插件,它支持基本主流与常用的数据库,例如mysql、

      oracle、mariaDB、DB2、SQLite、Hsqldb等。

      本项目在 github 的项目地址:https://github.com/pagehelper/Mybatis-PageHelper

      本项目在 gitosc 的项目地址:http://git.oschina.net/free/Mybatis_PageHelper

      3.2 PageHelper使用
      3.2.1.集成

      引入分页插件有下面2种方式,推荐使用 Maven 方式。

      3.2.1.1. 引入 Jar 包

      你可以从下面的地址中下载最新版本的 jar 包

      https://oss.sonatype.org/content/repositories/releases/com/github/pagehelper/pagehelper/

      http://repo1.maven.org/maven2/com/github/pagehelper/pagehelper/

      由于使用了sql 解析工具,你还需要下载 jsqlparser.jar:

      http://repo1.maven.org/maven2/com/github/jsqlparser/jsqlparser/0.9.5/

      3.2.1.2. 使用 Maven

      在 pom.xml 中添加如下依赖:

      在这里插入图片描述

      com.github.pagehelper

      pagehelper

      5.1.10

      3.2. 2.配置

      特别注意,新版拦截器是 com.github.pagehelper.PageInterceptor 。 com.github.pagehelper.PageHelper 现

      在是一个特殊的 dialect 实现类,是分页插件的默认实现类,提供了和以前相同的用法。

      3.2.2.1. 在 Spring 配置文件中配置拦截器插件

      使用 spring 的属性配置方式,可以使用 plugins 属性像下面这样配置:

      在这里插入图片描述

      oracle

      true

      3.3 订单分页查询
      3.3.1 Service,创建接口和实现类

      在这里插入图片描述

      在这里插入图片描述

      package com.itzheng.ssm.service;

      import com.itzheng.ssm.domain.Orders;

      import java.util.List;

      public interface IOrdersService {

      public List findAll(int page, int pageSize) throws Exception;

      }

      实现类当中

      在这里插入图片描述

      package com.itzheng.ssm.service.impl;

      import com.github.pagehelper.PageHelper;

      import com.itzheng.ssm.dao.IOrdersDao;

      import com.itzheng.ssm.domain.Orders;

      import com.itzheng.ssm.service.IOrdersService;

      import org.springframework.beans.factory.annotation.Autowired;

      import org.springframework.stereotype.Service;

      import org.springframework.transaction.annotation.Transactional;

      import java.util.List;

      @Service

      @Transactional

      public class OrdersServiceImpl implements IOrdersService {

      @Autowired

      IOrdersDao ordersDao;

      @Override

      public List findAll(int page, int pageSize) throws Exception {

      PageHelper.startPage(page, pageSize);

      return ordersDao.findAll();

      }

      }

      3.3.2 Controller

      OrdersController当中

      在这里插入图片描述

      package com.itzheng.ssm.controller;

      import com.github.pagehelper.PageInfo;

      import com.itzheng.ssm.domain.Orders;

      import com.itzheng.ssm.service.IOrdersService;

      import org.springframework.beans.factory.annotation.Autowired;

      import org.springframework.stereotype.Controller;

      import org.springframework.web.bind.annotation.RequestMapping;

      import org.springframework.web.bind.annotation.RequestParam;

      import org.springframework.web.servlet.ModelAndView;

      import java.util.List;

      @Controller

      @RequestMapping(“/orders”)

      public class OrdersController {

      @Autowired

      IOrdersService ordersService;

      @RequestMapping(“/findAll.do”)

      public ModelAndView findAll(@RequestParam(name = “page”, required = true, defaultValue = “1”) int page, @RequestParam(name = “size”, required = true, defaultValue = “4”) int size) throws Exception {

      ModelAndView mv = new ModelAndView();

      List ordersList = ordersService.findAll(page, size);

      //PageInfo就是一个分页Bean

      PageInfo pageInfo=new PageInfo(ordersList);

      mv.addObject(“pageInfo”,pageInfo);

      mv.setViewName(“orders-page-list”);

      return mv;

      }

      }

      3.3.3 运行测试

      在这里插入图片描述

      在这里插入图片描述

      在这里插入图片描述

      设置每页展示的条数

      4.订单详情的查询实现

      4.1 通过id查询
      (1)dao的实现

      IOrdersDao的findById方法

      在这里插入图片描述

      @Select(“select * from orders where id=#{id}”)

      @Results({

      @Result(id=true,column = “id”,property = “id”),

      @Result(column = “orderNum”,property = “orderNum”),

      @Result(column = “orderTime”,property = “orderTime”),

      @Result(column = “orderStatus”,property = “orderStatus”),

      @Result(column = “peopleCount”,property = “peopleCount”),

      @Result(column = “payType”,property = “payType”),

      @Result(column = “orderDesc”,property = “orderDesc”),

      @Result(column = “productId”,property = “product”,one = @One(select =

      “com.itzheng.ssm.dao.IProductDao.findById”)),

      @Result(column = “id”,property = “travellers”,many = @Many(select =

      “com.itzheng.ssm.dao.ITravellerDao.findByOrdersId”)),

      @Result(column = “memberId”,property = “member”,one = @One(select =

      “com.itzheng.ssm.dao.IMemberDao.findById”)),

      })

      Orders findById(String id) throws Exception;

      在这里插入图片描述

      IMemberDao的findById方法

      在这里插入图片描述

      ITravellerDao.findByOrdersId方法

      在这里插入图片描述

      package com.itzheng.ssm.dao;

      import com.itzheng.ssm.domain.Traveller;

      import org.apache.ibatis.annotations.Select;

      import java.util.List;

      public interface ITravellerDao {

      @Select(“select * from traveller where id in (select travellerId from order_traveller where orderId=#{ordersId})”)

      List findByOrdersId(String ordersId) throws Exception;

      }

      (2)Service的实现

      在这里插入图片描述

      Orders findById(String ordersId) throws Exception ;

      在这里插入图片描述

      @Override

      public Orders findById(String ordersId) throws Exception {

      return ordersDao.findById(ordersId);

      }

      (3)在OrdersController当中创建findById方法

      在这里插入图片描述

      @RequestMapping(“/findById.do”)

      public ModelAndView findById(@RequestParam(name = “id”,required = true) String ordersId) throws Exception {

      ModelAndView mv = new ModelAndView();

      Orders orders = ordersService.findById(ordersId);

      mv.addObject(“orders”,orders);

      mv.setViewName(“orders-show”);

      return mv;

      }

      (4)创建orders-show.jsp

      在这里插入图片描述

      <%@ page language=“java” contentType=“text/html; charset=UTF-8”

      pageEncoding=“UTF-8”%>

      <%@ taglib uri=“http://java.sun.com/jsp/jstl/core” prefix=“c”%>

      数据 - AdminLTE2定制版

      <meta

      content=“width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no”

      name=“viewport”>

      href=“${pageContext.request.contextPath}/plugins/bootstrap-datetimepicker/bootstrap-datetimepicker.min.css”>

      href=“${pageContext.request.contextPath}/plugins/bootstrap/css/bootstrap.min.css”>

      href=“${pageContext.request.contextPath}/plugins/font-awesome/css/font-awesome.min.css”>

      href=“${pageContext.request.contextPath}/plugins/ionicons/css/ionicons.min.css”>

      href=“${pageContext.request.contextPath}/plugins/iCheck/square/blue.css”>

      href=“${pageContext.request.contextPath}/plugins/morris/morris.css”>

      href=“${pageContext.request.contextPath}/plugins/jvectormap/jquery-jvectormap-1.2.2.css”>

      href=“${pageContext.request.contextPath}/plugins/datepicker/datepicker3.css”>

      href=“${pageContext.request.contextPath}/plugins/daterangepicker/daterangepicker.css”>

      href=“${pageContext.request.contextPath}/plugins/bootstrap-wysihtml5/bootstrap3-wysihtml5.min.css”>

      href=“${pageContext.request.contextPath}/plugins/datatables/dataTables.bootstrap.css”>

      href=“${pageContext.request.contextPath}/plugins/treeTable/jquery.treetable.css”>

      href=“${pageContext.request.contextPath}/plugins/treeTable/jquery.treetable.theme.default.css”>

      href=“${pageContext.request.contextPath}/plugins/select2/select2.css”>

      href=“${pageContext.request.contextPath}/plugins/colorpicker/bootstrap-colorpicker.min.css”>

      href=“${pageContext.request.contextPath}/plugins/bootstrap-markdown/css/bootstrap-markdown.min.css”>

      href=“${pageContext.request.contextPath}/plugins/adminLTE/css/AdminLTE.css”>

      href=“${pageContext.request.contextPath}/plugins/adminLTE/css/skins/_all-skins.min.css”>

      href=“${pageContext.request.contextPath}/css/style.css”>

      href=“${pageContext.request.contextPath}/plugins/ionslider/ion.rangeSlider.css”>

      href=“${pageContext.request.contextPath}/plugins/ionslider/ion.rangeSlider.skinNice.css”>

      href=“${pageContext.request.contextPath}/plugins/bootstrap-slider/slider.css”>

      href=“${pageContext.request.contextPath}/plugins/bootstrap-datetimepicker/bootstrap-datetimepicker.css”>

      <jsp:include page=“header.jsp”></jsp:include>

      <jsp:include page=“aside.jsp”></jsp:include>

      自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

      深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

      因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

      既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

      由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

      如果你觉得这些内容对你有帮助,可以扫码获取!!(资料价值较高,非无偿)

      img

      最后的内容

      在开头跟大家分享的时候我就说,面试我是没有做好准备的,全靠平时的积累,确实有点临时抱佛脚了,以至于我自己还是挺懊恼的。(准备好了或许可以拿个40k,没做准备只有30k+,你们懂那种感觉吗)

      如何准备面试?

      1、前期铺垫(技术沉积)

      程序员面试其实是对于技术的一次摸底考试,你的技术牛逼,那你就是大爷。大厂对于技术的要求主要体现在:基础,原理,深入研究源码,广度,实战五个方面,也只有将原理理论结合实战才能把技术点吃透。

      下面是我会看的一些资料笔记,希望能帮助大家由浅入深,由点到面的学习Java,应对大厂面试官的灵魂追问

      这部分内容过多,小编只贴出部分内容展示给大家了,见谅见谅!

      • Java程序员必看《Java开发核心笔记(华山版)》

      • Redis学习笔记

      • Java并发编程学习笔记

      四部分,详细拆分并发编程——并发编程+模式篇+应用篇+原理篇

      • Java程序员必看书籍《深入理解 ava虚拟机第3版》(pdf版)

      • 大厂面试必问——数据结构与算法汇集笔记

      其他像Spring,SpringBoot,SpringCloud,SpringCloudAlibaba,Dubbo,Zookeeper,Kafka,RocketMQ,RabbitMQ,Netty,MySQL,Docker,K8s等等我都整理好,这里就不一一展示了。

      2、狂刷面试题

      技术主要是体现在平时的积累实用,面试前准备两个月的时间再好好复习一遍,紧接着就可以刷面试题了,下面这些面试题都是小编精心整理的,贴给大家看看。

      ①大厂高频45道笔试题(智商题)

      ②BAT大厂面试总结(部分内容截图)

      ③面试总结

      3、结合实际,修改简历

      程序员的简历一定要多下一些功夫,尤其是对一些字眼要再三斟酌,如“精通、熟悉、了解”这三者的区别一定要区分清楚,否则就是在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:

      以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。

      另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。
      《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
      果你觉得这些内容对你有帮助,可以扫码获取!!(资料价值较高,非无偿)**

      img

      最后的内容

      在开头跟大家分享的时候我就说,面试我是没有做好准备的,全靠平时的积累,确实有点临时抱佛脚了,以至于我自己还是挺懊恼的。(准备好了或许可以拿个40k,没做准备只有30k+,你们懂那种感觉吗)

      如何准备面试?

      1、前期铺垫(技术沉积)

      程序员面试其实是对于技术的一次摸底考试,你的技术牛逼,那你就是大爷。大厂对于技术的要求主要体现在:基础,原理,深入研究源码,广度,实战五个方面,也只有将原理理论结合实战才能把技术点吃透。

      下面是我会看的一些资料笔记,希望能帮助大家由浅入深,由点到面的学习Java,应对大厂面试官的灵魂追问

      这部分内容过多,小编只贴出部分内容展示给大家了,见谅见谅!

      • Java程序员必看《Java开发核心笔记(华山版)》

      [外链图片转存中…(img-erEMzM7F-1711625472298)]

      • Redis学习笔记

      [外链图片转存中…(img-ukWfdWQn-1711625472298)]

      • Java并发编程学习笔记

      四部分,详细拆分并发编程——并发编程+模式篇+应用篇+原理篇

      [外链图片转存中…(img-W04G1kuh-1711625472298)]

      • Java程序员必看书籍《深入理解 ava虚拟机第3版》(pdf版)

      [外链图片转存中…(img-brHQ63Ba-1711625472298)]

      • 大厂面试必问——数据结构与算法汇集笔记

      [外链图片转存中…(img-Q1sHsKI8-1711625472298)]

      其他像Spring,SpringBoot,SpringCloud,SpringCloudAlibaba,Dubbo,Zookeeper,Kafka,RocketMQ,RabbitMQ,Netty,MySQL,Docker,K8s等等我都整理好,这里就不一一展示了。

      [外链图片转存中…(img-UmkECfCX-1711625472299)]

      2、狂刷面试题

      技术主要是体现在平时的积累实用,面试前准备两个月的时间再好好复习一遍,紧接着就可以刷面试题了,下面这些面试题都是小编精心整理的,贴给大家看看。

      ①大厂高频45道笔试题(智商题)

      [外链图片转存中…(img-OuMBi78H-1711625472299)]

      ②BAT大厂面试总结(部分内容截图)

      [外链图片转存中…(img-8qf1kFbj-1711625472299)]

      [外链图片转存中…(img-e9hZFAwr-1711625472299)]

      ③面试总结

      [外链图片转存中…(img-xQvpXLxf-1711625472299)]

      [外链图片转存中…(img-tgVckIOG-1711625472299)]

      3、结合实际,修改简历

      程序员的简历一定要多下一些功夫,尤其是对一些字眼要再三斟酌,如“精通、熟悉、了解”这三者的区别一定要区分清楚,否则就是在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:

      [外链图片转存中…(img-JlHLbdbR-1711625472300)]

      以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。

      另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。
      《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

    • 22
      点赞
    • 15
      收藏
      觉得还不错? 一键收藏
    • 0
      评论

    “相关推荐”对你有帮助么?

    • 非常没帮助
    • 没帮助
    • 一般
    • 有帮助
    • 非常有帮助
    提交
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值