BaseDao

#### 10.1 DAO概念> DAO:Data Access Object,数据访问对象。
>
> Java是面向对象语言,数据在Java中通常以对象的形式存在。一张表对应一个实体类,一张表的操作对应一个DAO对象!

    >

> 在Java操作数据库时,我们会将对同一张表的增删改查操作统一维护起来,维护的这个类就是DAO层。
>

    在开发中,我们会为数据库中的每一张表创建一个对应的DAO 类,这个 DAO 类专门负责处理与该表相关的所有数据库操作。

  • 如果数据库中有一张user表(存储用户信息),我们就会创建一个UserDAO
  • 这个UserDAO类中只会包含对user表的操作方法:
    • 添加用户(对应user表的 INSERT 操作)
    • 查询用户(对应user表的 SELECT 操作)
    • 更新用户(对应user表的 UPDATE 操作)
    • 删除用户(对应user表的 DELETE 操作)
DAO层只关注对数据库的操作,供业务层Service调用,将职责划分清楚!# 10.1 BaseDAO概念> 基本上每一个数据表都应该有一个对应的DAO接口及其实现类,发现对所有表的操作(增、删、改、查)代码重复度很高,所以可以抽取公共代码,给这些DAO的实现类可以抽取一个公共的父类,复用增删改查的基本操作,我们称为BaseDAO。/*** 通用的查询:多行多列、单行多列、单行单列*      多行多列:List<Employee>*      单行多列:Employee*      单行单列:封装的是一个结果。Double、Integer、。。。。。*  封装过程:*      1、返回的类型:泛型:类型不确定,调用者知道,调用时,将此次查询的结果类型告知BaseDAO就可以了。*      2、返回的结果:通用,List  可以存储多个结果,也可以存储一个结果 get(0)*      3、结果的封装:反射,要求调用者告知BaseDAO要封装对象的类对象。 Class*/

 if(params!=null && params.length > 0){
for (int i = 0; i < params.length; i++) {
//占位符是从1开始的。参数的数组是从0开始的
preparedStatement.setObject(i+1,params[i] );
}
}

    /*
通用的查询多个Javabean对象的方法,例如:多个员工对象,多个部门对象等
这里的clazz接收的是T类型的Class对象,
如果查询员工信息,clazz代表Employee.class,
如果查询部门信息,clazz代表Department.class,
返回List<T> list
*/

       /*
获取结果集的元数据对象。
元数据对象中有该结果集一共有几列、列名称是什么等信息
*/

  ResultSetMetaData metaData = res.getMetaData();
int columnCount = metaData.getColumnCount();//获取结果集列数

import java.lang.reflect.Field;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.util.ArrayList;
import java.util.List;/*** 将共性的数据库的操作代码封装在BaseDAO里。*/
public class BaseDAO {/*** 通用的增删改的方法。* @param sql 调用者要执行的SQL语句* @param params SQL语句中的占位符要赋值的参数* @return 受影响的行数*/public int executeUpdate(String sql,Object... params)throws Exception{//1.通过JDBCUtilV2获取数据库连接Connection connection = JDBCUtilV2.getConnection();//2.预编译SQL语句PreparedStatement preparedStatement = connection.prepareStatement(sql);//4.为占位符赋值,执行SQL,接受返回结果if(params!=null && params.length > 0){for (int i = 0; i < params.length; i++) {//占位符是从1开始的。参数的数组是从0开始的preparedStatement.setObject(i+1,params[i] );}}int row = preparedStatement.executeUpdate();//5.释放资源preparedStatement.close();if(connection.getAutoCommit()){JDBCUtilV2.release();}//6.返回结果return row;}/*** 通用的查询:多行多列、单行多列、单行单列*      多行多列:List<Employee>*      单行多列:Employee*      单行单列:封装的是一个结果。Double、Integer、。。。。。*  封装过程:*      1、返回的类型:泛型:类型不确定,调用者知道,调用时,将此次查询的结果类型告知BaseDAO就可以了。*      2、返回的结果:通用,List  可以存储多个结果,也可以存储一个结果 get(0)*      3、结果的封装:反射,要求调用者告知BaseDAO要封装对象的类对象。 Class*/public <T> List<T> executeQuery(Class<T> clazz,String sql,Object... params)throws Exception{//获取连接Connection connection = JDBCUtilV2.getConnection();//预编译SQL语句PreparedStatement preparedStatement = connection.prepareStatement(sql);//设置占位符的值if(params!=null && params.length > 0){for (int i = 0; i < params.length; i++) {preparedStatement.setObject(i+1, params[i]);}}//执行SQL,并接受返回的结果集ResultSet resultSet = preparedStatement.executeQuery();//获取结果集中的元数据对象//包含了:列的数量、每个列的名称ResultSetMetaData metaData = resultSet.getMetaData();int columnCount = metaData.getColumnCount();List<T> list = new ArrayList<>();//处理结果while(resultSet.next()){//循环一次,代表有一行数据,通过反射创建一个对象T t = clazz.newInstance();//循环遍历当前行的列,循环几次,看有多少列for (int i = 1; i <=columnCount ;i++){//通过下表获取列的值Object value = resultSet.getObject(i);//获取到的列的value值,这个值就是t这个对象中的某一个属性//获取当前拿到的列的名字 = 对象的属性名String fieldName = metaData.getColumnLabel(i);//通过类对象和fieldName获取要封装的对象的属性Field field = clazz.getDeclaredField(fieldName);//突破封装的privatefield.setAccessible(true);field.set(t,value);}list.add(t);}resultSet.close();preparedStatement.close();if(connection.getAutoCommit()){JDBCUtilV2.release();}return list;}/*** 通用查询:在上面查询的集合结果中获取第一个结果。 简化了获取单行单列的获取、单行多列的获取*/public <T> T executeQueryBean(Class<T> clazz,String sql,Object... params)throws Exception{List<T> list = this.executeQuery(clazz, sql, params);if(list ==null || list.size() == 0){return null;}return list.get(0);}
}

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

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

相关文章

USRP捕获手机/路由器数据传输信号波形(中)

目录&#xff1a; USRP捕获手机/路由器数据传输信号波形&#xff08;上&#xff09; USRP捕获手机/路由器数据传输信号波形&#xff08;中&#xff09; USRP捕获手机/路由器数据传输信号波形&#xff08;下&#xff09; 三、双工通信信号捕获 3.1 信号接收系统 5805e6Hz&a…

使用 Kiro AI IDE 3小时实现全栈应用Admin系统

Hello&#xff0c; 大家好&#xff0c;我是程序员海军, 全栈开发 |AI爱好者 &#xff5c; 独立开发。 之前我是采用Node生态开发的大模型以及MCP Server,大模型开发的生态主要是Python语言&#xff0c;为了更好的学习大模型开发&#xff0c;于是开了新坑。开始学习Python, 以及…

浏览器pdf、image显示

浏览器地址栏 pdf data:application/pdf;base64, data:application/pdf;base64,JVBERi0xLjcKJeLjz9MKMjMgMCBvYmoKPDwv image data:image/jpeg;base64, 

《Linux运维总结:银河麒麟V10 SP3启动docker容器报错permission denied》

总结&#xff1a;整理不易&#xff0c;如果对你有帮助&#xff0c;可否点赞关注一下&#xff1f; 更多详细内容请参考&#xff1a;Linux运维实战总结 一、环境信息 二、背景 1、使用docker启动一个nginx容器&#xff0c;报错信息如下&#xff1a; docker: Error response from…

PDF源码解析

PDF源码解析打开PDF解析PDF​0. 文件头关键信息解析技术原理图解文件头的重要性实际文件结构示例开发者注意事项历史背景1. 根目录整体结构关键字段解析核心概念解释实际应用场景完整对象关系图技术总结2. 页面树对象结构关键字段解析页面树工作原理技术要点总结实际应用3. 图像…

java开闭原则 open-closed principle

基本知识 1.核心思想&#xff1a;面向抽象编程 2.基本内涵&#xff1a;对修改关闭&#xff0c;对扩展开放 3.要求&#xff1a;尽可能不修改源码而是增加新功能 例子 以spring5核心原理与30个类手写实战中的为例 package com.gupaoedu.vip.design.principle.openclose;/*** Crea…

拥抱智慧物流时代:数字孪生技术的应用与前景

概述 在数字经济全面推进的当下&#xff0c;物流行业正经历着前所未有的智能化升级。作为新一代信息技术的重要代表&#xff0c;数字孪生技术正悄然改变着物流的运作方式和决策模式。所谓数字孪生&#xff0c;是指在虚拟空间中创建与现实物流系统高度一致的数字模型&#xff0…

libnest2d-头文件分析-libnest2d.hpp-几何类型-策略类型-参数配置

libnest2d 库的主头文件&#xff0c;定义了一个用于 二维不规则形状自动排样&#xff08;Nesting&#xff09; 的C接口。以下是详细解析&#xff1a;1. 头文件结构 (1) 防止重复包含 #ifndef LIBNEST2D_HPP #define LIBNEST2D_HPP // ... #endif // LIBNEST2D_HPP确保头文件只被…

【Docker】部署Docker可视化管理面板Dpanel

一、DPanel 介绍 1.1 DPanel 简介 DPanel 是一款专为 Docker 设计的可视化管理面板&#xff0c;旨在降低容器、镜像及相关资源的管理门槛。通过简洁直观的图形化界面&#xff0c;即使是对 Docker 不熟悉的用户&#xff0c;也能轻松上手&#xff0c;实现容器化应用的高效部署与管…

GCC/G++ + Makefile/make 使用

一、gcc\g编译器 什么是gcc和g&#xff0c;它们的区别又是什么&#xff1f; gcc编译器是专门用来编译C语言的&#xff0c;而g编译器既可以编译C语言又可以用来编译C&#xff0c;但是主要还是用来编译C。 我们都知道代码形成可执行程序都是需要经过预处理、编译、汇编和链接这四…

重复文件查找工具:DataSecurity Plus 全面提升企业文件管理效率

企业日常运营经常会出现这样的场景&#xff1a;员工在文件传输、共享与备份过程中&#xff0c;因操作不当或系统设置问题&#xff0c;出现文件重复存储&#xff1b;跨部门协作时&#xff0c;相同的项目资料可能被多次保存&#xff1b;随着数据迁移与系统升级&#xff0c;重复文…

【软件架构】资源池架构设计中的三种主流模式

在资源池架构设计中&#xff0c;三种主流模式——集中式、分布式和混合式资源池——各有其独特的优势、劣势和适用场景。理解它们的区别对于设计高效、可靠和可扩展的系统至关重要。 下面是对这三种模式的详细分析和比较&#xff1a;集中式资源池 核心概念&#xff1a; 将所有计…

Java 类加载冲突

在某次线上部署过程中&#xff0c;我们遇到了一个十分诡异的问题&#xff1a;同样的应用&#xff0c;在 ext3 文件系统下运行正常&#xff0c;但部署到 ext4 文件系统下却出现了如下异常&#xff1a;The methods class, com.ctc.wstx.io.StreamBootstrapper, is available from…

VMware安装 统信UOS桌面专业版

前言 近年来&#xff0c;随着Linux发行版在开发者、企业环境中的应用逐渐增多&#xff0c;国产操作系统统信UOS&#xff08;基于Debian&#xff09;因其良好的图形化界面和本地化支持&#xff0c;成为不少用户体验Linux生态的选择之一。本文将以VMware Workstation Pro 17为例…

SAP Datasphere 02 - 建模

创建连接创建到 HANA Cloud 实例的连接查看 HANA Cloud实例连接 Endpoint创建连接选择连接类型配置连接信息&#xff0c;授权方式&#xff0c;用户名密码等配置连接名称验证连接导入数据源表创建目录 Hotel &#xff0c;放置建模对象点击新建目录&#xff0c;导入远程表选择数据…

isasssim robotiq夹爪踩坑

1. usd导出urdf失败在isasssim的仿真中的 robotiq 2f夹爪&#xff0c;首先目前4.5asset里面的usd不能直接转urdf&#xff0c;因为模型中存在 “闭环连接”&#xff0c;即某个部件&#xff08;或关节&#xff09;同时与两个及以上的父部件相连&#xff0c;形成类似 “三角形” 的…

50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Pokedex(宝可梦图鉴)

&#x1f4c5; 我们继续 50 个小项目挑战&#xff01;—— Pokedex组件 仓库地址&#xff1a;https://github.com/SunACong/50-vue-projects 项目预览地址&#xff1a;https://50-vue-projects.vercel.app/ 使用 Vue 3 结合 PokeAPI 来创建一个炫酷的宝可梦图鉴应用。通过这个…

【Practical Business English Oral Scene Interpretation】在职主持会议-安排任务+结束会议

文章目录Introduction1. 讨论代办事项2. 分配工作任务3. 说明截止日期4. 说明截止日期5. 感谢参会者Introduction Note that each row of the table represents the content of the conversation in order. 1. 讨论代办事项 AlexBarryNoteLet’s review the to-dos from the…

ansible简单playbook剧本例子

1. 创建主机清单vim inventory.ini192.168.100.181[web:vars] ansible_userroot ansible_passwordAdmin123456[web] 192.168.100.1822. 创建一个简单的剧本vim playbook.yaml- name: My first playhosts: webtasks:- name: Ping my hostsansible.builtin.ping:- name: Print me…

爱心烟花浪漫立方体轮播图 - 用代码表达爱意

项目介绍 这是一个专为表白和营造浪漫氛围而设计的3D立方体轮播图结合了现代Web技术与浪漫元素&#xff0c;通过立方体的旋转展示珍贵的照片&#xff0c;同时配有爱心飘动、流星划过、烟花绽放和雪花飞舞等浪漫特效&#xff0c;为你的表白增添独特的科技浪漫。 效果展示截图原…