当前位置: 首页 > 面试题库 >

运行时错误:java.lang.ClassNotFoundException:com.mysql.jdbc.Driver

贺跃
2023-03-14
问题内容

我是mysql和jdbc的新手,但出现此标题错误。我整天都在搜索,找不到适合我的解决方案。

我尝试过的操作:卸载/重新安装mysql,将mysql-connector-
java-5.1.25-bin.jar和ojdbc7.jar复制粘贴到与我要运行的.class文件相同的位置,然后将该程序重建在其他目录中,可能还有其他几件事。

我正在使用notepad ++进行编码,并使用Windows命令提示符进行编译和运行。它编译正常,但我尝试与

C:\ Projects \ bin> java -cp。客户端库

输出为:

java.lang.ClassnNotFoundException:com.mysql.jdbc.Driver

在java.net.URLClassLoader $ 1.run(URLClassLoader.java:336)
在java.net.URLClassLoader $ 1.run(URLClassLoader.java:355)
在java.security.AccessController.doPrivileged(本机方法)
在java.net.URLClassLoader .findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:432)
at sun.misc.Launcher $ AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass( 再见 ClientBase.main(ClientBase.java:21)
处java.lang.Class.forName0(本机方法)
处的ClassLoader.java:356)(本机方法

再见。

// import packages
import java.sql.*;

// create class ClientBase
public class ClientBase{
            // JDBC driver name and database URL
            static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";                
            static final String DB_URL = "jdbc:mysql://localhost/CLIENTBASE";



 // Database credentials
    static final String USER = "root";
    static final String PASS = "";

// Begin method main
public static void main(String[] args) {
    Connection conn = null;
    Statement stmt = null;

    try{
        // register JDBC driver
        Class.forName("com.mysql.jdbc.Driver");

        // Open connection
        System.out.println("Connecting to database...");
        conn = DriverManager.getConnection(DB_URL, USER, PASS);

        // Execute a query
        System.out.println("Creating statement...");
        stmt = conn.createStatement();
        String sql;
        sql = "SELECT id, name, address, address 2, city, phone, state, zip, fax FROM CLIENTBASE";
        ResultSet rs = stmt.executeQuery(sql);

        // Extract data from result set
        while(rs.next()){
            // Retrieve by column name
            int id = rs.getInt("id");
            String name = rs.getString("name");
            String address = rs.getString("address");
            String address2 = rs.getString("address2");
            String city = rs.getString("city");
            String phone = rs.getString("phone");
            String state = rs.getString("state");
            String zip = rs.getString("zip");
            String fax = rs.getString("fax");

            // Display values
            System.out.print("ID: " + id);
            System.out.print(" Name: " + name);
            System.out.println("Address:" + address);
            System.out.println(address2);
            System.out.print("City:" + city);
            System.out.print(" State: " + state);
            System.out.println(" Zip: " + zip);
            System.out.print("Phone: " + phone);
            System.out.println(" Fax: " + fax);
        } // end while

        // clean up
        rs.close();
        stmt.close();
        conn.close();
    }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 se){
            se.printStackTrace();
        } // end finally
    } // end try
System.out.println("Goodbye.");
} // End method main
} // end class ClientBase

我还应该说我正在为该代码准备在线教程。我决定做一些与他们有所不同的事情时,这并不完全是他们拥有的东西,但通常是相同的。我不认为这是一个代码问题,尽管从错误是什么。

任何帮助,将不胜感激!我要疯了!


问题答案:

您需要将连接器库添加到运行时类路径:

java -cp .;mysql-connector-java-5.1.25-bin.jar ClientBase

我的示例使用Windows类路径分隔符";",在其他系统上可能有所不同(":"在Linux / Mac上)。它还假定mysql- connector-java-5.1.25-bin.jar该文件位于同一文件夹中。如果不是这种情况,请在库中放置一个路径,而不要使用纯名称。

ClientBase 这里代表Java类文件名

c:\>javac Test.java
c:\>java -cp .;F:\CK\JavaTest\JDBCTutorial\mysql-connector-java-5.1.18-bin Test


 类似资料:
  • 我正在尝试仅使用本地依赖项编译和运行java grpc客户端,但出现以下错误: 这是我的gradle文件: 程序将编译,但不运行。我已经从protos生成了我的java文件,并验证了我是否使用了正确的protoc和protoc gen grpc java与我正在使用的jar库相对应。非常感谢您的帮助。

  • 我收到一个奇怪的错误。在我初始化总数的线上。如果你有空闲时间帮我,我不明白; 第10行:Char 24:运行时错误:-inf超出了“int”(solution.cpp)类型的可表示值的范围摘要:UndefinedBehaviorSanitizer:undefined behavior prog_joined。cpp:19:24

  • 这个程序应该在一个JFrame中添加两个面板,每个面板都有一个开关按钮,允许用户在每个面板之间切换。它编译得很好,但是当我试图单击Switch1按钮时,我得到了这个错误: java线程“AWT-EventQueue-0”中出现异常。ClassCastException:java。awt。无法将BorderLayout转换为java。awt。测试仪上的卡片布局。在javax上执行的操作(tester

  • 我试图插入到一个MySQL数据库,代码工作和插入,但立即崩溃,看不出问题。 Applications.loginandRegister e/AndroidRuntime:致命异常:主进程:Applications.loginandRegister,PID:2545 Android.view.WindowManager$BadTokenException:无法添加窗口--令牌Android.os.B

  • 问题内容: 练习信: 给定一个mxn元素的矩阵(m行,n列),以螺旋顺序返回矩阵的所有元素。 例如,给定以下矩阵: 给定代码: 我的代码: 错误: 有什么建议?我真的无法分辨出什么问题。为什么超出范围?锻炼可以在这里找到 问题答案: 我用此矩阵尝试了您的方法: 我什么也没得到。您的代码似乎没有引发任何错误。 但是,我注意到输出不符合预期。它给我的输出是(只有8个数字),缺少矩阵中间的数字。 仔细查

  • 问题内容: 我的意图是读取原始资源,然后使用JSON将其转换为Java代码。执行此操作的类和外部库存储在另一个项目中。当我运行我的应用程序时,在日志猫中出现此错误: 我可以说该错误是由JSONArray的创建引起的。我已经在stackoverflow上遇到过此错误,但是没有明确的方法来解决此问题。任何人都可以向我推荐解决此问题的方法。帮助将不胜感激。 问题答案: 您正在添加似乎具有未解决依赖性的n