【JavaWeb】一篇文章复习JDBC、DAO及相关实现类(二)

简介: 【JavaWeb】一篇文章复习JDBC、DAO及相关实现类(二)

三、DAO及相关实现类


DAO


DAO(Data Access Object)访问数据信息的类和接口,包括了对数据的CRUD(Create、Retrival、Update、 Delete),而不包含任何业务相关的信息。


DAO作用: 为了实现功能的模块化,更有利于代码的维护和升级。


层次结构:


6b6b0ee40edb2c4517cc929e37ff2792_image-20220909142912189.png


c9191b0220db16bc9847f40311ab5f32_e3bfe64b65844ec3204f82fedd685835.png



代码如下:


pojo.User.java
package com.sun.pojo;
/**
 * @author JumperSun
 * @date 2022-09-09-12:51
 */
public class User {
    int id;
    String name;
    String password;
    public User(int id, String name, String password) {
        super();
        this.id = id;
        this.name = name;
        this.password = password;
    }
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}


BaseDao.java


package com.sun.dao;
import com.sun.util.JDBCUtils;
import com.sun.util.PsUtils;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
/**
 * @author JumperSun
 * @date 2022-09-09-12:53
 * 定义一个用来被继承的对数据库进行基本操作的Dao
 */
public abstract class BaseDao<T> {
    private PsUtils PsUtils = new PsUtils();
    // 定义一个变量来接收泛型的类型
    private Class<T> type;
    // 获取T的Class对象,获取泛型的类型,泛型是在被子类继承时才确定
    public BaseDao() {
        // 获取子类的类型
        Class clazz = this.getClass();
         // 获取父类的类型
        // getGenericSuperclass()用来获取当前类的父类的类型
        // ParameterizedType表示的是带泛型的类型
        ParameterizedType parameterizedType = (ParameterizedType) clazz.getGenericSuperclass();
        // 获取具体的泛型类型 getActualTypeArguments获取具体的泛型的类型
        // 这个方法会返回一个Type的数组
        Type[] types = parameterizedType.getActualTypeArguments();
        // 获取具体的泛型的类型·
        this.type = (Class<T>) types[0];
    }
    /**
     * 通用的增删改操作
     * @param sql
     * @param params
     * @return
     */
    public boolean update(String sql, Object... params) {
        boolean flag = false;
        try {
            flag = PsUtils.update(sql, params);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return flag;
    }
    /**
     * 获取一个对象
     *
     * @param sql
     * @param params
     * @return
     */
    public T getBean(String sql, Object... params) {
        T t = null;
        try {
            t = PsUtils.getBean(type,sql, params);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return t;
    }
    /**
     * 获取所有对象
     * @param sql
     * @param params
     * @return
     */
    public List<T> getBeanList(String sql, Object... params) {
        List<T> list = null;
        try {
            list = PsUtils.getBeanList(type, sql, params);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return list;
    }
}


UserDao.java


package com.sun.dao;
import com.sun.pojo.User;
import java.util.List;
/**
 * @author JumperSun
 * @date 2022-09-09-13:52
 */
public interface UserDao {
    /**
     * 查询所有用户
     * @return
     */
    List<User> getUsers();
    /**
     * 根据用户名查询用户
     * @param name
     * @return
     */
    User getUserByName(String name);
    /**
     * 添加用户
     * @param user
     * @return
     */
    boolean addUser(User user);
    /**
     * 删除用户
     * @param user
     * @return
     */
    boolean deleteUser(User user);
    /**
     * 修改用户
     * @param user
     * @return
     */
    boolean updateUser(User user);
}



UserDaoImpl.java


package com.sun.dao.impl;
import com.sun.dao.BaseDao;
import com.sun.dao.UserDao;
import com.sun.pojo.User;
import java.util.List;
/**
 * @author JumperSun
 * @date 2022-09-09-13:53
 */
public class UserDaoImpl extends BaseDao implements UserDao {
    @Override
    public List<User> getUsers() {
        String sql = "select * from user";
        List UserList = getBeanList(sql);
        return UserList;
    }
    @Override
    public User getUserByName(String name) {
        String sql = "select * from user where name = ?";
        User user = (User) getBean(sql, name);
        return user;
    }
    @Override
    public boolean addUser(User user) {
        String sql = "insert into user values(?,?,?)";
        boolean flag = update(sql, user.getId(), user.getName(), user.getPassword());
        return flag;
    }
    @Override
    public boolean deleteUser(User user) {
        String sql = "delete from user where name = ? and password = ?";
        boolean flag = update(sql, user.getName(), user.getPassword());
        return flag;
    }
    @Override
    public boolean updateUser(User user) {
        String sql = "update user set name = ? ,password = ? where id = ?";
        boolean flag = update(sql, user.getName(), user.getPassword(),user.getId());
        return flag;
    }
}


相关文章
|
3月前
|
存储 安全 Java
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第17天】本文详细介绍了Java编程中Map的使用,涵盖Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的并发处理和性能优化技巧,适合初学者和进阶者学习。
99 3
|
1天前
|
SQL Java 关系型数据库
使用 JDBC 实现 Java 数据库操作
JDBC(Java Database Connectivity)是 Java 提供的数据库访问技术,允许通过 SQL 语句与数据库交互。本文详细介绍了 JDBC 的使用方法,包括环境准备、编程步骤和完整示例。
22 7
|
1天前
|
SQL Java 数据库连接
【潜意识Java】Java中JDBC过时方法的替代方案以及JDBC为什么过时详细分析
本文介绍了JDBC中一些常见过时方法及其替代方案。
19 5
|
29天前
|
Java 数据库连接 数据库
springboot java.lang.ClassNotFoundException: dm.jdbc.driver.DmDriver应该如何解决
通过上述步骤,可以有效解决Spring Boot项目中遇到的 `java.lang.ClassNotFoundException: dm.jdbc.driver.DmDriver`问题。确保在项目中正确添加达梦数据库的JDBC驱动依赖,并在配置文件中正确配置数据源信息,是解决此问题的关键。通过这些方法,可以确保Spring Boot项目能够正确连接达梦数据库并正常运行。
206 31
|
5月前
|
Java 关系型数据库 数据库连接
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
56 8
|
5月前
|
Java 数据库连接 API
JDBC:Java数据库连接的“黑科技”大揭秘
JDBC:Java数据库连接的“黑科技”大揭秘
45 7
|
3月前
|
存储 安全 Java
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第19天】本文介绍了Java编程中重要的数据结构——Map,通过问答形式讲解了Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的使用和性能优化技巧,适合初学者和进阶者学习。
107 4
|
3月前
|
SQL Java 数据库连接
如何在 Java 脚本中有效地使用 JDBC
如何在 Java 脚本中有效地使用 JDBC
25 0
|
5月前
|
SQL Java 数据库连接
JDBC之旅:从陌生到熟悉的Java数据库连接之路
JDBC之旅:从陌生到熟悉的Java数据库连接之路
41 9
|
5月前
|
SQL Java 关系型数据库
探索Java数据库连接的奥秘:JDBC技术全攻略
探索Java数据库连接的奥秘:JDBC技术全攻略
71 8