【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;
    }
}


相关文章
|
1月前
|
存储 安全 Java
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第17天】本文详细介绍了Java编程中Map的使用,涵盖Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的并发处理和性能优化技巧,适合初学者和进阶者学习。
49 3
|
3天前
|
存储 缓存 安全
java 中操作字符串都有哪些类,它们之间有什么区别
Java中操作字符串的类主要有String、StringBuilder和StringBuffer。String是不可变的,每次操作都会生成新对象;StringBuilder和StringBuffer都是可变的,但StringBuilder是非线程安全的,而StringBuffer是线程安全的,因此性能略低。
|
21天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
42 17
|
12天前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
16天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
57 4
|
17天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
35 2
|
22天前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
|
26天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
26天前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
|
25天前
|
存储 Java 编译器
java wrapper是什么类
【10月更文挑战第16天】
30 3
下一篇
无影云桌面