servlet访问数据库

这篇博客展示了如何在Servlet应用中通过JDBC连接到MySQL数据库。首先,需要将数据库驱动放入Tomcat的lib目录。然后,使用`@WebServlet`注解定义Servlet,通过`Class.forName()`注册驱动,`DriverManager.getConnection()`建立连接,创建Statement执行SQL查询,并遍历ResultSet处理查询结果。最后,记得正确关闭资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// 注: 在访问数据库的时候需要将数据库的驱动包放在Tomcat工具下的lib包中
// 本例用了JDBC的方式范文数据库
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;
import java.util.Properties;
import java.util.logging.Logger;

@WebServlet(urlPatterns = "/testServlet") // 利用servlet3.0的新特性注解方式
public class TestServlet extends HttpServlet { 
   static final String url = "jdbc:mysql://localhost:3306/day04"; // 数据的的访问方式
   static final String user = "root";//数据库名称
   static final String password = "root";//访问数据库密码
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        Connection conn = null;
        Statement stmt = null;
        ResultSet rs = null;
        try {
            // 1 注册驱动 //用的反射技术
            Class.forName("com.mysql.jdbc.Driver");
            // 2 创建连接
            conn = DriverManager.getConnection(url, user, password);
            // 3 获得发送sql的对象
            stmt = conn.createStatement();
            // 4 执行sql 获得结果
            String sql = "select * from user";
            rs = stmt.executeQuery(sql);
            // 5    处理结果遍历数据库将其打印在控制台
            while (rs.next()){
                int id = rs.getInt("id");
                String username = rs.getString("NAME");
                String pwd = rs.getString("PASSWORD");
                System.out.println(id + "===" + username + ":::" + pwd);
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            // 6 释放资源
            try {if (rs != null) {rs.close();}} catch (SQLException e) {e.printStackTrace();}
            try {if (stmt != null) {stmt.close();}} catch (SQLException e) {e.printStackTrace();}
            try {if (conn != null) {conn.close();}} catch (SQLException e) {e.printStackTrace();}
        }
    }
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        doGet(request,response);
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值