DAO模式

前言

DAO(Data Access Object)模式 是一种常用的设计模式,主要用于将数据访问逻辑与业务逻辑分离。它提供了一种抽象层,使得应用程序可以与不同的数据源(如数据库、文件系统等)进行交互,而无需了解底层数据存储的细节。DAO 模式的核心思想是将数据访问操作封装在独立的类中,从而提高代码的可维护性、可扩展性和可重用性。

如何使用DAO模式

1.首先导入这个包(有需要的可以私聊我)然后添加配置文件,为项目添加依赖(具体看要求)

2.创建目录

如果没有问题目录应该是这个样子

>src

 >DAO(软件包)

        >>entity

        >>impl

>Lib

 然后我们在DAO包下创建BaseDao类

我们在这个类里写入数据库驱动

package DAO;import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;public class BaseDao {public static String a;public static String b;public static String c;public static String d;public static Connection conn;static {try {P();} catch (IOException e) {throw new RuntimeException(e);}}public static void P() throws IOException {Properties p =new Properties();InputStream in = BaseDao.class.getClassLoader().getResourceAsStream("jiangchao.properties");p.load(in);a=p.getProperty("a");b=p.getProperty("b");c=p.getProperty("c");d=p.getProperty("d");}public static void C() throws SQLException, ClassNotFoundException {Class.forName(a);conn =DriverManager.getConnection(b,c,d);}
}

附上配置文件参考

a=com.mysql.cj.jdbc.Driver
b=jdbc:mysql://localhost:3306/b?serverTimezone=GMT-8
c=root
d=123456

至此我们完成了第一步,接下来我们创建一个接口(名字看个人)

在接口里写入要用的方法

package DAO;import DAO.entity.Patient;import java.sql.SQLException;
import java.util.List;public interface CeDao {void sc() throws SQLException, ClassNotFoundException;
}

然后我们对着方法名ait+回车

实现方法(这里需要提前在impl里创好类,方便选择)

@Overridepublic void sc() throws SQLException, ClassNotFoundException {C();String sql="DELETE  FROM `checkitem_检查项目表` WHERE checkItemName='心电图';";PreparedStatement pr = conn.prepareStatement(sql);int i = pr.executeUpdate();if (i>0){System.out.println("成功");}else {System.out.println("失败");}}

这里需要记得继承类

public class CeDaoImpl extends BaseDao implements CeDao

调用

public class Text {public static void main(String[] args) throws ClassNotFoundException, SQLException {CeDao c = new CeDaoImpl();c.sc();}}

到这一个简单的DAO模式就完成了

深入一点

先在entity里创类

package DAO.entity;public class Patient {private Integer patientID;private String patientName;public void setPatientID(Integer patientID) {this.patientID = patientID;}public Integer getPatientID() {return patientID;}public void setPatientName(String patientName) {this.patientName = patientName;}public String getPatientName() {return patientName;}}

然后正常接口写方法(我们直接跳过到方法)

@Overridepublic Patient login(String Name, String pwd) throws SQLException, ClassNotFoundException {C();Patient p=new Patient();String sql="SELECT * FROM patient_病人 where patientName = ? and password=?";PreparedStatement pr = conn.prepareStatement(sql);pr.setString(1,Name);pr.setString(2,pwd);ResultSet resultSet = pr.executeQuery();if (resultSet.next()){p.setPatientID(Integer.valueOf(resultSet.getString("patientID")));p.setPatientName(resultSet.getString("patientName"));}return p;}

然后调用

Patient p=c.login("张三","123456");if (p.getPatientID()>0){System.out.println("欢迎"+p.getPatientName());}else {System.out.println("失败");}}

完成了

附上接口代码

Patient login(String Name, String pwd) throws SQLException, ClassNotFoundException;

概念知识

接口一般叫DAO接口,entity里的叫实体类,impl里的是实现类,其实还有一个工厂类(不过我觉得有点可有可无,少打一两句代码而已)

DAO有许多实现方式,我上面的例子是基于JDBC的实现方式,还有基于MyBatis的DAO实现,基于Spring JDBC的DAO实现等

DAO有解耦,提高代码维护性,扩展性,重用性,支持面向接口编程,便于单元测试等优点,但它也有增加了代码的复杂性,性能问题,难以处理复杂查询,需要额外配置,可能掩盖底层数据库细节等缺点

总体而言,DAO模式是一种强大的设计模式,适用于中大型项目,能够有效地管理数据访问操作,提高代码质量和开发效率。然而,在使用DAO模式时,需要根据具体项目需求和团队技术栈进行权衡和优化。

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

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

相关文章

mysql日志写满出现The table ‘xxxx_amazon_order’ is full

数仓发现写数据出现 SQL 错误 [1114] [HY000]: The table ‘xxxx_amazon_order’ is full 1.第一时间查看系统磁盘, 发现空间写满了 df -h因为mysql是使用docker部署的, Docker 的默认存储位置在 /var/lib/docker /var 目录默认是在根分区 (/dev/mapper/centos-root) 下的 …

【读书笔记-《网络是怎样连接的》- 7】Chapter3_2 路由器

本篇继续介绍路由器及其转发过程。 1 路由器内部结构 路由器内部结构图如图所示。 即主要包含左侧的包转发模块和右侧的端口模块。转发模块负责查找包的发送目的地,端口模块完成包的发送。通过安装不同的硬件,转发模块不仅可以支持以太网,也…

P5099 [USACO04OPEN] Cave Cows 4

P5099 [USACO04OPEN] Cave Cows 4https://www.luogu.com.cn/problem/P5099 思路: 这里的垫蹄石之间很明显是有后效性的 所以不能用dp来做 考虑宽搜 我们每次都枚举和这个垫蹄石之间x方向和z方向的距离均不超过2的垫脚石 因为都很大 我们可以使用 代码&#xf…

高阶C语言之六:程序环境和预处理

本文介绍程序的环境,在Linux下对编译链接理解,较为简短,着重在于编译的步骤。 C的环境 在ANSI C(标准C语言)的任何一种实现中,存在两个不同的环境。 翻译环境:在这个环境中,源代码…

【Python数据可视化分析实战】数据爬取—京东手机品牌信息数据爬取和数据分析与可视化

大数据分析设计方案 1.数据集来源:https://search.jd.com 2.实现思路: (1)数据爬取 首先,我们需要从京东平台上采集手机品牌的相关数据。可以通过网络爬虫或API接口等方式获取数据。为了保证数据的完整性和准确性&…

【MySQL-4】表的基本查询

目录 1. 整体学习的思维导图 2. 表的创建 2.1 Create(创建) 2.1.1 插入规则 2.1.2 更新插入 2.2 Retrieve(读取) 2.2.1 创建一个实例表 2.3 select使用 2.3.1 全表查询 2.3.2 指定序列查询 2.3.3 查询表达式 2.3.3.1 为查询表达式改名字 2.3.4 查询去重 2.…

无人机航测技术算法概述!

一、核心技术 传感器技术: GPS/GLONASS:无人机通过卫星定位系统实现高精度的飞行控制和数据采集。 高清相机:用于拍摄地面图像,通过后续图像处理生成三维模型。 激光雷达(LiDAR):通过激光扫…

uniapp 自定义加载组件,全屏加载,局部加载 (微信小程序)

效果图 全屏加载 页面加载使用 局部加载 列表加载里面使用 使用gif html <template><view><view class"" v-if"typeFullScreen"><view class"loading" v-if"show"><view class""><i…

【D3.js in Action 3 精译_040】4.4 D3 弧形图的绘制方法

当前内容所在位置&#xff1a; 第四章 直线、曲线与弧线的绘制 ✔️ 4.1 坐标轴的创建&#xff08;上篇&#xff09; 4.1.1 D3 中的边距约定&#xff08;中篇&#xff09;4.1.2 坐标轴的生成&#xff08;中篇&#xff09; 4.1.2.1 比例尺的声明&#xff08;中篇&#xff09;4.1…

element ui 走马灯一页展示多个数据实现

element ui 走马灯一页展示多个数据实现 element ui 走马灯一页展示多个数据实现 element ui 走马灯一页展示多个数据实现 主要是对走马灯的数据的操作&#xff0c;先看js处理 let list [{ i: 1, name: 1 },{ i: 2, name: 2 },{ i: 3, name: 3 },{ i: 4, name: 4 },]let newL…

使用MaxKB搭建知识库问答系统并接入个人网站(halo)

首发地址&#xff08;欢迎大家访问&#xff09;&#xff1a;使用MaxKB搭建知识库问答系统并接入个人网站 前言 从OpenAI推出ChatGPT到现在&#xff0c;大模型已经渗透到各行各业&#xff0c;大模型也逐渐趋于平民化&#xff1b;从最开始对其理解、生成、强大的知识积累的惊叹&…

Linux进阶:软件安装、网络操作、端口、进程等

软件安装 yum 和 apt 均需要root权限 CentOS系统使用&#xff1a; yum [install remove search] [-y] 软件名称 install 安装remove 卸载search 搜索-y&#xff0c;自动确认 Ubuntu系统使用 apt [install remove search] [-y] 软件名称 install 安装remove 卸载search 搜索-y&…

如何解决飞书网页文字无法复制的问题

如何解决网页文字无法复制的问题&#xff1f;特别推荐提词宝防复制文案功能&#xff01; 在日常工作和学习中&#xff0c;我们经常遇到一些网页文字无法复制的情况&#xff0c;无论是因为权限限制还是其他原因&#xff0c;手动输入内容不仅耗时费力&#xff0c;还容易出错。那…

STM32电源管理—实现低功耗

注&#xff1a; 本文是学习野火的指南针开发板过程的学习笔记&#xff0c;可能有误&#xff0c;详细请看B站野火官方配套视频教程&#xff08;这个教程真的讲的很详细&#xff0c;请给官方三连吧&#xff09; 在响应绿色发展的同时&#xff0c;在很多应用场合中都对电子设备的功…

Linux网络:守护进程

Linux网络&#xff1a;守护进程 会话进程组会话终端 守护进程setsiddaemon 在创建一个网络服务后&#xff0c;往往这个服务进程是一直运行的。但是对于大部分进程来说&#xff0c;如果退出终端&#xff0c;这个终端上创建的所有进程都会退出&#xff0c;这就导致进程的生命周期…

基于深度学习的文本信息提取方法研究(pytorch python textcnn框架)

&#x1f497;博主介绍&#x1f497;&#xff1a;✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示&#xff1a;文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…

Seatunnel解决Excel中无法将数字类型转换成字符串类型以及源码打包

需求 需要实现将Excel中的数字类型的单元格像数据库中字符串类型的字段中推送 问题原因 Seatunnel在读取字段类型的时候都是使用强转的形式去获取数据的 假如说数据类型不一样的话直接强转就会报错 修改位置 org/apache/seatunnel/api/table/type/SeaTunnelRow.java org…

AntFlow 0.11.0版发布,增加springboot starter模块,一款设计上借鉴钉钉工作流的免费企业级审批流平台

AntFlow 0.11.0版发布,增加springboot starter模块,一款设计上借鉴钉钉工作流的免费企业级审批流平台 传统老牌工作流引擎比如activiti,flowable或者camunda等虽然功能强大&#xff0c;也被企业广泛采用&#xff0c;然后也存着在诸如学习曲线陡峭&#xff0c;上手难度大&#x…

UniAPP快速入门教程(一)

一、下载HBuilder 首先需要下载HBuilder开发工具&#xff0c;下载地址:https://www.dcloud.io/hbuilderx.htmlhttps://www.dcloud.io/hbuilder.html 选择Windows正式版.zip文件下载。下载解压后直接运行解压目录里的HBuilderX.exe就可以启动HBuilder。 UniApp的插件市场网址…

计算机网络 (5)数据通信的基础知识

前言 数据通信是一种以信息处理技术和计算机技术为基础的通信方式&#xff0c;它通过数据通信系统将数据以某种信号方式从一处传送到另一处&#xff0c;为计算机网络的应用和发展提供了技术支持和可靠的通信环境&#xff0c;是现代通信技术的关键部分。 一、数据通信的基本概念…