技术文摘
JavaWeb 实现显示 MySQL 数据库数据的方法
2025-01-14 23:05:03 小编
JavaWeb 实现显示 MySQL 数据库数据的方法
在 JavaWeb 开发中,将 MySQL 数据库中的数据展示到页面上是一个常见的需求。本文将详细介绍实现这一功能的具体方法。
要确保开发环境的搭建。需要安装并配置好 JDK、Tomcat 服务器以及 MySQL 数据库,同时导入相关的 JDBC 驱动包,它是 Java 与 MySQL 数据库进行交互的桥梁。
接着,创建数据库和表,并插入测试数据。使用 SQL 语句创建一个数据库和包含所需字段的表,例如创建一个名为 “employees” 的表,包含 “id”、“name”、“age” 等字段,并插入几条数据用于测试。
在 Java 代码方面,需要编写数据库连接工具类。通过 JDBC 接口,利用 DriverManager.getConnection() 方法,传入数据库的 URL、用户名和密码来获取数据库连接对象。例如:
public class DBUtil {
private static final String URL = "jdbc:mysql://localhost:3306/yourdatabase";
private static final String USER = "root";
private static final String PASSWORD = "password";
public static Connection getConnection() throws SQLException {
return DriverManager.getConnection(URL, USER, PASSWORD);
}
}
然后,编写 DAO 层(数据访问对象)代码。在这里编写方法从数据库中查询数据。例如,查询 “employees” 表中所有数据的方法:
public class EmployeeDAO {
public List<Employee> getAllEmployees() {
List<Employee> employees = new ArrayList<>();
String sql = "SELECT * FROM employees";
try (Connection conn = DBUtil.getConnection();
PreparedStatement pstmt = conn.prepareStatement(sql);
ResultSet rs = pstmt.executeQuery()) {
while (rs.next()) {
Employee employee = new Employee();
employee.setId(rs.getInt("id"));
employee.setName(rs.getString("name"));
employee.setAge(rs.getInt("age"));
employees.add(employee);
}
} catch (SQLException e) {
e.printStackTrace();
}
return employees;
}
}
接下来是 Servlet 层。Servlet 负责接收请求,调用 DAO 层方法获取数据,并将数据传递给 JSP 页面。
@WebServlet("/employees")
public class EmployeeServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
EmployeeDAO dao = new EmployeeDAO();
List<Employee> employees = dao.getAllEmployees();
request.setAttribute("employees", employees);
request.getRequestDispatcher("employees.jsp").forward(request, response);
}
}
最后,在 JSP 页面中使用 EL 表达式和 JSTL 标签库来展示数据。例如:
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<html>
<head>
<title>员工列表</title>
</head>
<body>
<h2>员工列表</h2>
<table border="1">
<tr>
<th>ID</th>
<th>姓名</th>
<th>年龄</th>
</tr>
<c:forEach var="employee" items="${employees}">
<tr>
<td>${employee.id}</td>
<td>${employee.name}</td>
<td>${employee.age}</td>
</tr>
</c:forEach>
</table>
</body>
</html>
通过以上步骤,就能在 JavaWeb 应用中成功显示 MySQL 数据库中的数据。掌握这种方法,对于开发各种数据驱动的 Web 应用至关重要。