您的位置:

基于Dao设计的高效数据访问解决方案

一、Dao设计思想及其优势

Dao(Data Access Object)是一种数据访问对象,属于Java EE中的设计模式之一。Dao基本上是把数据访问逻辑与业务逻辑分离开来。其本质是对业务逻辑的解耦,将底层数据库的访问与业务逻辑分离,从而实现了对这两者之间的解耦。

优点:(1)将业务逻辑和数据访问逻辑分离开来。使得业务逻辑层可以独立于数据访问层的变化而变化;(2)在Dao中可以使用一些特殊技术来提高数据访问性能,如连接池、缓存等;(3)提高代码的可读性和可维护性,便于定义和使用数据访问接口。

二、Dao设计模式的常见实现方式

Dao设计模式的实现方式主要有两种:

1、基于实现的Dao设计模式。其实现方式是直接实现Dao接口,包括实现Dao接口的所有方法,并且在具体业务逻辑代码中使用实现类来进行持久化操作。这种方式不利于代码的维护,因为在业务需求变更时Dao接口和实现类都需要改变。

    public interface UserDao {
        List findAll();
        User findById(Long id);
        void save(User user);
        void update(User user);
        void delete(User user);
    }

    public class UserDaoImpl implements UserDao {
        public void save(User user) {
            //具体的实现
        }
        //其他方法的具体实现
    }

  

2、基于代理的Dao设计模式。其实现方式是使用动态代理技术来生成Dao实现类,代码可读性高,具有良好的拓展性。该方式能够将Dao的实现详细信息封装起来,隐藏了Dao的具体实现,不需要为每个Dao接口写相应的实现类,同时在应用的运行阶段动态生成Dao的实现类,使得Dao具有很好的灵活性。因此,本文主要介绍基于代理的Dao设计模式。

三、基于代理的Dao设计模式核心代码实现

1、首先定义数据访问对象的接口,包含了对于数据的增删改查方法的抽象声明。然后使用动态代理技术,在程序运行时生成该接口的代理类。

    public interface UserDao {
        List findAll();
        User findById(Long id);
        void save(User user);
        void update(User user);
        void delete(User user);
    }

    public class UserDaoProxyHandler implements InvocationHandler {
        //通过构造器传入真正要代理的对象
        public UserDaoProxyHandler(Object obj) {
            this.obj = obj;
        }
        public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
            Object result = null;
            //在代理对象的方法中,调用真正的方法
            result = method.invoke(obj, args);
            return result;
        }
        //真正要代理的对象
        private final Object obj;
    }

    public class DaoFactory {
        public static Object createDaoProxy(Object obj) {
            return Proxy.newProxyInstance(obj.getClass().getClassLoader(),
                    obj.getClass().getInterfaces(), new UserDaoProxyHandler(obj));
        }
    }

  

2、接下来,我们定义具体访问数据的方法DaoImpl,它实现了上面定义的Dao接口,并根据具体情况去实现具体数据库的SQL操作。

    public class UserDaoImpl implements UserDao {
        public List findAll() {
            List
    list = new ArrayList<>();
            Connection conn = null;
            PreparedStatement psmt = null;
            ResultSet rs = null;
            try {
                conn = getConnection();
                String sql = "select * from user";
                psmt = conn.prepareStatement(sql);
                rs = psmt.executeQuery();
                while (rs.next()) {
                    User user = new User();
                    user.setId(rs.getLong("id"));
                    user.setUsername(rs.getString("username"));
                    user.setPassword(rs.getString("password"));
                    list.add(user);
                }
            } catch (SQLException e) {
                e.printStackTrace();
            } finally {
                closeAll(conn, psmt, rs);
            }
            return list;
        }
        //其他方法的具体实现
    }

   
  

四、总结

基于Dao设计模式的高效数据访问解决方案,旨在将业务逻辑与数据访问逻辑分离,实现了对这两者之间的解耦。本文主要阐述了Dao设计模式的实现方式,包括基于实现和基于代理两种方式,并详细介绍了基于代理的Dao设计模式的核心代码实现。

基于Dao设计的高效数据访问解决方案

2023-05-20
java基础知识学习笔记一,Java基础笔记

2022-11-21
java方法整理笔记(java总结)

2022-11-08
python基础学习整理笔记,Python课堂笔记

2022-11-21
印象笔记记录java学习(Java成长笔记)

2022-11-12
数据库的笔记mysql,数据库管理系统笔记

2022-11-24
java学习笔记(java初学笔记)

2022-11-14
Mac笔记:在日常生活中高效实用的笔记工具

2023-05-18
jsp程序开发学习笔记2,jsp程序设计题库

本文目录一览: 1、《JSP&Servlet学习笔记》pdf下载在线阅读,求百度网盘云资源 2、林信良编著jsp&servlet学习笔记第2版课后答案吗 3、jsp有没有快速掌握的办法呀? 4、要学J

2023-12-08
Python字典:高效存储和快速访问数据的解决方案

2023-05-12
关于已前的学习笔记java的信息

2022-11-18
java博客系统,基于java的博客论坛

2023-01-09
js高级程序设计笔记14(js高级程序设计笔记14页)

本文目录一览: 1、JavaScript高级程序设计 该怎么看 2、JavaScript学习笔记之数组基本操作示例 3、JS中有关sort以及return的问题 JavaScript高级程序设计 该怎

2023-12-08
包含java读书笔记02的词条

2022-11-20
mysql数据库优化之设计层3,数据库优化设计方案有几种

2022-11-19
java学习的一些基础笔记(java初学笔记)

2022-11-14
使用MyBatis设置数据访问层(DAO)持久化与查询

2023-05-17
java客户端学习笔记(java开发笔记)

2022-11-14
java笔记,尚硅谷java笔记

2022-12-01
基础c语言笔记,C语言笔记

2023-01-06