43.0BaseDao抽取dao公共父类

2023-12-01 02:52

本文主要是介绍43.0BaseDao抽取dao公共父类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

43.1. 回顾

1. 把数据库表中查询的结果封装到一个实体类中。

命名规则:类名和表名一致 类中属性和表的字段对应。

表中的一条记录对应实体的一个对象  多条记录→集合

43.2. 正文

目录

43.1. 回顾

43.2. 正文

43.3. 抽取dao公共父类。

43.4. 引入数据源


43.3. 抽取dao公共父类。

通过昨天我们的操作,可以发现dao类中很多方法都有一些相同的内容。那么我们就可以把这些相同的代码抽取到一个公共父类中。只需要这些dao子类继承该父类,子类就无需再写这些公共代码。

 

public class BaseDao {//1.相同属性抽取过来protected Connection conn=null;protected PreparedStatement ps=null;protected ResultSet rs=null;private String url="jdbc:mysql://localhost:3306/myinfo";private String user="root";private String password="root";private static String driverName="com.mysql.cj.jdbc.Driver";//加载驱动放入静态代码块中--随着类的加载而被加载而且只会加载一次。 静态方法或静态代码只能调用静态成员static{try {Class.forName(driverName);} catch (ClassNotFoundException e) {e.printStackTrace();}}//2.获取连接对象public void getConnection() throws SQLException {conn = DriverManager.getConnection(url, user, password);}//3.关闭资源public void closeAll(){//关闭连接数据库的资源if (rs != null) {try {rs.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (ps != null) {try {ps.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (conn != null) {try {conn.close();} catch (SQLException throwables) {throwables.printStackTrace();}}}}

抽象一个公共的增删改方法,

//4. 公共的增删改操作 参数类型不同:Object  参数个数不确定 ...public int update(String sql,Object... params){try {//2. 获取连接数据库的对象getConnection();//3. 获取执行sql语句的对象 ?表示占位符ps = conn.prepareStatement(sql);//4. 为占位符赋值for(int i=0;i<params.length;i++) {ps.setObject(i+1, params[i]);}//5. 执行sql语句 把sql执行的结果封装到ResultSet中int row = ps.executeUpdate();return row;} catch (SQLException throwables) {throwables.printStackTrace();} finally {closeAll();}return 0;}

 

43.4. 引入数据源

数据源就是用来存放连接数据库的对象。也叫数据库连接池。 :

C3P0、DBCP 、BoneCP、Proxool、

DDConnectionBroker、DBPool、

XAPool、Primrose、SmartPool、

MiniConnectionPoolManager

Druid等。

 (1)引入jar包

(2)修改basedao代码

 上面选择的内容,我们发现写死再代码中,如果未来交付时,需要改为对应客户的信息。需要修改源码--一旦代码写完不允许修改源码。--我们可以把上面这些信息写在属性文件中。 XXX.properties

db.properties

 

driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/myinfo
username=root
password=root
# 初始化连接数量
initialSize=5
# 最大连接数
maxActive=10
# 最大等待时间
maxWait=3000

注意:名称必须为上面的名称→→ 值可以是你自己

 修改baseDao代码

public class BaseDao {//1.相同属性抽取过来protected Connection conn=null;protected PreparedStatement ps=null;protected ResultSet rs=null;//硬编码private static DataSource dataSource=null;//加载驱动放入静态代码块中--随着类的加载而被加载而且只会加载一次。 静态方法或静态代码只能调用静态成员static{try {//创建一个属性类Properties prop=new Properties();//加载属性文件prop.load(BaseDao.class.getClassLoader().getResourceAsStream("db.properties"));dataSource= DruidDataSourceFactory.createDataSource(prop);} catch (Exception e) {e.printStackTrace();}}//2.获取连接对象public void getConnection() throws SQLException {conn = dataSource.getConnection();}//4. 公共的增删改操作 参数类型不同:Object  参数个数不确定 ...public int update(String sql,Object... params){try {//2. 获取连接数据库的对象getConnection();//3. 获取执行sql语句的对象 ?表示占位符ps = conn.prepareStatement(sql);//4. 为占位符赋值for(int i=0;i<params.length;i++) {ps.setObject(i+1, params[i]);}//5. 执行sql语句 把sql执行的结果封装到ResultSet中int row = ps.executeUpdate();return row;} catch (SQLException throwables) {throwables.printStackTrace();} finally {closeAll();}return 0;}//3.关闭资源public void closeAll(){//关闭连接数据库的资源if (rs != null) {try {rs.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (ps != null) {try {ps.close();} catch (SQLException throwables) {throwables.printStackTrace();}}if (conn != null) {try {conn.close();} catch (SQLException throwables) {throwables.printStackTrace();}}}}

这篇关于43.0BaseDao抽取dao公共父类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/439518

相关文章

poj1330(LCA最近公共祖先)

题意:求最近公共祖先 思路:之前学习了树链剖分,然后我就用树链剖分的一小部分知识就可以解这个题目了,记录每个结点的fa和depth。然后查找时,每次将depth大的结点往上走直到x = y。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#include<math.h>#include<cstring>

在二叉树中找到两个节点的最近公共祖先(基于Java)

如题  题解 public int lowestCommonAncestor(TreeNode root, int o1, int o2) {//记录遍历到的每个节点的父节点。Map<Integer, Integer> parent = new HashMap<>();Queue<TreeNode> queue = new LinkedList<>();parent.put(roo

Hibernate插入数据时,报错:org.springframework.dao.DataIntegrityViolationException: could not insert: [cn.itc

在用junit测试:插入数据时,报一下错误: 错误原因: package junit;import org.junit.Test;import cn.itcast.crm.container.ServiceProvinder;import cn.itcast.crm.dao.ISysUserDao;import cn.itcast.crm.domain.SysRole;

【UVA】10066-The Twin Towers(最长公共子串问题)

赤裸裸的最长公共子串问题,没什么好说的,注意的是,每组数据后面都有一个空行。 13996019 10066 The Twin Towers Accepted C++ 0.015 2014-08-06 00:34:53 #include<cstdio>#include<cstring>#include<iostream>#include<algorithm>using

hibernate泛型Dao,让持久层简洁起来

【前言】hibernate作为持久层ORM技术,它对JDBC进行非常轻量级对象封装,使得我们可以随心所欲的使用面向对象的思想来操作数据库。同时,作为后台开发的支撑,的确扮演了一个举足轻重的角色,那么我们在项目中如何灵活应用hibernate,也会给项目维护以及项目开发带来便利,下面我将展示我们项目中是如何来对hibernate进行应用和操作。 【目录】              -

JAVA反射使用父类的非public方法(getMethods()和getDeclaredMethods()区别)

getMethods()和getDeclaredMethods()区别 虽然是老生常谈了,但是还是要先说一下两者的区别。 getMethods():能够获取类的所有public方法,包括自身定义的以及从父类继承的。 getDeclaredMethods():能够获取类本身的所有方法,包括private方法,实现的接口方法,但是不能获取从父类继承的非public方法。 因此getDeclaredM

MySQL中的`SUBSTRING()`和`MID()`函数:精准抽取字符串中的子串

在数据库操作中,经常需要从存储的字符串中提取出特定的部分,比如从用户全名中提取姓氏、从日期字符串中提取年份等。MySQL提供了SUBSTRING()和MID()两个函数,它们的功能几乎完全相同,都是用来从字符串中抽取子串的。本文将详细介绍这两个函数的用法、参数以及在实际场景中的应用。 一、SUBSTRING()和MID()函数的基本语法 1. SUBSTRING()函数 SUBSTRING(

设计之道:ORM、DAO、Service与三层架构的规范探索

引言: 实际开发中,遵守一定的开发规范,不仅可以提高开发效率,还可以提高项目的后续维护性以及项目的扩展性;了解一下本博客的项目设计规范,对项目开发很有意义 一、ORM思想 ORM(Object-Relational-Mapping)在对象模型和关系型模型之间做一个映射(转换)。 目的是为了解决面向对象编程语言的发展和关系型数据库的发展不匹配的问题 可以理解为: 将Java中的数据结

计算两个字符串的最大公共字符串的长度,字符不区分大小写

/*** */package testString;import java.util.Scanner;/***@author: Administrator*@date: 2016-12-28 下午01:08:30*/public class Main {public static void main(String[] args){Scanner sc=new Scanner(Syste

Python高效计算两个字符串的最长公共子序列

Python高效计算两个字符串的最长公共子序列 在Python面试中,考官通常会关注候选人的编程能力、问题解决能力以及对Python语言特性的理解。计算两个字符串的最长公共子序列(Longest Common Subsequence, LCS)是一个经典的动态规划问题,广泛应用于文本比较、DNA序列分析等领域。本文将详细介绍如何编写一个函数,计算两个字符串的最长公共子序列,确保代码实用性强,条理