热门标签 | 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中  ,为了看的更直观 ,我就没有更改……

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


推荐阅读
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Servlet多用户登录时HttpSession会话信息覆盖问题的解决方案
    本文讨论了在Servlet多用户登录时可能出现的HttpSession会话信息覆盖问题,并提供了解决方案。通过分析JSESSIONID的作用机制和编码方式,我们可以得出每个HttpSession对象都是通过客户端发送的唯一JSESSIONID来识别的,因此无需担心会话信息被覆盖的问题。需要注意的是,本文讨论的是多个客户端级别上的多用户登录,而非同一个浏览器级别上的多用户登录。 ... [详细]
  • 项目运行环境配置及可行性分析
    本文介绍了项目运行环境配置的要求,包括Jdk1.8、Tomcat7.0、Mysql、HBuilderX等工具的使用。同时对项目的技术可行性、操作可行性、经济可行性、时间可行性和法律可行性进行了分析。通过对数据库的设计和功能模块的设计,确保系统的完整性和安全性。在系统登录、系统功能模块、管理员功能模块等方面进行了详细的介绍和展示。最后提供了JAVA毕设帮助、指导、源码分享和调试部署的服务。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 分享css中提升优先级属性!important的用法总结
    web前端|css教程css!importantweb前端-css教程本文分享css中提升优先级属性!important的用法总结微信门店展示源码,vscode如何管理站点,ubu ... [详细]
  • Java如何导入和导出Excel文件的方法和步骤详解
    本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • 面试经验分享:华为面试四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试
    最近有朋友去华为面试,面试经历包括四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试。80%的人都在第一轮电话面试中失败,因为缺乏基础知识。面试问题涉及 ... [详细]
  • 在IDEA中运行CAS服务器的配置方法
    本文介绍了在IDEA中运行CAS服务器的配置方法,包括下载CAS模板Overlay Template、解压并添加项目、配置tomcat、运行CAS服务器等步骤。通过本文的指导,读者可以轻松在IDEA中进行CAS服务器的运行和配置。 ... [详细]
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社区 版权所有