数据库 – DAO和JDBC的关系?
|
我知道Hibernate实现了ORM(对象关系映射),JDBC实现了什么类型的映射?它实现了DAO吗?我不完全理解DAO如何与JDBC相关……? 解决方法DAO不是映射. DAO代表数据访问对象.它看起来像这样:public interface UserDAO {
public User find(Long id) throws DAOException;
public void save(User user) throws DAOException;
public void delete(User user) throws DAOException;
// ...
}
对于DAO,JDBC只是一个实现细节. public class UserDAOJDBC implements UserDAO {
public User find(Long id) throws DAOException {
// Write JDBC code here to return User by id.
}
// ...
}
Hibernate可能是另一个. public class UserDAOHibernate implements UserDAO {
public User find(Long id) throws DAOException {
// Write Hibernate code here to return User by id.
}
// ...
}
JPA可能是另一个(如果你将现有的遗留应用程序迁移到JPA;对于新的应用程序,它会有点奇怪,因为JPA本身实际上是DAO,例如Hibernate和EclipseLink作为可用的实现). public class UserDAOJPA implements UserDAO {
public User find(Long id) throws DAOException {
// Write JPA code here to return User by id.
}
// ...
}
它允许您在不更改使用DAO的业务代码的情况下切换UserDAO实现(当然,只有当您正在对接口进行正确编码时). 对于JDBC,你只需要编写很多行来查找/保存/删除所需的信息,而使用Hibernate只需要几行.无论你是否正在使用DAO,Hiberenate作为一个ORM都会从你的手中完成令人讨厌的JDBC工作. 也可以看看: > I found JPA,or alike,don’t encourage DAO pattern (编辑:天瑞地安资讯网_黄海网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 扩展性很好的一个分页存储过程分析
- sql-server – 恢复数据库,不包括FILESTREAM数据
- sql – 根据来自另一个数据库的查询结果查询数据库
- sql-server – 使用LEFT JOIN或NOT EXISTS之间的最佳实践
- sql-server-2005 – 永久删除表时回收SQL Server 2005数据库
- sqlserver中check约束是什么?如何创建?
- 如何从ColdFusion中的查询对象获取SQL?
- sqlserver 临时表 Vs 表变量 详细说明
- sql-server – 外部应用vs左连接性能
- sql-server – SQL:如果不是CPU或IO,什么会降低INSERT的速


