当前位置: 首页 > news >正文

web作业七

一、三层架构

1.controller:接受请求,响应数据

service:业务逻辑层,处理业务逻辑,接口实现。在service中要创建dao层对象,才能拿到返回数据

dao:数据访问层,负责数据访问操作(增删改查),面向接口的方式

三层架构请求流程:前端发起请求,controller接收请求后调用service进行逻辑处理,service调用dao层,dao调用数据,将数据返回给service,service进行逻辑处理,再将结果返回给controller,controller响应给前端。

Dao层实现类

package com.example.third.dao.impl; import java.util.List; import com.example.third.dao.EmpDao; import com.example.third.pojo.Emp; import com.example.third.utils.XmlParserUtils; //EmpDaoA是EmpDao接口的一个实现类, public class EmpDaoA implements EmpDao { //加载并解析xml文件,获取Emp对象列表,直接使用相对路径来指定xml文件的位置 @Deprecated public List<Emp> listEmp() { String file = "no6/third/src/main/resources/emp.xml"; System.out.println("file:"+file); List<Emp> empList = XmlParserUtils.parse(file, Emp.class); return empList;//调用XmlParserUtils工具类的parse方法,传入xml文件路径和Emp类的Class对象,返回一个Emp对象列表 } }

Dao层接口

package com.example.third.dao; import java.util.List; import com.example.third.pojo.Emp; //EmpDao接口定义了一个方法listEmp(),用于获取员工信息的列表。 public interface EmpDao { //EmpDao接口定义了一个方法listEmp(),用于获取员工信息的列表。这个接口是一个数据访问对象(DAO)接口,负责与数据源进行交互,获取员工信息的数据。 List<Emp> listEmp(); }

二、分层解耦

1.内聚:软件中各个功能模块内部的功能联系

2.耦合:衡量软件中各个层/模块之间的依赖、关联程度,关联度越高,耦合度越高

eg、controller中创建了service类,改变service就要改变controller的代码,二者之间耦合

低耦合高内聚

3.分层解耦

创建service对象放到一个容器中,controller只需要在容器中查找对应的对象,即可完成对象

(1)控制反转(IOC):对象创建的控制权由程序自身转移到容器。在类上加上@Component注解,将当前类交给IOC容器管理。

声明bean的注解@Compoent@Controller(标注在控制器上)@Service(标注在业务类上)@Respostory(标注在数据访问类上)。

@componet(value+“名字”)为bean命名,默认首字母小写

(2)依赖注入(DI):容器为应用程序提供运行时所依赖的资源。在对象前加上@Autowired注解·,运行时IOC容器会提供该类型对象,并赋值给对应变量

(3)Bean是对象(bean):IOC容器中创建、管理的对象

三、Mybatis

1.对教案中的user表进行增删改查的mapper和test测试文件

UserMapperTest.java

package com.example.mybatis01; import com.example.mybatis01.mapper.UserMapper; import com.example.mybatis01.pojo.User; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.junit.jupiter.api.Test; import java.util.List; @SpringBootTest // 这个注解让测试类能启动Spring容器 public class UserMapperTest { @Autowired // 把UserMapper自动注入进来,方便我们调用 private UserMapper userMapper; // 测试1:查询所有 @Test public void testList() { List<User> list = userMapper.list(); System.out.println("===== 查询所有用户 ====="); for (User user : list) { System.out.println(user); } } // 测试2:根据ID查询 @Test public void testGetById() { User user = userMapper.getById(1); System.out.println("===== 查询ID为1的用户 ====="); System.out.println(user); } // 测试3:新增用户 @Test public void testInsert() { User user = new User(); user.setName("令狐冲"); user.setAge((short) 28); user.setGender((short) 1); user.setPhone("13912345678"); int rows = userMapper.insert(user); System.out.println("===== 新增用户 ====="); System.out.println("影响行数:" + rows); System.out.println("生成的新ID:" + user.getId()); } // 测试4:修改用户(把ID为1的名字改一下) @Test public void testUpdate() { User user = new User(); user.setId(1); user.setName("白眉大侠"); // 把原来叫白眉鹰王的改成白眉大侠 user.setAge((short) 55); user.setGender((short) 1); user.setPhone("18800000000"); int rows = userMapper.update(user); System.out.println("===== 修改用户 ====="); System.out.println("影响行数:" + rows); } // 测试5:删除用户(删除ID为7的用户,如果ID不存在就报错) @Test public void testDelete() { int rows = userMapper.delete(7); System.out.println("===== 删除用户 ====="); System.out.println("影响行数:" + rows); } }

UserMapper.java

package com.example.mybatis01.mapper; import com.example.mybatis01.pojo.User; import org.apache.ibatis.annotations.*; import java.util.List; @Mapper public interface UserMapper { // 1. 查询所有用户 @Select("select id, name, age, gender, phone from [dbo].[user]") List<User> list(); // 2. 根据id查询 @Select("select id, name, age, gender, phone from [dbo].[user] where id = #{id}") User getById(Integer id); // 3. 新增用户(id自增,不传id) @Insert("insert into [dbo].[user](name, age, gender, phone) values(#{name}, #{age}, #{gender}, #{phone})") @Options(useGeneratedKeys = true, keyProperty = "id") // 返回自增id int insert(User user); // 4. 修改用户 @Update("update [dbo].[user] set name=#{name}, age=#{age}, gender=#{gender}, phone=#{phone} where id=#{id}") int update(User user); // 5. 删除用户 @Delete("delete from [dbo].[user] where id = #{id}") int delete(Integer id); }

2.实体类改成lombok来实现

(1)在pom.xml中添加 Lombok 依赖

(2)给 VS Code 装Lombok Annotations Support插件

(3)user.java代码

package com.example.mybatis01.pojo; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @Data // 这个注解会自动生成:getter/setter、toString、equals、hashCode @NoArgsConstructor // 生成无参构造方法 @AllArgsConstructor // 生成全参构造方法 public class User { private Integer id; private String name; private Short age; private Short gender; private String phone; }
http://www.jsqmd.com/news/1070184/

相关文章:

  • 如何用AI驱动市场调研工具last30days-skill实现数据驱动的商业决策
  • 如何在PC上轻松运行3DS游戏:Citra模拟器全面实用指南
  • AI 浏览器 Tabbit 实测:Agent 模式如何操作网页,以及多模型接入方案
  • 每天运营Instagram,却始终0客户咨询?
  • 苹果电脑录屏怎么带声音?3 种实用方法
  • Spring Boot原生集成Nacos的3种方式
  • 中国古代的科技之谜——图灵竟是老子转世,而C++里藏着“道”的源代码
  • RTranslator离线翻译模型快速部署终极指南:告别漫长下载,5分钟完成安装
  • 大模型应用开发 · 极速学习手册
  • 如何免费获取国家教育平台电子课本:终极离线使用指南
  • 设计师AI创意工具选型指南(2024年Q2权威评测版):基于87家设计团队、1268小时工作流埋点分析
  • Serenity-skill解决方案:构建AI驱动的供应链瓶颈投资研究系统
  • 深度解析mpv命令行播放器:如何在Intel UHD显卡上实现4K/8K超高清流畅播放
  • 终极指南:如何免费让2007-2015年老款Mac焕发新生
  • GLM-5.2 深度解读:智谱新一代旗舰模型,如何重新定义开源大模型的性能边界?
  • 深度解析游戏逆向工程:AES加密破解与模组开发实战指南
  • 火山引擎 FORCE 大会开幕,豆包大模型 1.8 发布,Seedance 月入 10 亿
  • 3分钟学会:如何一键下载国家中小学智慧教育平台电子课本
  • Pingora 深度解析:Cloudflare 下一代 Rust 高性能代理
  • Agent 的工具是如何被大模型使用的
  • 本地部署ChatGLM3、Qwen2、DeepSeek-V3全栈实操:手把手配置CUDA 12.4+Triton+vLLM,3步实现吞吐翻倍、延迟压至87ms
  • Windows系统管理终极指南:Chris Titus Tech WinUtil一键搞定所有烦恼
  • 终极指南:如何在Intel UHD显卡上配置MPV实现4K视频流畅播放
  • 普通软件接入 AI API 的完整方案:功能设计、接口封装、鉴权配置与常见排错
  • 设置目标IP的端口是否开放
  • 遥感水环境智能监测:从数据预处理到AI反演的60个实战案例
  • 联想百应AI主机300 vs ibbot青春版:当26999元的本地工作站遇到1999元的AI手机,谁更懂AI原生时代?
  • 5分钟掌握Chatterbox:开源语音合成的完整实践指南
  • Pose-Search:用人体姿态解锁图像搜索的终极指南
  • PyPDF终极指南:Python中最强大的PDF处理库完全解析