当前位置:主页 > java教程 > 浅谈对于DAO设计模式的理解

浅析DAO设计模式

发布:2020-02-17 20:43:36 199


为找教程的网友们整理了Java相关的编程文章,网友巢文山根据主题投稿了本篇教程内容,涉及到DAO、设计模式、浅谈对于DAO设计模式的理解相关内容,已被347网友关注,内容中涉及的知识点可以在下方直接下载获取。

浅谈对于DAO设计模式的理解

为了降低耦合性,提出了DAO封装数据库操作的设计模式。

它可以实现业务逻辑与数据库访问相分离。相对来说,数据库是比较稳定的,其中DAO组件依赖于数据库系统,提供数据库访问的接口。

一般的DAO的封装由以下另个原则:

 · 一个表对应一个表,相应地封装一个DAO类。
 · 对于DAO接口,必须由具体的类型定义。这样可以避免被错误地调用。

 在DAO模式中,将对数据的持久化抽取到DAO层,暴露出Service层让程序员使用,这样,一方面避免了业务代码中混杂JDBC调用语句,使得业务落实实现更加清晰。

 通常我们创建一个包,用于保存DAO接口,再创建一个包,用于保存DAO接口的实现类即可。

下面展示一个DAO接口实例Manage:

public interface Manage {
  /*插入(insert)操作--->方法名(插入的数据1,插入的数据2,……)-->返回T|F*/
  public boolean insert(String name,String classes,String score);
  /*获取全表(select *)操作-->利用Bean,一行对应一个Bean-->返回一个承载Bean的Collection*/
  public Collection select();
  /*删除(delete)操作-->方法名(where处需要的数据)--->返回T|F*/
  public boolean delete(String id);
  /*获取指定行对象---->方法名(where处需要的数据)---->返回一个承载Bean的List*/
  public List up_select(String id);
  /*修改指定行对象---->方法名(修改数据1,修改数据2,……,where处需要的数据)---->返回T|F*/
  public boolean update(String name,String classes,String id);
}

下面我们针对一张具体的表对Manage创建实现类,比如表名为test,数据库名为bean。

public class ManageInfo implements Manage {
  final private String url="jdbc:mysql://localhost:3306/bean";
  final private String user="root";
  final private String password="root";
  @Override
  public boolean insert(String name, String classes, String score) throws Exception {
    Class.forName("com.mysql.jdbc.Driver");
    Connection conn = DriverManager.getConnection(url, user, password);
    String sql="insert into test(name,classes,score) Values(?,?,?)";
    PreparedStatement st=conn.prepareStatement(sql);
    st.setString(1,name);
    st.setString(2,classes);
    st.setString(3,score);
    int count=st.executeUpdate();
    if(count<=1){
      return true;
    }else {
      return false;
    }
  }

其余实现近乎相同,若返回Bean类型的Collection,则从ResultSet里读取出每一行的数据。

将一行的数据,存入一个Java Bean中(为Bean 创建对应类型的成员变量),并将Set好的Bean存入Add入Collection。

再读取下一行的数据,重复操作,最后返回Collection即可。

总结

以上就是本文关于浅谈对于DAO设计模式的理解的全部内容,希望对大家有所帮助。感兴趣的朋友可以参阅本站:BaseJDBC和CRUDDAO的写法实例代码、使用JDBC实现数据访问对象层(DAO)代码示例等,有什么问题可以随时留言,小编会及时回复大家。感谢阅读!


参考资料

相关文章

  • java中设计模式的实例用法

    发布:2019-11-19

    这篇文章主要介绍了java 中设计模式(值对象)的实例详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下


  • Python中职责链模式原理与用法详解

    发布:2019-11-22

    这篇文章主要介绍了Python设计模式之职责链模式,结合具体实例形式分析了Python责任链模式的概念、原理、定义与使用方法,需要的朋友可以参考下


  • js单例模式原理与用法简要说明

    发布:2019-12-04

    这篇文章主要介绍了js设计模式之单例模式原理与用法,结合实例形式详细分析了javascript单例模式的概念、原理、用法及相关操作注意事项,需要的朋友可以参考下


  • 一文带你厉害Java设计模式中的模板方法

    发布:2023-04-21

    模板方法定义了一个算法的步骤,并允许子类为一个或多个步骤提供实现。这篇文章就来带大家了解一下Java模板方法的概念与实现,感兴趣的小伙伴可以跟随小编一起学习一下


  • java设计模式中代理模式的知识点

    发布:2020-06-18

    下面小编就为大家带来一篇java设计模式-代理模式(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧


  • java设计模式Ctrl C和Ctrl V的原型模式详解

    发布:2023-04-12

    这篇文章主要为大家介绍了java设计模式Ctrl C和Ctrl V的原型模式详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • java开发只要tomcat设计模式用的好下班就能早

    发布:2023-04-07

    这篇文章主要为大家介绍了java开发只要tomcat设计模式的示例详解,<BR>只要设计模式用的好下班就能早,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • Java设计中Builder模式实例详解

    发布:2019-11-22

    这篇文章主要介绍了从一个Person例子进行分析重叠构造器模式、Builder模式的使用场景以及运用JavaBeans模式弥补重叠构造器模式的不足


网友讨论