DAO模式
DAO(Data Access Object)数据访问对象是一个面向对象的数据库接口,它显露了 Microsoft Jet数据库引擎(由 Microsoft Access 所使用),并允许 Visual Basic 开发者通过 ODBC 像直接连接到其他数据库一样,直接连接到 Access 表。DAO 最适用于单系统应用程序或小范围本地分布使用。
DAO设计模优势,实现两次隔离
1.隔离了数据访问代码和业务逻辑代码,业务逻辑代码直接调用DAO方法即可,完全感受不到数据库表的存在,分工明确,数据访问层代码变化不影响业务逻辑代码,这符合单一职能原则,降低了耦合性,提高了可复用性。
2.隔离了不同数据库实现,采用面向接口编程,如果底层数据库变化,如由MySQL变成Qracle只要增加DAO接口的新实现类即可,原有MySQL实现不用修改。这符合“开”-“闭”原则,降低了代码的耦合性,提高了代码的扩展性和系统的可移植性。
4.DAO 实现类: 针对不同数据库给出DAO接口定义方法的具体实现。
5.实体类:用于存放与传输对象数据。
6.数据库连接和关闭工具类: 避免了数据库连接和关闭代码的重复使用,方便修改。
DAO接口
把对数据库的所有操作定义成抽象方法,可以提供多种实现。
public interface BookDao {
//增加
public int addBook(Book book);
//删除
public int delBook(int id);
}