java - "Cannot find symbol"使用Class.forName()时出现问题

标签 java

我的代码中出现找不到符号错误。有谁知道什么会导致这个问题?

代码是:

// 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/

相关文章:

Java 从 DataStream 切换到 ObjectStream

javax.servlet.ServletException : Servlet execution threw an exception:org. apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)

java - 如何删除分隔符内的空间?

java - 实现具有两个不同方法签名和主体的接口(interface)

java - 调用 Facebook API 的 Servlet 获取访问 token

java - 如何从excel文件中获取值?

java - 使用 Google BigQuery 并使用 Compute Engine?

java - 如何从谷歌日历获取日期时间

java - Gradle:使用 Spring Boot 依赖项构建 'fat jar'

java - 线程转储 : The hexa-decimal (lock, 条件等) - 它们是什么,以及如何理解它们是什么?