我正在尝试与 MySQL 数据库建立连接,并且正在使用 Tomcat v6.0。Java中的源代码是这样的:
连接管理器.java
package admin;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class ConnectionManager {
private static ConnectionManager instance = null;
private static final String USERNAME = "root";
private static final String PASSWORD = "";
private static final String CONN_STRING =
"jdbc:mysql://localhost/sondazh";
private Connection conn = null;
private ConnectionManager() {
}
public static ConnectionManager getInstance() {
if (instance == null) {
instance = new ConnectionManager();
}
return instance;
}
private boolean openConnection() throws ClassNotFoundException {
try {
conn = DriverManager.getConnection(CONN_STRING, USERNAME, PASSWORD);
return true;
} catch (SQLException e) {
e.printStackTrace();
}
return false;
}
public Connection getConnection() {
if (conn == null) {
try {
if (openConnection()) {
return conn;
} else {
return null;
}
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return conn;
}
public void close() {
try {
conn.close();
conn = null;
} catch (Exception e) {
}
}
}
数据库对象.java
package admin;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.swing.JOptionPane;
public abstract class DatabaseObject {
private static Connection conn = ConnectionManager.getInstance()
.getConnection();
public static ResultSet query(String sql) {
try {
PreparedStatement stmt = conn.prepareStatement(sql);
ResultSet rs = stmt.executeQuery();
return rs;
} catch (Exception e) {
JOptionPane.showMessageDialog(null, e.getMessage());
System.out.println(e.getMessage());
return null;
}
}
public static boolean update(String sql){
try {
PreparedStatement stmt = conn.prepareStatement(sql);
int affected = stmt.executeUpdate();
if(affected == 0){
return false;
}
return true;
} catch (Exception e) {
System.out.println(e.getMessage());
return false;
}
}
public static int insert(String sql){
try {
Statement stmt = conn.createStatement();
int affected = stmt.executeUpdate(sql, Statement.RETURN_GENERATED_KEYS);
return affected;
} catch (Exception e) {
return 0;
}
}
}
我还为数据库中的所有实体创建了 getter 和 setter,但是当我运行它时显示错误:
HTTP 状态 404 - 类型状态报告
信息
描述 请求的资源不可用。
Apache Tomcat/6.0.36
我想显示来自用户实体的一些数据:
test.jsp
<%@page import="java.sql.Connection"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="admin.User"%>
<%@page import="admin.ConnectionManager"%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title> test </title>
</head>
<body>
<div>
<table>
<%
ResultSet rs = User.loadAll();
while (rs.next()) {
%>
<tr>
<TH>ID</TH>
<TH>Name</TH>
<TH>Surname</TH>
<TH>Email</TH>
</tr>
<tr>
<td> <%= rs.getInt(1) %> </td>
<td> <%= rs.getString(2) %> </td>
<td> <%= rs.getString(3) %> </td>
<td> <%= rs.getString(4) %> </td>
</tr>
</table>
</div>
<%
}
%>
</body>
</html>
这是我尝试运行的 test.jsp,但由于我之前提到的错误,我无法得到我想要的结果。Tomcat 正在运行。我的jsp代码可以吗?