【发布时间】:2016-04-30 13:22:42
【问题描述】:
我正在 NetBeans 8.1 中构建一个简单的 HelloWorld 应用程序。 它必须工作简单,一旦编译并运行,它将使用 MySQL 将表 acc 的所有数据加载到数据库帐户中。
我已经在我的项目库中包含了 Connector/J jar 文件并与 MySQL 建立了连接,但 Class.forName(com.mysql.jdbc.Driver).newInstance();一段代码中的行显示“未报告的异常 InstantiationException;必须被捕获或声明为被抛出”,我完全不知道该怎么做。我有点卡在这里。
这是我的代码
package learning_jdbc;
import java.sql.*;
public class Hello {
Connection connection;
private void displaySQLErrors(SQLException e) {
System.out.println("SQLException: " + e.getMessage());
System.out.println("SQLState: " + e.getSQLState());
System.out.println("VendorError: " + e.getErrorCode());
}
public Hello() {
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
} catch (ClassNotFoundException e) {
System.out.println("Class not found.");
}
}
public void connectToDB() {
try {
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/accounts","root","thejoker");
} catch(SQLException e) {
displaySQLErrors(e);
}
}
public void executeSQL() {
try (Statement statement = connection.createStatement();
ResultSet rs = statement.executeQuery("SELECT * FROM acc")) {
while (rs.next()) {
System.out.println(rs.getString(1));
}
connection.close();
} catch(SQLException e) {
displaySQLErrors(e);
}
}
public static void main(String[] args) {
Hello hello = new Hello();
hello.connectToDB();
hello.executeSQL();
}
}
【问题讨论】:
-
您认为该错误消息是什么意思?你能改写一下吗?这是我的尝试:“您必须捕获 InstantiationException。或者您必须声明它可以被抛出。”。阅读docs.oracle.com/javase/tutorial/essential/exceptions。了解此消息的含义以及异常的工作原理很重要,但请注意,这行代码不是必需的。
标签: java mysql jdbc connector-j