我的代码中出现找不到符号
错误。有谁知道什么会导致这个问题?
代码是:
// Register JDBC driver
Class.forName("net.sourceforge.jtds.jdbc.Driver");
错误输出为:
blah.java:314: cannot find symbol
symbol : method forName(java.lang.String)
location: class java.lang.Class
Class.forName("net.sourceforge.jtds.jdbc.Driver");
^
1 error
<小时/>
//STEP 1. Import required packages
import java.sql.*;
public class JDBCExample {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "com.sql.jdbc.Driver";
static final String DB_URL = (":jdbc:jtds:sqlserver://localhost:1433/tempdb" );
// Database credentials
static final String USER = "username";
static final String PASS = "password";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try{
//STEP 2: Register JDBC driver
Class.forName("net.sourceforge.jtds.jdbc.Driver");
//STEP 3: Open a connection
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL, USER, PASS);
//STEP 4: Execute a query
System.out.println("Creating database...");
stmt = conn.createStatement();
String sql = "CREATE DATABASE ";
stmt.executeUpdate(sql);
System.out.println("Database created successfully...");
}catch(SQLException se){
//Handle errors for JDBC
se.printStackTrace();
}catch(Exception e){
//Handle errors for Class.forName
e.printStackTrace();
}finally{
//finally block used to close resources
try{
if(stmt!=null)
stmt.close();
}catch(SQLException se2){
}// nothing we can do
try{
if(conn!=null)
conn.close();
}catch(SQLException se){
se.printStackTrace();
}//end finally try
}//end try
System.out.println("Goodbye");
}//end main
}//end JDBCExample
最佳答案
Class.forName()
失败的主要方式是类路径上没有可用的 JDBC 驱动程序,但这将是一个运行时错误,而不是编译时错误,如下所示你似乎快到了。
利用我的心灵调试能力,我认为您可能正在使用 GWT。我不相信它在客户端允许这样做(它被转换为 JavaScript)。所有 JDBC 内容都必须保留在服务器端。 Google 自己发布了 JRE emulation reference这样你就可以看到什么是允许的。
Class
支持的方法仅限于:
- desiredAssertionStatus()
- getEnumConstants()
- getName()
- getSuperclass()
- isArray()
- isEnum()
- isInterface()
- isPrimitive()
- toString()
如果我对您使用 GWT 的看法是正确的,那么最好使用 GWT-RPC 在客户端和服务器之间进行通信,并让服务器本身发出 JDBC 调用。
如果您想了解有关 GWT-RPC 的更多信息,请参阅 here 。有一个thread在 GWT 新闻组中,您可以阅读该新闻组以获取更多信息。
关于java - "Cannot find symbol"使用Class.forName()时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3034867/