DAO模式及单例模式

本文探讨了DAO模式和单例模式。DAO模式通过创建数据存取对象接口及其实现,实现了业务逻辑与数据访问的分离,提高了代码的复用性和数据库的可更换性。而单例模式确保了类只有一个实例,提供了全局访问点,降低了资源消耗。文章还介绍了单例模式的实现方式和其在系统中的应用。
摘要由CSDN通过智能技术生成

DAO模式及单例模式

​ 我们在写jdbc连接数据库时,我们一直重复写一些代码,不具有复用性,我们更改数据库类型,代码就要全部改动,耦合性太强。
在这里插入图片描述

我们需要把逻辑代码和数据访问代码隔离开,也就是封装JDBC。

一,DAO模式

什么是DAO

  • Data Access Object(数据存取对象)
  • 位于业务逻辑和持久化数据之间
  • 实现对持久化数据的访问
    在这里插入图片描述

DAO模式的组成

DAO模式的组成部分:

  • DAO接口
  • DAO实现类
  • 实体类
  • 数据库连接和关闭工具类

优势

  • 隔离了数据访问代码和业务逻辑代码
  • 隔离了不同数据库实现

在这里插入图片描述

dao模式就是对应接口,实现类(利用封装好的JDBC工具类),实体类(pojo)

下面是我的dao模式的文件结构
在这里插入图片描述

JDBC工具类

​ 每个人封装的工具类都可能不一样,所以仅供参考(这个工具类需要dao实现类继承,也可以把工具类改成静态方法)。

package com.wff.util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties;

/**
 * 数据库连接工具类
 * @author zy
 *
 */
public class BaseDao {
   
	
	protected ResultSet rs = null;
	protected PreparedStatement ps = null;
	protected Connection conn = null;
	//获得数据库连接
	public boolean getConnection() {
   
		try {
   
			ConfigManger config=ConfigManger.getInstance();
			String driver=config.getProperty("driver");
			String url=config.getProperty("url");
			String uname=config.getProperty("username");
			String upwd=config.getProperty("userpwd");
			Class.forName(driver);
			//通过DriverManager.getConnection获得Connection对象
			 conn = DriverManager.
					getConnection(url, uname, upwd);
			 
			 return true;
			 
		} catch (Exception e) {
   
			e.printStackTrace();
			 return false;
		}
		
		
	}
	/**
	 * 公共修改  添加  删除
	 * @param sql
	 * @param objs
	 * @return
	 */
	public int executUpdate(String sql,Object[] objs) {
   
		int updateRows = 0;
		try {
   
			
			ps = conn.prepareStatement(sql);
			if
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值