Servlet使用适配器模式进行增删改查案例(BaseDaoUtilImpl.java)

简介: Servlet使用适配器模式进行增删改查案例(BaseDaoUtilImpl.java)
/**
 * 
 */
package org.dao.impl;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.dao.BaseDao;
import org.entity.Dept;
import org.entity.Emp;
/**
 * 
*    
* 项目名称:test_BaseDao   
* 类名称:BaseDaoUtilImpl   ,继承BaseDao
* 类描述:   公共的实现类
* 创建人:Mu Xiongxiong  
* 创建时间:2017-9-10 上午11:08:25   
* 修改人:Mu Xiongxiong   
* 修改时间:2017-9-10 上午11:08:25   
* 修改备注:   
* @version    
*
 */
public class BaseDaoUtilImpl<T> extends BaseDao  {
  
  
  /**
   * 
  * @Description: 该方法的主要作用:添加数据(Emp和Dept的)
  * @Title: save
  * @param  @param entity   实体
  * @param  @param tag    区分是Emp还是Dept
  * @param  @return 设定文件  
  * @return  返回类型:int   大于0成功,否则失败
  * @throws
   */
  public int save(T entity,String tag) {
    int                         rel       =     0;
    String                    sql       =     "";
    List<Object>              prams   =     new ArrayList<Object>();  
    if(tag.equals("emp")){
    Emp                     emp     =     (Emp) entity;                   //初始化Emp对象
      //添加员工
                  sql     =   "insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno) values(?,?,?,?,to_date(?, 'YYYY-MM-DD   HH24:MI:SS '),?,?,?)";             //sql语句
      try {
        prams.add(emp.getEmpno());
        prams.add(emp.getEname());
        prams.add(emp.getJob());
        prams.add(emp.getMgr());
        prams.add(emp.getHiredate());
        prams.add(emp.getSal());
        prams.add(emp.getComm());
        prams.add(emp.getDeptno());
                  rel     =   executeUpdate(sql, prams);
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();     //关闭连接
      }
      return rel;
    }else if (tag.equals("dept")) {
      //添加部门  
      Dept                      dept      =     (Dept) entity;                    //初始化Dept对象
                                sql       =     "insert into dept values(?,?,?)";       //sql语句
      
      try {
          prams.add(dept.getDeptno());
          prams.add(dept.getDname());
          prams.add(dept.getLoc());
                  rel     =   executeUpdate(sql, prams);
        
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();       //关闭连接
      }
      return rel;
    }
    return 0;                     //此处执行不到,也可以写成return null;
    
  }
  /**
   * 
  * @Description: 该方法的主要作用:修改数据
  * @Title: update
  * @param  @param entity
  * @param  @return 设定文件  
  * @return  返回类型:int   
  * @throws
   */
  public int update(T entity,String tag) {
    int                         rel       =     0;
    String                    sql       =     "";
    List<Object>              prams   =     new ArrayList<Object>();  
    if(tag.equals("emp")){
    Emp                     emp     =     (Emp) entity;                   //初始化Emp对象
      //修改员工
                  sql     =   "update emp set ename = ?,job=?,mgr=?,hiredate=to_date(?, 'YYYY-MM-DD   HH24:MI:SS ') ,sal=?,comm=?,deptno=? where empno=?";      //sql语句
      try {
        prams.add(emp.getEname());
        prams.add(emp.getJob());
        prams.add(emp.getMgr());
        prams.add(emp.getHiredate());
        prams.add(emp.getSal());
        prams.add(emp.getComm());
        prams.add(emp.getDeptno());
        prams.add(emp.getEmpno());
                  rel     =   executeUpdate(sql, prams);
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();     //关闭连接
      }
      return rel;
    }else if (tag.equals("dept")) {
      //修改部门  
      Dept                      dept      =     (Dept) entity;                    //初始化Dept对象
                                sql       =     "update dept set dname=?,loc=? where deptno =?";      //sql语句
      
      try {
          prams.add(dept.getDname());
          prams.add(dept.getLoc());
          prams.add(dept.getDeptno());
                  rel     =   executeUpdate(sql, prams);
        
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();       //关闭连接
      }
      return rel;
    }
    return 0;                     //此处执行不到,也可以写成return null;
    
  }
  
  /**
   * 
  * @Description: 该方法的主要作用:删除数据
  * @Title: delete
  * @param  @param id
  * @param  @return 设定文件  
  * @return  返回类型:int   
  * @throws
   */
  public int delete(int id,String tag) {
    int                         rel       =     0;
    String                    sql       =     "";
    List<Object>              prams   =     new ArrayList<Object>();  
    if(tag.equals("emp")){
      //删除员工
      
                  sql     =   "delete from emp where empno = ?";      //sql语句
      try {
        prams.add(id);
                  rel     =   executeUpdate(sql, prams);
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();     //关闭连接
      }
      return rel;
    }else if (tag.equals("dept")) {
      //删除部门  
                                sql       =     "delete from dept where deptno =?";       //sql语句
      
      try {
          prams.add(id);
                  rel     =   executeUpdate(sql, prams);
        
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();       //关闭连接
      }
      return rel;
    }
    return 0;                     //此处执行不到,也可以写成return null;
    
  }
  /**
   * 
  * @Description: 该方法的主要作用:根据编号查询
  * @Title: queryById
  * @param  @param id
  * @param  @return 设定文件  
  * @return  返回类型:T   
  * @throws
   */
  @SuppressWarnings("unchecked")
  public T queryById(int id,String tag) {
    String                    sql       =     "";
    List<Object>              prams   =     new ArrayList<Object>();  
    if(tag.equals("emp")){
      //查询员工
      Emp                     emp     =     null;
                              sql       =     "select * from emp where empno = ?";      //sql语句
      try {
                  
        prams.add(id);
        ResultSet rs        =   executeQuery(sql, prams);
        if(rs.next()){
                  emp     =   new Emp();  
                  emp.setEmpno(rs.getInt(1));
                  emp.setEname(rs.getString(2));
                  emp.setJob(rs.getString(3));
                  emp.setMgr(rs.getInt(4));
                  emp.setHiredate(rs.getString(5));
                  emp.setSal(rs.getFloat(6));
                  emp.setComm(rs.getFloat(7));
                  emp.setDeptno(rs.getInt(8));
        }
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();     //关闭连接
      }
      return (T) emp;
    }else if (tag.equals("dept")) {
      //查询部门  
                                sql       =     "select * from dept where deptno =?";       //sql语句
          Dept                  dept      =     null;
      
      try {
          prams.add(id);
          ResultSet             rs          =     executeQuery(sql, prams);
          if(rs.next()){
                                dept      =     new Dept();   
              dept.setDeptno(rs.getInt(1));
              dept.setDname(rs.getString(2));
              dept.setLoc(rs.getString(3));
          }
        
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();       //关闭连接
      }
      return (T)dept;
    }
    return null;                      //此处执行不到,也可以写成return null;
  }
  
  /**
   * 
  * @Description: 该方法的主要作用:查询全部
  * @Title: queryAll
  * @param  @return 设定文件  
  * @return  返回类型:List<T>   
  * @throws
   */
  @SuppressWarnings("unchecked")
  public List<T> queryAll(String tag) {
    String                    sql       =     "";
    if(tag.equals("emp")){
      //查询员工
      
                              sql       =   "select * from emp";      //sql语句
      Emp                     emp     =     null;
      List<Emp>                           empList   =     new ArrayList<Emp>();
      try {
        ResultSet rs        =   executeQuery(sql, null);
        while(rs.next()){
                  emp     =   new Emp();  
                  emp.setEmpno(rs.getInt(1));
                  emp.setEname(rs.getString(2));
                  emp.setJob(rs.getString(3));
                  emp.setMgr(rs.getInt(4));
                  emp.setHiredate(rs.getString(5));
                  emp.setSal(rs.getFloat(6));
                  emp.setComm(rs.getFloat(7));
                  emp.setDeptno(rs.getInt(8));
                  empList.add(emp);
        }
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();     //关闭连接
      }
      return (List<T>) empList;
    }else if (tag.equals("dept")) {
      //添加部门  
                                sql       =     "select * from dept";       //sql语句
          Dept                  dept      =     null;
          List<Dept>                      deptList    =     new ArrayList<Dept>();
      
      try {
          ResultSet             rs          =     executeQuery(sql, null);
          while(rs.next()){
                                dept      =     new Dept();   
              dept.setDeptno(rs.getInt(1));
              dept.setDname(rs.getString(2));
              dept.setLoc(rs.getString(3));
              deptList.add(dept);
          }
        
      } catch (SQLException e) {
        e.printStackTrace();
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      }finally{
        closeConnnection();       //关闭连接
      }
      return (List<T>)deptList;
    }
    return null;                      //此处执行不到,也可以写成return null;
  }
}


相关文章
|
25天前
|
自然语言处理 前端开发 Java
JBoltAI 框架完整实操案例 在 Java 生态中快速构建大模型应用全流程实战指南
本案例基于JBoltAI框架,展示如何快速构建Java生态中的大模型应用——智能客服系统。系统面向电商平台,具备自动回答常见问题、意图识别、多轮对话理解及复杂问题转接人工等功能。采用Spring Boot+JBoltAI架构,集成向量数据库与大模型(如文心一言或通义千问)。内容涵盖需求分析、环境搭建、代码实现(知识库管理、核心服务、REST API)、前端界面开发及部署测试全流程,助你高效掌握大模型应用开发。
151 5
|
1月前
|
前端开发 JavaScript Java
Java 学习路线规划及项目案例中的技术栈应用解析
内容包括:**Java 17核心特性**(如sealed class、record)与模块化开发;Spring Boot 3 + Spring Cloud微服务架构,涉及响应式编程(WebFlux)、多数据库持久化(JPA、R2DBC、MongoDB);云原生技术**如Docker、Kubernetes及CI/CD流程;性能优化(GraalVM Native Image、JVM调优);以及前后端分离开发(Vue 3、Spring Boot集成)。通过全栈电商平台项目实战,掌握从后端服务(用户、商品、订单)到前端应用(Vue 3、React Native)的全流程开发。
76 9
|
1月前
|
人工智能 Java 开发者
【Java实例-简易计算机】使用Java实现简单的计算机案例
一个简单的Java案例——“简易计算器”,帮助编程新手快速上手。通过实现用户输入、基本逻辑运算和结果输出,学习者可以掌握变量声明、Scanner对象使用、控制流语句等关键知识点。文章分为设计思路、关键知识点、完整代码和测试运行四个部分。
99 9
【Java实例-简易计算机】使用Java实现简单的计算机案例
|
24天前
|
人工智能 Java API
Java 生态大模型应用开发全流程实战案例与技术路径终极对决
在Java生态中开发大模型应用,Spring AI、LangChain4j和JBoltAI是三大主流框架。本文从架构设计、核心功能、开发体验、性能扩展性、生态社区等维度对比三者特点,并结合实例分析选型建议。Spring AI适合已有Spring技术栈团队,LangChain4j灵活性强适用于学术研究,JBoltAI提供开箱即用的企业级解决方案,助力传统系统快速AI化改造。开发者可根据业务场景和技术背景选择最适合的框架。
134 2
|
1月前
|
存储 Java 数据安全/隐私保护
Java技术栈揭秘:Base64加密和解密文件的实战案例
以上就是我们今天关于Java实现Base64编码和解码的实战案例介绍。希望能对你有所帮助。还有更多知识等待你去探索和学习,让我们一同努力,继续前行!
147 5
|
1月前
|
缓存 NoSQL Java
校招 Java 面试常见知识点及实战案例全解析
本文全面解析了Java校招面试中的常见知识点,涵盖Java新特性(如Lambda表达式、、Optional类)、集合框架高级应用(线程安全集合、Map性能优化)、多线程与并发编程(线程池配置)、JVM性能调优(内存溢出排查、垃圾回收器选择)、Spring与微服务实战(Spring Boot自动配置)、数据库与ORM框架(MyBatis高级用法、索引优化)、分布式系统(分布式事务、缓存应用)、性能优化(接口优化、高并发限流)、单元测试与代码质量(JUnit 5、Mockito、JaCoCo)以及项目实战案例(电商秒杀系统、社交消息推送)。资源地址: [https://pan.quark.cn/s
86 4
|
28天前
|
缓存 Java API
Java 集合容器实操技巧与案例详解
本教程基于Java 8+新特性和现代开发实践,深入讲解Java集合容器的实操技巧。通过具体场景演示Stream API数据处理、ConcurrentHashMap并发控制、LinkedHashMap实现LRU缓存、TreeSet自定义排序等高级特性。同时涵盖computeIfAbsent优化操作、EnumMap专用集合使用、集合统计与运算(交集、并集、差集)等内容。代码示例丰富,助力掌握高效编程方法。[点击获取完整代码](https://pan.quark.cn/s/14fcf913bae6)。
40 0
|
6月前
|
存储 监控 Java
JAVA线程池有哪些队列? 以及它们的适用场景案例
不同的线程池队列有着各自的特点和适用场景,在实际使用线程池时,需要根据具体的业务需求、系统资源状况以及对任务执行顺序、响应时间等方面的要求,合理选择相应的队列来构建线程池,以实现高效的任务处理。
231 12
|
8月前
|
jenkins Java 测试技术
如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例详细说明
本文介绍了如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例,详细说明了从 Jenkins 安装配置到自动构建、测试和部署的全流程。文中还提供了一个 Jenkinsfile 示例,并分享了实践经验,强调了版本控制、自动化测试等关键点的重要性。
219 3
|
8月前
|
存储 Java 关系型数据库
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接创建、分配、复用和释放等操作,并通过电商应用实例展示了如何选择合适的连接池库(如HikariCP)和配置参数,实现高效、稳定的数据库连接管理。
157 2

热门文章

最新文章