JavaWeb之综合案例
前言
这一节讲一个案例
1. 环境搭建
然后就是把这些数据全部用到sql语句中执行
2.查询所有-后台&前台
我们先写后台代码
2.1 后台
2.2 Dao
BrandMapper:
注意因为数据库里面的名称是下划线分割的,我们类里面是驼峰的,所以要映射
这里我们已经写好了
BrandMapper:
@Select("select * from tb_brand ")@ResultMap("brandResultMap")List<Brand> selectAll();
2.3 services
这下写这个我们先写一个接口,再写实现类
这个services要被servlet调用,所以我们在写servlet
以前是要在这里面创建一个services的类
现在我们就可以用接口指向实现类
BrandServiceImpl:
这个service我们就写完了
现在开始写servlet
SelectAllServlet:
运行一下试一下
现在开始写前端代码
页面加载完成之后发送异步请求—》有mounted
brand.html:原:
现在:
这样我们就写好了
刚好48条我们就做好了
3. 新增品牌
BrandMapper:
BrandService:
BrandServiceImpl:
AddServlet:
下面开始写前端代码
brand.html:
这里是提交按钮,提交以后就会调用addBrand方法
开始修改
结果发现点了提交没有反应,f12一下
发现我们数据是添加成功了的
问题主要是我们一个用下划线的this
关闭是关闭了,但是我们下面的数据没有显示完全
因为我们只是关闭的窗口,这个brand.html没有刷新的
所以我们的代码那里要重新查询一下
但是这个方法我们已经写过了,所以我们定义一个方法来专门存储
这样就可以了
这样就可以了
这样我们不刷新也有了
接下来我们在做一个小功能,就是新增完成之后,有一个新增成功的提示框
我们就要这个消息提示
4. Servlet代码优化
一个功能写一个servlet感觉不太好,这样写的太多了
这样的话就意味着,会有很多的请求路径来访问servlet,但是我们@WebServlet(“/addServlet”)这样写就写死了,就只能添加了
但是还有一个问题,就是我们的servlet只能执行doget和dopost,但我们要写我们自定义的方法,怎么办呢
所以就不能继承HttpServlet了
BaseServlet:
然后我们在定义一个brandSrvlet,它就继承我们定义的这个servlet就可以了,不用继承HttpServlet
BaseServlet:
写的这个/brand/SelectAll
但还是要先去执行BaseServlet中的service方法
这里的后面的参数就是执行方法的参数
执行方法的参数是什么呢,就是response和request
我们丰富一下
这样我们就写完了
接下来我们完成真正的功能
BrandServlet:
就把原来servlet里面的代码考过去就可以了
然后修改页面的访问路径
brand.html:
然后注释掉
5. 批量删除
Dao:
BrandMapper:
BrandMapper.xml:
这里问号该有几个呢—》动态sql拼接
service:
BrandService:
BrandServiceImpl:
BrandServlet:
brand.html:
批量删除在这里
然后绑定一个单击事件
然后写出方法
这个是我们选中的复选框,之后会把数据放在这个模型里面
我们来试一下
看有没有我们选中的数据
我们来复制一下
就是这个样子
可以看出,这就是一个数组,里面是一个一个brand对象
我们需要的是id
我们增加一个id的模型数据
这样我们就写完了
但是我们点了删除没有反应
f12
看一下报错,就知道了,sql语句有问题
BrandMapper.xml:
我们发现了问题就是where后面少写了id
这样就成功了
点删除的话,我们应该提示一下,是否要这样操作,不然误操作了
这里确定就执行then的逻辑,取消就执行catch的逻辑
brand.html:
这样就可以了
6. 分页查询
6.1 分析
要分页查询的话,数据库里面也要分页查询
我们先来创建pageBean
6.2 实现
BrandMapper:
BrandService:
BrandServiceImpl:
BrandServlet:
测试一下:
现在开始写前端代码
我们要改造这个方法,因为我们只需要查询一页就可以了
注意我们resp获取出来的数据是一个大类
测试一下,发现有错,主要是因为我们的selectByPage没有写ResultMap,添加上去就可以了
但是还不能翻页
现在我们改一下共400条那里
因为这里我们写的是400
改一下,写成模型数据
我们在selectAll中设置这个模型值
但是这里默认显示的是4页,我们也改一下
原因就是因为这里的currentPage,这里默认是4
改为1
现在我们应该点完页码数据就应该产生变化
这里就要看上面的两个方法了
size-change是每页显示条数发生变化,执行的代码
current-change是当前页码发生变化显示条数
我们给这里的currentPage写成动态的,会变化的
这样就可以了
然后添加模型数据
这样就可以了
这样就可以动态变化了
然后在修改另一个方法
这里是可以输入修改的,但是不能用数字键盘
7. 条件查询
7.1后台
BrandMapper:
BrandMapper.xml:
第一个sql语句我们就写完了
第二个和第一个就比较类似了
因为我们第二个sql语句的方法只有一个参数,所以没有param注解,所以不用brand.来
然后我们ctrl+r整体替换就可以了
BrandService:
BrandServiceImpl
BrandServlet:
分页还好传递,通过get来就是url
但是brand条件怎么传递呢
brand.html:
原:
我们这里增加一个data这个JSON数据,我们既有url参数,也有请求体里面的参数,请求体的参数获取—》就可以获取条件了
BrandServlet:
7.2 前端
查询条件我们也要绑定一个对象模型
这里其实我们都绑定上了
我们先给这个按钮绑定一个单击事件
已经有了
发现并没有错
然后修改selectAll
注意还要修改一下我们访问的方法名
但是我们运行出来会报错
我们发现是动态sql的问题
为什么会这样呢,经过我的仔细检查,发现错误就是
就是动态sql那里不能写注释,写了注释就要出错,改了就没事了
这个没有带条件的查询的就是全部
现在我们优化一下,就是当前状态那里改为启用和禁用
Brand实体类里面有一个逻辑视图,就是这个就可以了
这里就是那个状态的展示
我们改一下
这个就是逻辑视图的妙
8. 前端代码优化
如果里面能直接写this就很方便了
这样写就相当于lambda表达式,里面就不用写_this了
总结
以后开始讲SSM了
相关文章:

JavaWeb之综合案例
前言 这一节讲一个案例 1. 环境搭建 然后就是把这些数据全部用到sql语句中执行 2.查询所有-后台&前台 我们先写后台代码 2.1 后台 2.2 Dao BrandMapper: 注意因为数据库里面的名称是下划线分割的,我们类里面是驼峰的,所以要映射 …...

MySQL 报错:1137 - Can‘t reopen table
MySQL 报错:1137 - Can’t reopen table 1. 问题 对临时表查询: select a.ts_code,a.tsnum,b.tsnum from (select t.ts_code ,count(*) tsnum from tmp_table t group by t.ts_code having count(*) > 20 and count(*)< 50 ) a ,(select t.ts_…...

Claude3.5-Sonnet和GPT-4o怎么选(附使用链接)
随着人工智能模型的不断进化,传统的评估标准已经逐渐变得陈旧和不再适用。以经典的“喝水测试”为例,过去广泛应用于检测模型能力,但现如今即便是国内的一些先进模型,也能够轻松答对这些简单的问题。因此,我们亟需引入…...

使用itextpdf进行pdf模版填充中文文本时部分字不显示问题
在网上找了很多种办法 都解决不了; 最后发现是文本域字体设置出了问题; 在这不展示其他的代码 只展示重要代码; 1 引入扩展包 <dependency><groupId>com.itextpdf</groupId><artifactId>itext-asian</artifactId><version>5.2.0</v…...

java-贪心算法
1. 霍夫曼编码(Huffman Coding) 描述: 霍夫曼编码是一种使用变长编码表对数据进行编码的算法,由David A. Huffman在1952年发明。它是一种贪心算法,用于数据压缩。霍夫曼编码通过构建一个二叉树(霍夫曼树&a…...

OpenCV和Qt坐标系不一致问题
“ OpenCV和QT坐标系导致绘图精度下降问题。” OpenCV和Qt常用的坐标系都是笛卡尔坐标系,但是细微处有些不同。 01 — OpenCV坐标系 OpenCV是图像处理库,是以图像像素为一个坐标位置,即一个像素对应一个坐标,所以其坐标系也叫图像…...

前端VUE项目启动方式
将VUE项目的前端项目运行起来,整个过程非常简单,预计5分钟就可以完成,取决于大家的网速。 项目运行先安装Node.js Windows 安装 Node.js 指南:http://www.iocoder.cn/NodeJS/windows-install(opens new window) Mac 安装 Node.js…...

Python小白学习教程从入门到入坑------习题课5(基础巩固)
目录 实战题 1、“千年虫”是什么虫? 2、模拟京东购物流程 3、模拟12306火车票订票流程 4、模拟手机通讯录 实战题 1、“千年虫”是什么虫? 要求:已知一个列表中存储的是员工的出生年份 [88,89,90,98,00,99] 由于时间比较久,出生的年份均为2位整数…...

飞凌嵌入式T113-i开发板RISC-V核的实时应用方案
随着市场对嵌入式设备的功能需求越来越高,集成了嵌入式处理器和实时处理器的主控方案日益增多,以便更好地平衡性能与效率——实时核负责高实时性任务,A核处理复杂任务,两核间需实时交换数据。然而在数据传输方面,传统串…...

基于Java后台实现百度、高德和WGS84坐标的转换实战
目录 前言 一、需求的缘由 1、百度坐标拾取 2、高德坐标拾取 3、不同地图的坐标展示 二、后端坐标偏移转换处理 1、相关类库介绍 2、coordtransorm类图介绍 3、后台实际转换 三、总结 前言 在当今数字化时代,地理位置信息的精确性和实时性对于各种应用至…...

SQL,力扣题目1635,Hopper 公司查询 I
一、力扣链接 LeetCode_1635 二、题目描述 表: Drivers ---------------------- | Column Name | Type | ---------------------- | driver_id | int | | join_date | date | ---------------------- driver_id 是该表的主键(具有唯一值的列)。 该表的每一行…...

Android 分区相关介绍
目录 一、MTK平台 1、MTK平台分区表配置 2、MTK平台刷机配置表 3、MTK平台分区表配置不生效 4、Super分区的研究 1)Super partition layout 2)Block device table 二、高通平台 三、展锐平台 四、相关案例 1、Super分区不够导致编译报错 经验…...

JMeter监听器与压测监控之 InfluxDB
1. 简介 在本文中,我们将介绍如何在 Kali Linux 上通过 Docker 安装 InfluxDB,并使用 JMeter 对其进行性能监控。InfluxDB 是一个高性能的时序数据库,而 JMeter 是一个开源的性能测试工具,可以用于对各种服务进行负载测试和性能监…...

信息安全管理与评估赛项(网络安全)--应急响应专项训练
web1 题目来源:https://mp.weixin.qq.com/s/89IS3jPePjBHFKPXnGmKfA 题目 1.攻击者的shell密码2.攻击者的IP地址3.攻击者的隐藏账户名称4.攻击者挖矿程序的矿池域名(仅域名)5.有实力的可以尝试着修复漏洞靶机 用户:administrator密码:Zgsfadmin.com题解 攻击者…...

ElasticSearch学习篇18_《检索技术核心20讲》LevelDB设计思想
目录 一些常见的设计思想以及基于LSM树的LevelDB是如何利用这些设计思想优化存储、检索效率的。 几种常见的设计思想 索引和数据分离减少磁盘IO读写分离分层思想 LevelDB的设计思想 读写分离设计分层设计与延迟合并LRU缓存加速检索 几种常见设计思想 索引与数据分离 索引…...

使用 FFmpeg 提取音频的详细指南
FFmpeg 是一个开源的多媒体处理工具,支持视频、音频的编码、解码、转换等多种功能。通过 FFmpeg,提取视频中的音频并保存为各种格式非常简单和高效。这在音视频剪辑、媒体处理、转码等场景中具有广泛的应用。 本文将详细讲解如何使用 FFmpeg 提取音频&a…...

中国省级新质生产力发展指数数据(任宇新版本)2010-2023年
一、测算方式:参考C刊《财经理论与实践》任宇新(2024)老师的研究,新质生产力以劳动者劳动资料劳动对象及其优化组合的质变为 基本内涵,借 鉴 王 珏 和 王 荣 基 的 做 法构建新质生产力发展水平评价指标体系如下所示&a…...

C++设计模式:建造者模式(Builder) 房屋建造案例
什么是建造者模式? 建造者模式是一种创建型设计模式,它用于一步步地构建一个复杂对象,同时将对象的构建过程与它的表示分离开。简单来说: 它将复杂对象的“建造步骤”分成多部分,让我们可以灵活地控制这些步骤。通过…...

Python 快速入门(上篇)❖ Python基础知识
Python 基础知识 Python安装**运行第一个程序:基本数据类型算术运算符变量赋值操作符转义符获取用户输入综合案例:简单计算器实现Python安装** Linux安装: yum install python36 -y或者编译安装指定版本:https://www.python.org/downloads/source/ wget https://www.pyt…...

string接口的模拟实现
文章目录 一. string底层逻辑演示声明和定义分开 二. size()三. operator[]四. 迭代器四. const迭代器五. 预留空间(reserve)六. 尾插一个字符push_back七. 尾插一个字符串append八. operator九. operator 一. string底层逻辑 (1)为了和库里面…...

sed使用扩展正则表达式时, -i 要写在 -r 或 -E 的后面
sed使用扩展正则表达式时, -i 要写在 -r 或 -E 的后面 前言 -r 等效 -E , 启用扩展正则表达式 -E是新叫法,更统一,能增强可移植性 , 但老系统,比如 CentOS-7 的 sed 只能用 -r ### Ubuntu24.04-E, -r, --regexp-extendeduse extended regular expressions in the script(fo…...

Verilog HDL可综合与不可综合语句
目录 什么是逻辑综合 可综合语句 不可综合语句 逻辑综合建模建议 综合流程 什么是逻辑综合 所谓逻辑综合就是在标准单元库和特定的设计约束的基础上,把设计的高层次描述转换成优化的门级网表的过程。 标准单元库(工艺库)可以包含简单的…...

tomcat 后台部署 war 包 getshell
1. tomcat 后台部署 war 包 getshell 首先进入该漏洞的文件目录 使用docker启动靶场环境 查看端口的开放情况 访问靶场:192.168.187.135:8080 访问靶机地址 http://192.168.187.135:8080/manager/html Tomcat 默认页面登录管理就在 manager/html 下,…...

网络云计算】2024第47周-每日【2024/11/21】周考-实操题-RAID6实操解析1
文章目录 1、RAID6配置指南(大致步骤)2、注意事项3、截图和视频 网络云计算】2024第47周-每日【2024/11/21】周考-实操题-RAID6实操 RAID6是一种在存储系统中实现数据冗余和容错的技术,其最多可以容忍两块磁盘同时损坏而不造成数据丢失。RAID…...

前端面试题大汇总:React 篇
基础知识 1. 什么是 React?它的主要特点是什么? React 是一个用于构建用户界面的 JavaScript 库,由 Facebook 开发并维护。它主要用于构建单页应用程序(SPA)和复杂的用户界面。React 的主要特点包括: 组件…...

【prism】遇到一个坑,分享!
背景 我通用prism的方式写了一个弹窗,弹窗绑定一个 Loaded 事件,但是Loaded事件一直不触发!!! 具体过程 我的loaded事件也是通过命令的方式绑定的: <i:Interaction.Triggers><i:EventTrigger EventName="Loaded...

Python+Selenium+Pytest+Allure+ Jenkins webUI自动化框架
Python+Selenium+Pytest+Allure+ Jenkins webUI自动化框架 WebUI接口框架使用的工具...

智象未来(HiDream.ai)技术赋能,开启AR眼镜消费时代
Rokid Jungle 2024合作伙伴暨新品发布会于近日隆重举行,标志着AR眼镜跑步进入消费时代,更预示着ARAI技术融合的新篇章。智象未来(HiDream.ai),作为多模态生成式人工智能技术的领跑者,与Rokid的深度合作&…...

element dialog 2层弹窗数据同步问题
注意:本帖为公开技术贴,不得用做任何商业用途 element dialog 2层弹窗数据同步问题 如果嵌套dialog,也就是多层dialog嵌套 2个input,key用同样的值 会导致内外2层dialog,用相同key值的input会数据同步 原因如下&a…...

向量数据库FAISS之五:原理(LSH、PQ、HNSW、IVF)
1.Locality Sensitive Hashing (LSH) 使用 Shingling MinHashing 进行查找 左侧是字典,右侧是 LSH。目的是把足够相似的索引放在同一个桶内。 LSH 有很多的版本,很灵活,这里先介绍第一个版本,也是原始版本 Shingling one-hot …...