dbexceptionservlet.java

来自「孙鑫的Java Web开发详解一书的源代码」· Java 代码 · 共 72 行

JAVA
72
字号
package org.sunxin.lesson.jsp.ch10;

import javax.servlet.*;
import java.io.*;
import javax.servlet.http.*;
import java.sql.*;

public class DBExceptionServlet extends HttpServlet
{
    public void init() throws ServletException
    {
        try
        {
            Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
            
        }
        catch(ClassNotFoundException ce)
        {
            throw new UnavailableException("加载数据库驱动失败!");
        }
    }
    
    public void doGet(HttpServletRequest req, HttpServletResponse resp)
               throws ServletException,IOException
    {   
        Connection conn=null;
        Statement stmt=null;
        try
        {
            conn=DriverManager.getConnection(
            "jdbc:microsoft:sqlserver://localhost:1433;databasename=pubs","sa","winsun1234");
            stmt=conn.createStatement();
            stmt.executeUpdate("delete from jobs where job_id=13");
        }
        catch(SQLException se)
        {
            
            getServletContext().log("ServletContext.log(): 数据库操作失败!"+
                                    se.toString());
            log("GenericServlet.log(): 数据库操作失败!"+se.toString());
            resp.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR,
                        "数据库操作出现问题,请联系管理员。");
        }
        finally
        {
            if(stmt!=null)
            {
                try
                {
                    stmt.close();
                }
                catch(SQLException se)
                {
                    log("关闭Statement失败!",se);
                }
                stmt=null;
            }
            if(conn!=null)
            {
                try
                {
                    conn.close();
                }
                catch(SQLException se)
                {
                    log("关闭数据库连接失败!",se);
                }
                conn=null;
            }
        }
    }
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?