热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

JavaWeb应用实例:用servlet实现oracle基本增删改查

很久没有写博客了,可能是太懒散,不愿意把时间花在这上面,可是我心里还是知道写博客的重要性的 ,所以从今天开始 ,我将与大家分享一下我学Jav

很久没有写博客了,可能是太懒散,不愿意把时间花在这上面,可是我心里还是知道写博客的重要性的 ,所以从今天开始 ,我将与大家分享一下我学Java WEB写的一些小实例  ,我个人是不太喜欢书本上的晦涩的概念的,所以我花了更多的时间在一些应用实例上,我觉得这样的学习方式很适合我,由简到繁,由浅入深

废话不多话,开始我们的第一个实例:

 servlet实现Oracle 基本增删改查

开发环境:JDK7 +Myeclipse10+tomcat7.0+oracle 11g

首先附上数据库创建脚本:

create table student( 
id VARCHAR2(50) PRIMARY KEY NOT NULL, 
name varchar2(50) NOT NULL, 
calssGrent varchar2(50) NOT NULL , 
result varchar(12) NOT NULL 
); 
insert into student(id,name,calssGrent,result) values(perseq.nextval,'张三','33','98') 

下图为代码结构图和功能演示界面做的比较糟糕 只为实现功能:

MMC_01.Java

页面 //主界面提供添加,修改删除的方法

package org.lsy.servlet; 
 
import java.io.IOException; 
import java.io.PrintWriter; 
import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.ResultSet; 
import java.sql.Statement; 
 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
import oracle.jdbc.oracore.TDSPatch; 
 
public class MMC_01 extends HttpServlet 
{ 
  // 驱动程序就是之前在classpath中配置的jdbc的驱动程序的jar包中 
 
  // 连接地址是由各个数据库生产商单独提供的,所以需要单独记住 
  public static final String DBURL = "jdbc:oracle:thin:@localhost:1521:LIUSY"; 
  // 连接数据库的用户名 
  public static final String DBUSER = "scott"; 
  // 连接数据库的密码 
  public static final String DBPASS = "tiger"; 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response) 
      throws ServletException, IOException 
  { 
    //设置请求和响应的编码 ,不然页面上容易出现乱码 
    request.setCharacterEncoding("UTF-8"); 
    response.setCharacterEncoding("UTF-8");  
   
    response.setContentType("text/html;UTF-8"); 
    //输出流 
    PrintWriter out = response.getWriter(); 
    //数据库连接代码 
    try 
    { 
      Connection cOnn= null; // 表示数据库的连接的对象 
      Statement stmt = null; // 表示数据库的更新操作 
      String sql="insert into student(id,name,calssGrent,result) values('67','刘12宇','33','98')"; 
      System.out.println(sql) ; 
      // 1、使用Class类加载驱动程序 
      Class.forName("oracle.jdbc.driver.OracleDriver"); 
      // 2、连接数据库 
      cOnn= DriverManager.getConnection(DBURL, DBUSER, DBPASS); 
      // 3、Statement接口需要通过Connection接口进行实例化操作 
      stmt = conn.createStatement(); 
      //用 rs获取查询结果 ,这里的SQL语句最好不要用* 我的字段比较少所以就偷一下懒,-,- 
      ResultSet rs=stmt.executeQuery("select *from student"); 
      out.println(""); 
      out.println(""); 
      out.println(" "); 
      out.println(" "); 
      //输出表头部分 
      out.print(""); 
      while(rs.next()) 
      { 
        //获取数据库中的ID 
        String id=rs.getString("id"); 
        //输出一列元素 
        out.print("" + 
        "" + 
        ""); 
         
      } 
      out.println(""); 
      out.println(" "); 
      out.println("");  
      conn.close(); 
       
    } 
    catch (Exception e) 
    { 
      e.printStackTrace(); 
    } 
    out.flush(); 
    out.close(); 
  } 
 
} 

 UpdatePage.java    //获取要修改的数据 ,并把修改过的数据提交给Update

package org.lsy.servlet; 
import java.io.IOException; 
import java.io.PrintWriter; 
import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.ResultSet; 
import java.sql.Statement; 
 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
import com.sun.crypto.provider.RSACipher; 
 
public class UpdatePage extends HttpServlet 
{ 
  // 连接地址是由各个数据库生产商单独提供的,所以需要单独记住 
    public static final String DBURL = "jdbc:oracle:thin:@localhost:1521:LIUSY"; 
    // 连接数据库的用户名 
    public static final String DBUSER = "scott"; 
    // 连接数据库的密码 
    public static final String DBPASS = "tiger"; 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response) 
      throws ServletException, IOException 
  { 
    String id=request.getParameter("id"); 
    //设置请求和响应的编码 ,不然页面上容易出现乱码 
    request.setCharacterEncoding("UTF-8"); 
    response.setCharacterEncoding("UTF-8");  
    response.setContentType("text/html;UTF-8"); 
    PrintWriter out = response.getWriter(); 
    try 
    { 
      Connection cOnn= null; // 表示数据库的连接的对象 
      Statement stmt = null; // 表示数据库的更新操作 
      // 1、使用Class类加载驱动程序 
      Class.forName("oracle.jdbc.driver.OracleDriver"); 
      // 2、连接数据库 
      cOnn= DriverManager.getConnection(DBURL, DBUSER, DBPASS); 
      // 3、Statement接口需要通过Connection接口进行实例化操作 
      stmt = conn.createStatement(); 
      //用 rs获取查询结果 ,这里的SQL语句最好不要用* 我的字段比较少所以就偷一下懒,-,- 
      ResultSet rs=stmt.executeQuery("select *from student where id='"+id+"'"); 
      while (rs.next()) 
      { 
      out.println(""); 
      out.println(""); 
      out.println(" "); 
      out.println(" "); 
      //输入成绩的表单,提交至Update 
      out.print("  "); 
      out.print("
姓名" + "班级成绩修改删除
"+rs.getString("name") +""+rs.getString("calssGrent")+"" + ""+rs.getString("result")+"修改 删除
添加数据
"); out.print(""); out.print(""); //为了作为查询数据库的条件 ,这里要把ID传过去 out.print(""); out.print("
姓名:
      name='name' size=20 >
班级:
成绩:
"); out.print(" "); out.println(""); } out.flush(); out.close(); } catch (Exception e) { e.printStackTrace();// TODO: handle exception } } }

Update.java  接收要修改的数据 ,并更新数据库

package org.lsy.servlet; 
 
import java.io.IOException; 
import java.io.PrintWriter; 
import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.Statement; 
 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
public class Update extends HttpServlet 
{ 
  // 驱动程序就是之前在classpath中配置的jdbc的驱动程序的jar包中 
 
  // 连接地址是由各个数据库生产商单独提供的,所以需要单独记住 
  public static final String DBURL = "jdbc:oracle:thin:@localhost:1521:LIUSY"; 
  // 连接数据库的用户名 
  public static final String DBUSER = "scott"; 
  // 连接数据库的密码 
  public static final String DBPASS = "tiger"; 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response) 
      throws ServletException, IOException 
  { 
    try 
     
    { 
      request.setCharacterEncoding("UTF-8"); 
      response.setCharacterEncoding("UTF-8");  
      response.setContentType("text/html;UTF-8"); 
      PrintWriter out = response.getWriter();  
      Connection cOnn= null; // 表示数据库的连接的对象 
      Statement stmt = null; // 表示数据库的更新操作 
      //获取表单提交的参数 
      String id=request.getParameter("id"); 
      System.out.println(id); 
      String name=request.getParameter("name"); 
      String grent=request.getParameter("grent"); 
      String result=request.getParameter("result"); 
      //更新SQL 
      String sqlString="update student set name='"+name+"' ," + 
          "calssGrent='"+grent+"',result='"+result+"' where id='"+id+"' ";  
      // 1、使用Class类加载驱动程序 
      Class.forName("oracle.jdbc.driver.OracleDriver"); 
      // 2、连接数据库 
      cOnn= DriverManager.getConnection(DBURL, DBUSER, DBPASS); 
      // 3、Statement接口需要通过Connection接口进行实例化操作 
      stmt = conn.createStatement(); 
      int pd=stmt.executeUpdate(sqlString); 
      if(pd!=0) 
      { 
      out.println(""); 
      out.println(""); 
      out.println(" "); 
      out.println(" "); 
      out.print(" 更新成功
查看列表 "); out.println(" "); out.println(""); } out.flush(); out.close(); stmt.close(); conn.close(); } catch (Exception e) { // TODO: handle exception } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }

addPage .java,添加数据页面

package org.lsy.servlet; 
 
import java.io.IOException; 
import java.io.PrintWriter; 
 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
public class AddPage extends HttpServlet 
{ 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response) 
      throws ServletException, IOException 
  { 
    //设置请求和响应的编码 ,不然页面上容易出现乱码 
    request.setCharacterEncoding("UTF-8"); 
    response.setCharacterEncoding("UTF-8");  
    response.setContentType("text/html;UTF-8"); 
    PrintWriter out = response.getWriter(); 
    out.println(""); 
    out.println(""); 
    out.println(" "); 
    out.println(" "); 
    //输入成绩的表单,提交至add 
    out.print("  "); 
    out.print(""); 
    out.print(""); 
    out.print("");  
    out.print("
姓名:
班级:
成绩:
"); out.println("查看列表"); out.println(" "); out.println(""); out.flush(); out.close(); } }

add   接收addpage传来的传,更新数据库

package org.lsy.servlet; 
 
import java.io.IOException; 
import java.io.PrintWriter; 
import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.PreparedStatement; 
import java.sql.ResultSet; 
import java.sql.Statement; 
 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
 
import com.sun.org.apache.xerces.internal.impl.io.UTF8Reader; 
 
import oracle.jdbc.oracore.TDSPatch; 
 
public class Add extends HttpServlet 
{ 
  // 驱动程序就是之前在classpath中配置的jdbc的驱动程序的jar包中 
 
  // 连接地址是由各个数据库生产商单独提供的,所以需要单独记住 
  public static final String DBURL = "jdbc:oracle:thin:@localhost:1521:LIUSY"; 
  // 连接数据库的用户名 
  public static final String DBUSER = "scott"; 
  // 连接数据库的密码 
  public static final String DBPASS = "tiger"; 
 
  @Override 
  protected void doPost(HttpServletRequest req, HttpServletResponse resp) 
      throws ServletException, IOException 
  { 
    // TODO Auto-generated method stub 
    doGet(req, resp); 
  } 
 
  public void doGet(HttpServletRequest request, HttpServletResponse response) 
      throws ServletException, IOException 
  { 
    //设置请求和响应的编码 ,不然页面上容易出现乱码 
    request.setCharacterEncoding("UTF-8"); 
    response.setCharacterEncoding("UTF-8");  
   
    response.setContentType("text/html;UTF-8"); 
    //输出流 
    PrintWriter out = response.getWriter(); 
    //数据库连接代码 
    try 
    { 
      Connection cOnn= null; // 表示数据库的连接的对象 
      Statement pstmt = null; // 表示数据库的更新操作 
      String nameString=request.getParameter("name"); 
      String grentString=request.getParameter("grent"); 
      String resultString=request.getParameter("result"); 
      System.out.print(nameString); 
      String sql="insert into student(id,name,calssGrent,result)  

 values(perseq.nextval,'"+nameString+"','"+grentString+"','"+resultString+"')"; 
   
      // 1、使用Class类加载驱动程序 
      Class.forName("oracle.jdbc.driver.OracleDriver"); 
      // 2、连接数据库 
      cOnn= DriverManager.getConnection(DBURL, DBUSER, DBPASS); 
      pstmt=conn.createStatement(); 
      int pd=pstmt.executeUpdate(sql); 
      if (pd!=0) 
      { 
        out.println("添加成功"); 
        out.println("
查看列表"); } conn.close(); } catch (Exception e) { e.printStackTrace(); } out.flush(); out.close(); } }

web.xml 配置文件

<&#63;xml version="1.0" encoding="UTF-8"&#63;> 
 
   
  
  index.jsp 
  
  MMC_01 
  org.lsy.servlet.MMC_01 
  
  
  delete 
  org.lsy.servlet.delete 
  
  
  Add 
  org.lsy.servlet.Add 
  
  
  AddPage 
  org.lsy.servlet.AddPage 
  
  
  UpdatePage 
  org.lsy.servlet.UpdatePage 
  
  
  Update 
  org.lsy.servlet.Update 
  
 
 
  
  MMC_01 
  /MMC_01 
  
  
  delete 
  /delete 
  
  
  Add 
  /Add 
  
  
  AddPage 
  /AddPage 
  
  
  UpdatePage 
  /UpdatePage 
  
  
  Update 
  /Update 
  
 

本人并非老鸟,一直处于学习中,有什么错误的地方还请指证,上面的代码有很多重复的部分,很多不合理的地方 ,比较数据库连接直接暴露于操作servlet中  ,为了看的更直观 ,我就没有更改……

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文介绍了 PHP 的基本概念、服务器与客户端的工作原理,以及 PHP 如何与数据库交互。同时,还涵盖了常见的数据库操作和安全性问题。 ... [详细]
  • Java毕业设计项目:“传情旧物”网站(含源码与数据库)
    本项目介绍了如何配置和运行“传情旧物”网站,包括所需的技术栈、环境配置以及具体的操作步骤。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 流处理中的计数挑战与解决方案
    本文探讨了在流处理中进行计数的各种技术和挑战,并基于作者在2016年圣何塞举行的Hadoop World大会上的演讲进行了深入分析。文章不仅介绍了传统批处理和Lambda架构的局限性,还详细探讨了流处理架构的优势及其在现代大数据应用中的重要作用。 ... [详细]
  • Centos7 Tomcat9 安装笔记
    centos7,tom ... [详细]
  • 解决Jenkins编译过程中ERROR: Failed to Parse POMs的问题
    在使用Jenkins进行自动化构建时,有时会遇到“ERROR: Failed to parse POMs”的错误。本文将详细分析该问题的原因,并提供有效的解决方案。 ... [详细]
  • 搭建个人博客:WordPress安装详解
    计划建立个人博客来分享生活与工作的见解和经验,选择WordPress是因为它专为博客设计,功能强大且易于使用。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
  • 如何在Django框架中实现对象关系映射(ORM)
    本文介绍了Django框架中对象关系映射(ORM)的实现方式,通过ORM,开发者可以通过定义模型类来间接操作数据库表,从而简化数据库操作流程,提高开发效率。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • JUnit下的测试和suite
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 如何将955万数据表的17秒SQL查询优化至300毫秒
    本文详细介绍了通过优化SQL查询策略,成功将一张包含955万条记录的财务流水表的查询时间从17秒缩短至300毫秒的方法。文章不仅提供了具体的SQL优化技巧,还深入探讨了背后的数据库原理。 ... [详细]
  • 在尝试启动Java应用服务器Tomcat时,遇到了org.apache.catalina.LifecycleException异常。本文详细记录了异常的具体表现形式,并提供了有效的解决方案。 ... [详细]
  • Tomcat SSL 配置指南
    本文详细介绍了如何在 Tomcat 中配置 SSL,以确保 Web 应用的安全性。通过正确的配置,可以启用 HTTPS 协议并保护数据传输的安全。 ... [详细]
  • MySQL Administrator: 监控与管理工具
    本文介绍了 MySQL Administrator 的主要功能,包括图形化监控 MySQL 服务器的实时状态、连接健康度、内存健康度以及如何创建自定义的健康图表。此外,还详细解释了状态变量和系统变量的管理。 ... [详细]
author-avatar
潘泓浩_236
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有