Latest web development tutorials

서블릿 데이터베이스 액세스

이 튜토리얼에서는 JDBC 응용 프로그램을 작동 알고 있다고 가정합니다. 당신은 서블릿 데이터베이스 액세스를 배우기 시작하기 전에 참조하시기 바랍니다 자바 MySQL의 연결을 설정하고 관련 드라이버를 구성 할 수 있습니다.

참고 :

당신이 사이트를 다운로드 할 수 항아리 패키지 제공 : MySQL의 커넥터 - 자바-5.1.39-bin.jar를

자바 프로젝트에서, 우리는 이클립스 자바 프로젝트에서 실행할 수있는 MySQL의 커넥터 - 자바-5.1.39-bin.jar를 도입 할 필요가있다.

우리는 Class.forName를 ( "om.mysql.jdbc.Driver")를 실행할 때 이클립스 웹 프로젝트에; 구동 할 때 발견하지 않을. 이 경우에 그래서 우리는 MySQL의 커넥터 - 자바-5.1.39-bin.jar를하는 바람둥이 lib 디렉토리에 복사를해야합니다.

시작하는 기본 개념에서의 간단한 테이블을 만들 수, 테이블에 몇 가지 레코드를 만들 수 있습니다.


테스트 데이터를 생성

다음으로 우리는 MySQL 데이터베이스에 w3big 작성, 웹 사이트 및 데이터 테이블을 만들고 다음과 같이 테이블 구조는 다음과 같습니다

CREATE TABLE `websites` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` char(20) NOT NULL DEFAULT '' COMMENT '站点名称',
  `url` varchar(255) NOT NULL DEFAULT '',
  `alexa` int(11) NOT NULL DEFAULT '0' COMMENT 'Alexa 排名',
  `country` char(10) NOT NULL DEFAULT '' COMMENT '国家',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

일부 데이터를 삽입합니다 :

INSERT INTO `websites` VALUES ('1', 'Google', 'https://www.google.cm/', '1', 'USA'), ('2', '淘宝', 'https://www.taobao.com/', '13', 'CN'), ('3', '本教程', 'http://www.w3big.com', '5892', ''), ('4', '微博', 'http://weibo.com/', '20', 'CN'), ('5', 'Facebook', 'https://www.facebook.com/', '3', 'USA');

데이터 테이블은 다음과 같습니다 :



Access 데이터베이스

다음의 예는 서블릿 액세스 w3big 데이터베이스를 사용하는 방법을 보여줍니다.

package com.w3big.test;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet implementation class DatabaseAccess
 */
@WebServlet("/DatabaseAccess")
public class DatabaseAccess extends HttpServlet {
	private static final long serialVersionUID = 1L;
	// JDBC 驱动名及数据库 URL
	static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  
	static final String DB_URL = "jdbc:mysql://localhost:3306/w3big";
	
	// 数据库的用户名与密码,需要根据自己的设置
	static final String USER = "root";
	static final String PASS = "123456"; 
    /**
     * @see HttpServlet#HttpServlet()
     */
    public DatabaseAccess() {
        super();
        // TODO Auto-generated constructor stub
    }

	/**
	 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		Connection conn = null;
		Statement stmt = null;
		// 设置响应内容类型
		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		String title = "Servlet Mysql 测试 - 本教程";
		String docType = "<!DOCTYPE html>\n";
		out.println(docType +
		"<html>\n" +
		"<head><title>" + title + "</title></head>\n" +
		"<body bgcolor=\"#f0f0f0\">\n" +
		"<h1 align=\"center\">" + title + "</h1>\n");
		try{
			// 注册 JDBC 驱动器
			Class.forName("com.mysql.jdbc.Driver");
			
			// 打开一个连接
			conn = DriverManager.getConnection(DB_URL,USER,PASS);

			// 执行 SQL 查询
			stmt = conn.createStatement();
			String sql;
			sql = "SELECT id, name, url FROM websites";
			ResultSet rs = stmt.executeQuery(sql);

			// 展开结果集数据库
			while(rs.next()){
				// 通过字段检索
				int id  = rs.getInt("id");
				String name = rs.getString("name");
				String url = rs.getString("url");
	
				// 输出数据
				out.println("ID: " + id);
				out.println(", 站点名称: " + name);
				out.println(", 站点 URL: " + url);
				out.println("<br />");
			}
			out.println("</body></html>");

			// 完成后关闭
			rs.close();
			stmt.close();
			conn.close();
		} catch(SQLException se) {
			// 处理 JDBC 错误
			se.printStackTrace();
		} catch(Exception e) {
			// 处理 Class.forName 错误
			e.printStackTrace();
		}finally{
			// 最后是用于关闭资源的块
			try{
				if(stmt!=null)
				stmt.close();
			}catch(SQLException se2){
			}
			try{
				if(conn!=null)
				conn.close();
			}catch(SQLException se){
				se.printStackTrace();
			}
		}
	   
	}

	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		doGet(request, response);
	}
}

이제 위의 서블릿을 컴파일하고 web.xml 파일에 다음 항목을 만들 수 있습니다 :

....
	<servlet>
		<servlet-name>DatabaseAccess</servlet-name>
		<servlet-class>com.w3big.test.DatabaseAccess</servlet-class>
	</servlet>
	<servlet-mapping>
		<servlet-name>DatabaseAccess</servlet-name>
		<url-pattern>/TomcatTest/DatabaseAccess</url-pattern>
	</servlet-mapping>
....

HTTP : // localhost를 : 8080 / TomcatTest / DatabaseAccess, 결과는 다음과 같은 응답이 표시됩니다 이제 링크를 입력,이 서블릿을 호출