当前位置: 首页> 健康> 知识 > cms网站源码_该工具支持 preview 功能_百度广告电话号码_百度指数查询官网入口

cms网站源码_该工具支持 preview 功能_百度广告电话号码_百度指数查询官网入口

时间:2025/7/18 16:48:36来源:https://blog.csdn.net/weixin_68093610/article/details/145738862 浏览次数:0次
cms网站源码_该工具支持 preview 功能_百度广告电话号码_百度指数查询官网入口

DAO设计模式

1.概念

​ DAO(Data Access Object)模式是一种用于分离业务逻辑与数据访问逻辑的设计模式,其核心思想是通过抽象接口屏蔽底层数据操作细节,提升代码的可维护性和扩展性。

2.DAO模式的定义与核心思想

DAO模式属于J2EE设计模式,通过接口与实现分离的方式,将数据访问操作(如CRUD)封装为独立层,主要包含以下项目目录结构

  • 实体层(entity):存放与数据库表对应的Java对象(如User.java
  • DAO接口层(dao):定义数据访问接口(如UserDao.java
  • DAO实现层(impl):接口的具体实现(如UserDaoImpl.java
  • 工具类(util):数据库连接/关闭工具(如DBUtil.java
  • 业务层(service):调用DAO完成业务逻辑
  • 测试类(test):验证DAO功能

3.具体实现

(1)创建实体类: 实体类与数据库表字段对应,用于数据传输。

(2)编写数据库工具类: 封装连接获取与释放逻辑,避免重复代码。

**(3)定义DAO接口:**声明原子化数据操作方法,不涉及具体实现。

**(4)实现DAO接口:**使用JDBC或ORM框架(如MyBatis)完成数据库操作。

**(5)编写测试类:**声明原子化数据操作方法,不涉及具体实现。

4.DAO模式的优缺点

优点

  • 降低耦合性:业务逻辑与数据访问分离,符合单一职责原则。
  • 提升复用性:相同数据操作逻辑可被多个业务模块复用。
  • 易于维护:修改底层数据库时只需调整DAO实现类,无需改动业务代码。

缺点

  • 代码冗余:简单项目可能因分层过多导致复杂度上升。
  • 性能开销:频繁的数据库连接操作需结合连接池优化。

5.示例

以下是一个简单的DAO模式实现示例:

  1. 实体类(User)
@Data
@NoArgsConstructor
@AllArgsConstructor
@Accessors(chain = true)
public class User {private int id;private String name;private String email;}
  1. DAO接口(UserDAO)
public interface UserDAO {void addUser(User user);User getUserById(int id);void updateUser(User user);void deleteUser(int id);
}
  1. DAO实现类(UserDAOImpl)
import java.sql.*;
public class UserDAOImpl implements UserDAO {private Connection connection;public UserDAOImpl(Connection connection) {this.connection = connection;}@Overridepublic void addUser(User user) {String sql = "INSERT INTO users (name, email) VALUES (?, ?)";try (PreparedStatement stmt = connection.prepareStatement(sql)) {stmt.setString(1, user.getName());stmt.setString(2, user.getEmail());stmt.executeUpdate();} catch (SQLException e) {e.printStackTrace();}}@Overridepublic User getUserById(int id) {String sql = "SELECT * FROM users WHERE id = ?";try (PreparedStatement stmt = connection.prepareStatement(sql)) {stmt.setInt(1, id);ResultSet rs = stmt.executeQuery();if (rs.next()) {return new User(rs.getInt("id"), rs.getString("name"), rs.getString("email"));}} catch (SQLException e) {e.printStackTrace();}return null;}@Overridepublic void updateUser(User user) {String sql = "UPDATE users SET name = ?, email = ? WHERE id = ?";try (PreparedStatement stmt = connection.prepareStatement(sql)) {stmt.setString(1, user.getName());stmt.setString(2, user.getEmail());stmt.setInt(3, user.getId());stmt.executeUpdate();} catch (SQLException e) {e.printStackTrace();}}@Overridepublic void deleteUser(int id) {String sql = "DELETE FROM users WHERE id = ?";try (PreparedStatement stmt = connection.prepareStatement(sql)) {stmt.setInt(1, id);stmt.executeUpdate();} catch (SQLException e) {e.printStackTrace();}}
}
  1. 使用DAO
public class Main {public static void main(String[] args) {Connection connection = // 获取数据库连接UserDAO userDAO = new UserDAOImpl(connection);User user = new User(1, "John Doe", "john@example.com");userDAO.addUser(user);User retrievedUser = userDAO.getUserById(1);System.out.println(retrievedUser.getName());user.setEmail("john.doe@example.com");userDAO.updateUser(user);userDAO.deleteUser(1);}
}

6.总结

DAO设计模式通过抽象数据访问逻辑,使代码更具模块化和可维护性。它是企业级应用中常见的设计模式,特别适用于需要频繁与数据库交互的场景。

关键字:cms网站源码_该工具支持 preview 功能_百度广告电话号码_百度指数查询官网入口

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: