4

我是 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(Native Method)
在 java.net.URLClassLoader .findClass(URLClassLoader.java:354)
在 java.lang.ClassLoader.loadClass(ClassLoader.java:432)
在 sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
在 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)
再见。

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

我还应该说我要关闭此代码的在线教程。这不是他们拥有它的方式,因为我决定制作一些与他们不同的东西,但通常是相同的。我认为这不是代码问题,尽管错误是什么。

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

4

6 回答 6

11

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

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
于 2013-08-10T05:21:30.463 回答
3

I was also get same problem :-
我是如何解决Linux 系统的。

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

2.)然后将其粘贴到您的类或文件的同一文件夹或目录(在您希望连接出现的位置)

3.)现在在您的 linux 命令提示符下使用以下命令。

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

这就是你需要做的一切...... :)

于 2014-08-07T09:34:16.887 回答
2

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

于 2014-02-20T04:46:16.937 回答
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!

评论:

你为什么使用记事本++?安装 IDE (Eclipse/Netbeans/IntelliJ) - 定位此类问题会容易得多(例如,未包含的 jars)

于 2013-08-10T05:21:56.800 回答
1

添加mysql.connector-java-x.x.x-bin.jar到您的库文件夹。无需导入任何东西。祝你有个好的一天。

于 2014-07-13T17:43:42.810 回答
0

如果您正在使用Swing ,则必须添加my-sql-connect 的外部 Jar

否则,如果您正在使用jsp servlet您必须添加外部 jar 并将该 Jar 复制到WEB_INF/lib项目文件夹中

于 2017-05-16T17:16:11.883 回答