当前位置: 首页 > 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.cnnetsun.cn/news/2995141.html

相关文章:

  • 深度解构PDFPatcher:.NET生态下的PDF处理技术实现内幕
  • 如何快速搭建Arduino ESP32开发环境:新手完整指南
  • NVIC_SYSTEMRESET失败卡死
  • 6.24线上DevCon预约:OpenVINO™开源AI朋友圈,等你来加入
  • RTranslator离线翻译模型快速部署终极指南:告别漫长下载,5分钟完成安装
  • HarmonyOS ArkUI 自定义跑道布局:CustomMultiChildLayout 模式深度实践
  • Emscripten如何重塑Web技术栈:从原生代码到WebAssembly的战略架构迁移
  • 如何用Globe.GL打造惊艳的3D地球数据可视化:从零到一的实战指南
  • 36氪新浪潮大会:值得买科技朱越分享AI时代消费决策链路变化与品牌应对策略
  • 易元智创APP:AI智能画面去杂物,海南易元现实科技有限公司一键净化实拍场景
  • linux内核中阶梯判断switch-case的一种罕见用法(连续阶梯值的情况)
  • 简单代码审计
  • 为什么现在所有大厂都在做 CLI ?(附Cluade Code接入飞书CLI教程)
  • 进程、线程、协程与Java虚拟线程
  • Dify、Cursor、Chatbox、Cherry Studio 怎么统一接入:Base URL、模型 ID 和 API Key 验收清单
  • 卵巢早衰备孕还有机会吗
  • 用 Typeoff 口述代码思路:从原始想法到结构化 Markdown
  • AVR单片机内部温度传感器校准指南:从原理到单点/两点校准实践
  • XMEGA A3BU嵌入式开发实战:低功耗、高精度ADC与时钟系统深度优化
  • ATtiny88 SPI与TWI通信接口:寄存器级配置与实战避坑指南
  • 嵌入式安全芯片HAL层开发指南:从CryptoAuthLib原理到STM32实战
  • ATmega单片机端口复用:从GPIO到SPI/ADC/中断的实战配置与冲突解决
  • ATmega164P/324P/644P嵌入式实战:选型、低功耗与汽车级应用
  • CD5283/CD5314电流调节器芯片:从恒流原理到PCB设计实战
  • 备孕期为什么要补充维生素b?高仕星维生素b帮你打好营养基础
  • Curiosity Nano Base硬件平台:标准化连接如何提升嵌入式开发效率
  • ARM7TDMI编程模型与Thumb指令集:嵌入式开发的底层基石
  • 天峰律政代表的合规公关派正在重塑行业服务标准
  • KA Music:酷狗概念版纯净轻量替代品,无损音质免费畅听
  • Go语言的sync.Map条件操作