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

5

我是mysql和jdbc的新手,在这个标题中遇到了错误。我已经搜索了一整天,但找不到适合我的解决方案。

我尝试过以下方法:卸载/重新安装mysql,将mysql-connector-java-5.1.25-bin.jar和ojdbc7.jar复制粘贴到与我正在运行的.class文件相同的位置,重新在不同的目录中构建程序,以及可能还有其他一些东西。

我使用notepad++编写代码,并使用Windows命令提示符进行编译和运行。它可以编译,但是当我尝试运行时:

C:\Projects\bin>java -cp . ClientBase

输出如下:

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

at java.net.URLClassloader$1.run(URLClassLoader.java:336)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at 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(ClassLoader.java:356)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:188)
at ClientBase.main(ClientBase.java:21)
Goodbye.

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

我应该还是要说一下,这段代码是在一个在线教程中学到的。虽然我决定做出来的东西与他们的有些不同,但总体上是大致相同的。我认为这不是代码问题,因为错误信息并不是指向代码的。

如果能得到任何帮助,我将不胜感激!我已经快疯了!


你能发布文件夹层次结构吗? - ihsan kocak
// 最终块用于关闭资源 - 真的吗?那你为什么在 try 中关闭它们呢?还有,尝试格式化你的代码!!! - Mr_and_Mrs_D
6个回答

12

你需要将连接器库添加到Runtime类路径中:

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

谢谢,这个方法可行!我在其他帖子中看到了相同的答案,但是我没有从中理解,并且在输入时错误地在jar后添加了分号和完整的ClientBase类路径。 - user2669813
我也遇到了同样的问题:
我将文件复制到与我的类文件保存在同一文件夹中,然后在Linux中运行以下命令:
java -cp .:mysql-connector-java-5.1.18-bin.jar FirstExample
- HaRsH
我正在通过NetBeans运行项目,如何将其配置为“默认”,以便我不必每次传递命令行参数? - Malwinder Singh
感谢您对“;”和“:”之间差异的澄清,这一直困扰着我。 - OJVM

3

我也遇到了同样的问题:
以下是我在Linux系统上解决的方法。

1.) 从给定链接或其他地方下载文件mysql-connector-java-5.1.18-bin.jar

2.) 然后将其粘贴到与您的类或文件相同的文件夹或目录中(您希望连接出现在哪里)。

3.) 现在使用您的Linux命令提示符执行以下命令:

java -cp .:mysql-connector-java-5.1.18-bin.jar YourFileName ..

这就是您需要做的全部... :)


2
如果您使用Netbeans,请按照以下步骤操作: 1.打开Netbeans IDE 2.右键单击您的项目。 3.选择属性。 4.在左侧点击“库”。 5.在“编译”选项卡下,点击“添加Jar/文件夹”按钮。 6.选择下载的“mysql-connector-java-5.1.25-bin.jar”文件(从dev.mysql.com下载Connector/J)。 7.点击确定 再次运行... 它就可以工作了。

1

你导入了什么? 根据文档:http://dev.mysql.com/doc/connector-j/en/connector-j-usagenotes-connect-drivermanager.html

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
// Notice, do not import com.mysql.jdbc.*
// or you will have problems!

评论:

为什么你使用notepad++?安装一个IDE(Eclipse/Netbeans/IntelliJ)- 这样会更容易找到这样的问题(例如未包含的jar文件)


1
mysql.connector-java-x.x.x-bin.jar添加到您的库文件夹中。无需导入任何内容。祝一切顺利。

0
如果你正在使用 Swing,则必须添加 my-sql-connect 的外部 Jar 包。
如果你正在使用 jsp servlet,则必须添加外部 Jar 包并将该 Jar 包复制到项目文件夹的 WEB_INF/lib 目录中。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接