每日面经分享(Spring Boot: part2 DAO层)

1. Spring Boot DAO层的作用

a. 封装数据访问逻辑:DAO层的主要责任是封装与数据访问相关的逻辑。负责处理与数据库的交互,包括数据的增删改查等操作。通过将数据访问逻辑统一封装在DAO层中,可以提高代码的可维护性和可重用性。
b. 解耦业务逻辑和数据访问逻辑:通过将数据访问逻辑放在DAO层中,可以将业务逻辑与数据访问逻辑解耦。业务逻辑层可以通过调用DAO层提供的方法来获取和操作数据,而不需要关心具体的数据访问细节。实现业务逻辑与数据访问逻辑的独立开发和测试(松散耦合,面试常见问题)。
c. 提供数据持久化和查询的接口:DAO层包含一组接口,定义对数据进行持久化和查询的方法。提供对数据的CRUD操作,以及自定义查询方法的定义。通过这些接口,业务逻辑层可以方便地调用DAO层的方法进行数据的持久化和查询。
d. 提供事务管理支持:DAO层还负责管理数据访问操作的事务。通过在DAO层的方法上使用@Transactional注解,可以实现对数据库操作的事务性管理。优点:在多个数据库操作中,如果其中一个操作失败,整个事务可以回滚,确保数据的一致性。

2. Spring Boot DAO层的搭建过程

a. 创建实体类:根据数据库表的结构创建与之对应的实体类。使用注解来映射实体类和数据库表以及属性和字段的关系。

@Entity
@Table(name = "my_table")
public class MyEntity {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;@Column(name = "column_name")private String columnName;// Getters and setters
}

b. 创建Repository接口:创建一个接口来定义对实体类进行持久化和查询的方法。可以使用Spring Data JPA提供的一组默认方法,也可以自定义查询方法(按需)。

@Repository
public interface MyRepository extends JpaRepository<MyEntity, Long> {// 自定义查询方法List<MyEntity> findByColumnName(String columnName);
}

c. 注入Repository:在需要使用数据访问的地方,使用依赖注入的方式注入Repository接口。

@Service
public class MyService {private final MyRepository myRepository;@Autowiredpublic MyService(MyRepository myRepository) {this.myRepository = myRepository;}// 使用myRepository执行数据访问操作
}

3. 搭建DAO层的注意事项

a. 定义数据访问接口:除了使用Spring Data JPA提供的默认方法外,可以在Repository接口中定义自己的数据访问方法。
b. 实现自定义查询方法:在Repository接口中定义自定义查询方法后,可以在实现类中提供相应的方法实现。实现类可以使用EntityManager或JdbcTemplate等来执行自定义查询,并将结果映射到实体类中,方便灵活地执行复杂的查询操作。

@Repository
public interface MyRepository extends JpaRepository<MyEntity, Long> {// 自定义查询方法List<MyEntity> findByColumnName(String columnName);
}

c. 关联关系处理:如果数据库中存在多个表,并且这些表之间存在关联关系,可以使用注解来处理关联关系。例如,使用@OneToOne、@OneToMany、@ManyToOne、@ManyToMany等注解来定义实体类之间的关联关系,这有利于在查询数据时方便地处理关联数据。
d. 事务管理:在DAO层进行数据库操作时,需要使用事务管理来确保数据的一致性和完整性。在DAO层的方法上使用@Transactional注解来启用事务管理。在方法执行期间,如果发生异常或错误,事务会回滚,保证数据的原子性操作。

@Repository
@Transactional
public interface MyRepository extends JpaRepository<MyEntity, Long> {// ...
}

e. 单元测试:为确保DAO层的正确性和可靠性,研发需要养成编写单元测试的习惯。使用Spring Boot的测试框架,如JUnit和SpringBootTest,编写针对DAO层方法的测试用例,并验证其功能和预期结果。

互联网大厂测开经历,目前担任测试开发负责人,每天分享互联网面经,如果你有测试相关的问题,欢迎咨询,海鲜市场【简历优化】、【就业指导】、【模拟/辅导面试】,已辅导20位以上同学拿到心仪offer

海鲜市场

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/782309.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pytest--python的一种测试框架--request请求加入headers

一、request headers中的cookie和session机制的作用与区别 Cookie 和 Session 是两种在客户端和服务器之间保持状态的技术。HTTP 协议本身是无状态的&#xff0c;这意味着服务器无法从上一次的请求中保留任何信息到下一次请求。Cookie 和 Session 机制就是为了解决这个问题。 …

Python算法学习

一、排序 排序算法是指将一组数据按照某种规则重新排列&#xff0c;使得数据呈现出递增或递减的顺序。常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序、堆排序等。 1.冒泡排序 解释&#xff1a; 冒泡排序通过不断交换相邻两个元素的位置&#xff0c;使…

dcat笔记

一&#xff0c;修改系统自带的表和页面 环境&#xff1a;laravel9dcat2php8.2 此处我想修改admin_users表&#xff0c;添加一个park_id 关联到parks表&#xff0c;须要修改管理员页面 使用继承重写的思路&#xff0c;最好不要直接去修改vendor包里面的dcat源码&#xff0c;只…

乐观锁的简单感悟

乐观锁&#xff08;Optimistic Locking&#xff09;是一种并发控制机制&#xff0c;用于解决多个线程或进程同时访问共享资源时可能发生的冲突问题。与悲观锁不同&#xff0c;乐观锁假设冲突很少发生&#xff0c;因此不会对整个操作过程进行严格的加锁。 乐观锁的实现方式通常…

Unity 通过鼠标移动和LineRenderer组件实现画线功能

在Unity中&#xff0c;使用LineRenderer组件可以在场景中绘制简单的线条&#xff0c;所以我们要实现通过鼠标移动来绘制线条的功能&#xff0c;可以使用LineRenderer组件实现。 要灵活进行绘制&#xff0c;那么就需要全程使用代码控制&#xff0c;包括线条的创建和基本属性设置…

KingSCADA|问题处理:数据输入后,数据已经写入,但SCADA界面显示为0问题。

哈喽&#xff0c;你好啊&#xff01;我是雷工&#xff01; 最近做KingSCADA项目遇到这么一个问题&#xff1a; KingSCADA系统和三菱的PLC通讯&#xff0c;当数值输入数据需要数据后&#xff0c;输入的数值点击确定按钮可以写入到PLC内&#xff0c;但是点完确定SCADA界面显示0&a…

神经网络 各个模块介绍(Pytorch 07)

一 网络层和块 单个神经网络&#xff08;1&#xff09;接受一些输入&#xff1b;&#xff08;2&#xff09;生成相应的标量输出&#xff1b;&#xff08;3&#xff09;具有一组相关 参数&#xff08;parameters&#xff09;&#xff0c;更新这些参数 可以优化某目标函数。 当…

CSS3 (一)

一、CSS3 2D转换 转换&#xff08;transform&#xff09;是CSS3中具有颠覆性的特征之一&#xff0c;可以实现元素的位移、旋转、缩放等效果。转换&#xff08;transform&#xff09;你可以简单理解为变形。 移动&#xff1a;translate 、旋转&#xff1a;rotate 、缩放&#xf…

MATLAB 点云随机渲染赋色(51)

MATLAB 点云随机渲染赋色(51) 一、算法介绍二、算法实现1.代码2.效果总结一、算法介绍 为点云中的每个点随机赋予一种颜色,步骤和效果如图: 1、读取点云 (ply格式) 2、随机为每个点的RGB颜色字段赋值 3、保存结果 (ply格式) 二、算法实现 1.代码 代码如下(示例):…

pytest--python的一种测试框架--pycharm创建项目并进行接口请求

前言 学习request的使用&#xff0c;在用之前&#xff0c;用官方文档提供的接口&#xff1a;https://api.github.com/events&#xff1b; ctrl鼠标左键可以进入被调用函数源码&#xff0c;可以看到第一个参数URL是必须参数&#xff0c;params是选填&#xff0c;**kwargs是关键…

嵌入式|蓝桥杯STM32G431(HAL库开发)——CT117E学习笔记15:PWM输出

系列文章目录 嵌入式|蓝桥杯STM32G431&#xff08;HAL库开发&#xff09;——CT117E学习笔记01&#xff1a;赛事介绍与硬件平台 嵌入式|蓝桥杯STM32G431&#xff08;HAL库开发&#xff09;——CT117E学习笔记02&#xff1a;开发环境安装 嵌入式|蓝桥杯STM32G431&#xff08;…

css3之2D转换transform

2D转换transform 一.移动&#xff08;translate)(中间用&#xff0c;隔开&#xff09;二.旋转&#xff08;rotate)&#xff08;有单位deg)1.概念2.注意点3.转换中心点&#xff08;transform-origin)&#xff08;中间用空格&#xff09;4.一些例子(css三角和旋转&#xff09; 三…

Spring Boot 使用详解

Spring Boot 使用详解 本节将详细介绍如何使用 Spring Boot。涵盖的主题包括构建系统、自动配置和如何运行应用程序。我们还将讨论一些 Spring Boot 最佳实践。尽管 Spring Boot 没有什么特别之处(它只是您可以使用的另一个库),但遵循以下一些建议会使您的开发过程更加轻松…

基于微信小程序医院挂号系统的设计与实现(论文+源码)_kaic

摘 要 进入21世纪网络和微信小程序得到了飞速发展&#xff0c;并和生活进行了紧密的结合。目前&#xff0c;网络的运行速度以达到了千兆&#xff0c;覆盖范围更是深入到生活中的脚脚落落。这就促使微信小程序的发展。微信小程序可以实现远程处理事务&#xff0c;远程提交工…

深度学习基础模型之Mamba

Mamba模型简介 问题&#xff1a;许多亚二次时间架构(运行时间复杂度低于O(n^2)&#xff0c;但高于O(n)的情况)&#xff08;例如线性注意力、门控卷积和循环模型以及结构化状态空间模型&#xff08;SSM&#xff09;&#xff09;已被开发出来&#xff0c;以解决 Transformer 在长…

mac怎么删除python

mac 默认安装了python2&#xff1b;自己后面又安装了python3&#xff1b;为了方便&#xff0c;现在想将python3换成Anaconda3。 Anaconda是一个开源的Python发行版本&#xff0c;其包含了conda、Python等180多个科学包及其依赖项。 Python3安装之后&#xff0c;在系统中不同目…

40个学习网站合集

1、Google&#xff1a;https://google.com 作为王牌浏览器&#xff0c;相比打开电脑就会进入谷歌浏览器&#xff0c;里面的谷歌搜索很好用。 在这里插入图片描述 2、CSDN— 开发者齐聚的网站&#xff1a;https://www.csdn.net/ CSDN不用多说&#xff0c;老牌专业 IT 技术社区&…

概率论经典题目-二维随机变量及分布--由概率密度求分布函数和概率

解答&#xff1a; 由概率密度函数求解分布函数的公式可知&#xff1a; 辅助图形加以确定积分上下限

酷得单片机方案 2.4G儿童遥控漂移车

电子方案开发定制&#xff0c;我们是专业的 东莞酷得智能单片机方案之2.4G遥控玩具童车具有以下比较有特色的特点&#xff1a; 1、内置充电电池&#xff1a;这款小车配备了可充电的电池&#xff0c;无需频繁更换电池&#xff0c;既环保又方便。充电方式可能为USB充电或者专用…

Linux 给网卡配置ip

ip addr | grep eth9 ifconfig eth9 10.0.0.2 netmask 255.255.255.0 up