什么是DAO

        DAO是Data Access Object数据访问接口,数据访问:故名思义就是与数据库打交道。夹在业务逻辑与数据库资源中间。

DAO的功能:

  1. DAO用来封装Data Source的..就比如,Connection conn = DAOFacotry.createConnection()..
  就可以把Driver. URL. username, passpword这一些放在DAO中
  以后要更改数据库的类型.比如要把MSSQL换成Oracle的话..只需要更改DAOFacory里面的getConnection()里面的Driver.URL.之类的..
  2. DAO也是把对数据库的操作(比如最基本的CRUD操作)全部封装在里面..
  比如说你要你要插入一个新的用户..那么.在DAO中我们只需要提供一个insertUser(User user)这一个方法就可以了..具体的操作是在DAO中实现的...
  那么对于要调用DAO的时候.我们只要知道insertUser(User)是用来插入一个新的用户...而不需要知道是如何实现的。

  一般 DAO是与Abstract Factory模式一起来用的...

  Factory来建立数据库和定位具体的DAO(比如说是UserDao..CustomerDao..)..一般将getConnection设置为static..也可以把HibernateSessionFactory这一个公共类放在这一AbstractFactory类中去...


  public class DAOFactory {
  private static final SessionFactory sessionFacotory;
  // 定义一个TrheadLocal .
  static Session currentSession().....
  public UserDao getUserDAO() { return new UserDaoImpl(sesssion);}
  pulbic OtherDao getOtherDAO() { return new OtherDaoImpl(session);}
  ......
  }

  public interface UserDao {
  public insertUser(FormBean)
  public updateUser(FormBean);
  }
  然后就实现DAO的接口: (Struts的FormBean...VO来的..)
  public class UserDaoImpl implements UserDao {
  private Session session;
  public UserDaoImpl(Session session){
  this.session = session;
  }...
  public insertUser(FormBean) {
  ..//..
  session.save(UserPO);
  ..//..
  return FormBean;
  }
  public FormBean updateUser(FormBean) {
  ..//..
  session.update(UserPO);
  ..//..
  return FormBean;
  }
  }
  最后定义你的PO:
  public class UserPO {
  String firstname, lastname, password..........
  }

           DAO,对DAO的初步理解就是DAO封装了对持久层的访问,如果持久层是RDBS(关系型数据库),那么也就是实现了对jdbc的封装。

DAO实现包括:

  DAO接口   DAO实现   DAO工厂  以及值传输对象(VO),其实这也是个工厂模式的应用。

### JavaWeb 中 DAO 的概念及作用 #### 定义 数据访问对象 (Data Access Object, DAO) 是一种用于封装对数据库或其他持久存储机制的访问的设计模式。通过这种模式,可以将数据访问逻辑与业务逻辑分离,从而提高代码的可维护性和重用性[^3]。 #### 主要职责 DAO 层的主要职责是对底层的数据源执行 CRUD(创建、读取、更新和删除)操作,并向服务层提供干净简洁的方法接口。这使得应用程序其他部分不需要关心具体的数据库交互细节,只需要调用 DAO 提供的方法即可完成所需的操作。 #### 实现方式 通常情况下,在 Java Web 应用程序中会采用 MyBatis 或 Hibernate 这样的 ORM 框架来简化 DAO 的编写工作。这些框架允许开发者定义映射关系并自动生成大部分 SQL 语句,减少了手动编码的工作量。例如: ```java public interface UserDAO { void insertUser(User user); List<User> getAllUsers(); } ``` 以及对应的 XML 映射文件 `UserDAOMapper.xml`: ```xml <mapper namespace="com.example.dao.UserDAO"> <insert id="insertUser" parameterType="User"> INSERT INTO users(name, email) VALUES(#{name}, #{email}) </insert> <select id="getAllUsers" resultType="User"> SELECT * FROM users; </select> </mapper> ``` 这样做的好处是可以让不同的模块专注于各自的任务——控制器负责接收 HTTP 请求并将它们转发给适当的服务;而服务则依赖于 DAO 来获取或保存必要的信息到数据库中去。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xhw79

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值