idea写一个Servlet以实现增删改查 Emp表,连接oracle数据库

时间: 2024-05-18 07:18:43 浏览: 13
好的,我可以帮您实现一个Servlet来实现Emp表的增删改查操作并连接到Oracle数据库。 首先,您需要在您的项目中添加Oracle数据库的JDBC驱动程序,并将其添加到Web应用程序的类路径中。您可以在以下链接中下载Oracle的JDBC驱动程序:https://www.oracle.com/database/technologies/jdbcdriver-ucp-downloads.html 接下来,您需要创建一个Emp类,该类包含Emp表中的所有字段: ``` public class Emp { private int empno; private String ename; private String job; private int mgr; private Date hiredate; private double sal; private double comm; private int deptno; // getters and setters } ``` 然后,您需要创建一个EmpDAO类,该类包含所有与Emp表相关的数据库操作方法: ``` public class EmpDAO { private Connection conn; public EmpDAO(Connection conn) { this.conn = conn; } public List<Emp> getAllEmps() throws SQLException { List<Emp> emps = new ArrayList<>(); String sql = "SELECT * FROM emp"; try (PreparedStatement stmt = conn.prepareStatement(sql)) { try (ResultSet rs = stmt.executeQuery()) { while (rs.next()) { Emp emp = new Emp(); emp.setEmpno(rs.getInt("empno")); emp.setEname(rs.getString("ename")); emp.setJob(rs.getString("job")); emp.setMgr(rs.getInt("mgr")); emp.setHiredate(rs.getDate("hiredate")); emp.setSal(rs.getDouble("sal")); emp.setComm(rs.getDouble("comm")); emp.setDeptno(rs.getInt("deptno")); emps.add(emp); } } } return emps; } public Emp getEmpById(int empno) throws SQLException { String sql = "SELECT * FROM emp WHERE empno = ?"; try (PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setInt(1, empno); try (ResultSet rs = stmt.executeQuery()) { if (rs.next()) { Emp emp = new Emp(); emp.setEmpno(rs.getInt("empno")); emp.setEname(rs.getString("ename")); emp.setJob(rs.getString("job")); emp.setMgr(rs.getInt("mgr")); emp.setHiredate(rs.getDate("hiredate")); emp.setSal(rs.getDouble("sal")); emp.setComm(rs.getDouble("comm")); emp.setDeptno(rs.getInt("deptno")); return emp; } else { return null; } } } } public void addEmp(Emp emp) throws SQLException { String sql = "INSERT INTO emp (empno, ename, job, mgr, hiredate, sal, comm, deptno) VALUES (?, ?, ?, ?, ?, ?, ?, ?)"; try (PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setInt(1, emp.getEmpno()); stmt.setString(2, emp.getEname()); stmt.setString(3, emp.getJob()); stmt.setInt(4, emp.getMgr()); stmt.setDate(5, emp.getHiredate()); stmt.setDouble(6, emp.getSal()); stmt.setDouble(7, emp.getComm()); stmt.setInt(8, emp.getDeptno()); stmt.executeUpdate(); } } public void updateEmp(Emp emp) throws SQLException { String sql = "UPDATE emp SET ename = ?, job = ?, mgr = ?, hiredate = ?, sal = ?, comm = ?, deptno = ? WHERE empno = ?"; try (PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setString(1, emp.getEname()); stmt.setString(2, emp.getJob()); stmt.setInt(3, emp.getMgr()); stmt.setDate(4, emp.getHiredate()); stmt.setDouble(5, emp.getSal()); stmt.setDouble(6, emp.getComm()); stmt.setInt(7, emp.getDeptno()); stmt.setInt(8, emp.getEmpno()); stmt.executeUpdate(); } } public void deleteEmp(int empno) throws SQLException { String sql = "DELETE FROM emp WHERE empno = ?"; try (PreparedStatement stmt = conn.prepareStatement(sql)) { stmt.setInt(1, empno); stmt.executeUpdate(); } } } ``` 最后,您需要创建一个EmpServlet类,该类处理所有与客户端的HTTP请求,并调用EmpDAO类中的方法来执行数据库操作: ``` public class EmpServlet extends HttpServlet { private EmpDAO dao; @Override public void init() throws ServletException { try { Class.forName("oracle.jdbc.driver.OracleDriver"); String url = "jdbc:oracle:thin:@//localhost:1521/orcl"; String username = "your_username"; String password = "your_password"; Connection conn = DriverManager.getConnection(url, username, password); dao = new EmpDAO(conn); } catch (ClassNotFoundException | SQLException e) { throw new ServletException(e); } } @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String action = request.getParameter("action"); if (action == null) { List<Emp> emps = dao.getAllEmps(); request.setAttribute("emps", emps); request.getRequestDispatcher("/WEB-INF/views/empList.jsp").forward(request, response); } else if (action.equals("add")) { request.getRequestDispatcher("/WEB-INF/views/addEmp.jsp").forward(request, response); } else if (action.equals("edit")) { int empno = Integer.parseInt(request.getParameter("empno")); Emp emp = dao.getEmpById(empno); request.setAttribute("emp", emp); request.getRequestDispatcher("/WEB-INF/views/editEmp.jsp").forward(request, response); } else if (action.equals("delete")) { int empno = Integer.parseInt(request.getParameter("empno")); dao.deleteEmp(empno); response.sendRedirect(request.getContextPath() + "/emp"); } } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String action = request.getParameter("action"); if (action.equals("add")) { Emp emp = new Emp(); emp.setEmpno(Integer.parseInt(request.getParameter("empno"))); emp.setEname(request.getParameter("ename")); emp.setJob(request.getParameter("job")); emp.setMgr(Integer.parseInt(request.getParameter("mgr"))); emp.setHiredate(Date.valueOf(request.getParameter("hiredate"))); emp.setSal(Double.parseDouble(request.getParameter("sal"))); emp.setComm(Double.parseDouble(request.getParameter("comm"))); emp.setDeptno(Integer.parseInt(request.getParameter("deptno"))); dao.addEmp(emp); response.sendRedirect(request.getContextPath() + "/emp"); } else if (action.equals("edit")) { Emp emp = new Emp(); emp.setEmpno(Integer.parseInt(request.getParameter("empno"))); emp.setEname(request.getParameter("ename")); emp.setJob(request.getParameter("job")); emp.setMgr(Integer.parseInt(request.getParameter("mgr"))); emp.setHiredate(Date.valueOf(request.getParameter("hiredate"))); emp.setSal(Double.parseDouble(request.getParameter("sal"))); emp.setComm(Double.parseDouble(request.getParameter("comm"))); emp.setDeptno(Integer.parseInt(request.getParameter("deptno"))); dao.updateEmp(emp); response.sendRedirect(request.getContextPath() + "/emp"); } } } ``` 在这个例子中,EmpServlet类处理HTTP GET和POST请求。当收到HTTP GET请求时,它会根据参数“action”的值来调用不同的方法。如果“action”是null,则它将获取Emp表中的所有记录并将它们发送到JSP视图进行呈现。如果“action”是“add”,则它将发送一个包含Emp表中所有字段的表单,以便用户添加新记录。如果“action”是“edit”,则它将发送一个包含Emp表中所有字段的表单,以便用户编辑现有记录。如果“action”是“delete”,则它将从Emp表中删除指定的记录。当收到HTTP POST请求时,它将根据参数“action”的值来调用不同的方法。如果“action”是“add”,则它将从表单中获取所有字段的值并将它们插入到Emp表中。如果“action”是“edit”,则它将从表单中获取所有字段的值并将它们更新到Emp表中。 最后,您需要编写JSP视图来呈现Emp表中的数据和表单。您可以创建一个名为empList.jsp的JSP页面来呈现Emp表中的所有记录,一个名为addEmp.jsp的JSP页面来添加新记录,以及一个名为editEmp.jsp的JSP页面来编辑现有记录。这些JSP页面应该使用JSTL和EL表达式来呈现数据和动态生成HTML。

相关推荐

最新推荐

recommend-type

李兴华Oracle数据库全套课堂笔记

《李兴华Oracle数据库课堂笔记》 例:查询出所有不领取佣金的雇员。 SELECT*FROM emp WHERE comm IS NULL; 例:查询出所有领取佣金的雇员。 SELECT*FROM emp WHERE comm IS NOT NULL; SELECT*FROM emp WHERE ...
recommend-type

SQL Server多表查询优化方案集锦

这是因为ORACLE只对简单的表提供高速缓冲(cache buffering) ,这个功能并不适用于多表连接查询..数据库管理员必须在init.ora中为这个区域设置合适的参数,当这个内存区域越大,就可以保留更多的语句,当然被共享的可能性...
recommend-type

Oracle中分组查询group by用法规则详解

在select 语句中可以使用group by 子句将行划分成较小的组,一旦使用分组后select操作的对象变为各个分组后的数据,使用聚组函数返回的是每一个组的汇总信息。 使用having子句 限制返回的结果集。group by 子句可以...
recommend-type

创建一个过程,向dept表中添加一个新记录

1.创建一个过程,向dept表中添加一个新记录。(in参数) 创建过程: create or replace procedure Insert_dept ( num_dept in number ,v_ename in varchar3)is begin insert into dept values(num_dept,v_ename);...
recommend-type

Oracle多表连接练习

From emp e,dept d Where e.deptno=d.deptno; 2. 列出所有部门的详细信息和部门人数 Select d.deptno,d.dname, d.loc,count(e.empno) From emp e,dept d Where e. deptno(+)=d.deptno Group by d.deptno,d.dname,d....
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

从键盘输入一段英文字符串,其中包含多个字母‘h',请编写程序利用正则表达式,将英文字符串中的’h'全部改为‘H’

好的,我可以帮您解决这个问题。 您可以使用 Python 编写一个程序来实现这个功能。具体步骤如下: 1. 首先导入 re 模块,这个模块是 Python 中用于处理正则表达式的模块。 2. 然后定义一个包含英文字符串的变量,例如: text = "This is a string containing multiple h's." 3. 接下来,使用 re.sub() 方法来进行替换操作。re.sub() 方法的第一个参数是正则表达式,第二个参数是替换的字符或字符串,第三个参数是被替换的字符串。在这个例子里,我们需要将所有的小写字母 h 替换成大写字母 H,所以正则表达式可以写成
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。