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

运行时错误:java.lang.ClassNotFoundException:com.mysql.jdbc.Driver,java,mysql,jdbc,classnotfoundexception,Java,Mysql,Jdbc,Classnotfoundexception,我是mysql和jdbc新手,我在这个标题中发现了错误。我搜索了一整天,找不到适合我的解决方案 我所尝试的: 卸载/重新安装mysql,将mysql-connector-java-5.1.25-bin.jar和ojdbc7.jar复制粘贴到与我尝试运行的.class文件相同的位置,在不同的目录中重建程序,可能还有一些其他事情 我正在使用记事本++进行编码,并使用windows命令提示符进行编译和运行。它编译得很好,但我尝试使用 C:\Projects\bin>java-cp。客户群 输出为: j

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

我所尝试的: 卸载/重新安装mysql,将mysql-connector-java-5.1.25-bin.jar和ojdbc7.jar复制粘贴到与我尝试运行的.class文件相同的位置,在不同的目录中重建程序,可能还有一些其他事情

我正在使用记事本++进行编码,并使用windows命令提示符进行编译和运行。它编译得很好,但我尝试使用

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

输出为:

java.lang.ClassFoundException: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)
位于java.lang.ClassLoader.loadClass(ClassLoader.java:432)
位于sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
位于java.lang.ClassLoader.loadClass(ClassLoader.java:356)
在java.lang.Class.forName0(本机方法)
位于java.lang.Class.forName(Class.java:188)
位于ClientBase.main(ClientBase.java:21)
再见

我还应该说,我正在进行这段代码的在线教程。这并不完全是他们如何拥有的,因为我决定做一些与他们有点不同的东西,但大体上是一样的。我不认为这是一个代码问题,虽然从错误是什么


任何帮助都将不胜感激!我快疯了

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

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
你进口了什么? 从文件中:

评论:


你为什么使用记事本++?安装IDE(Eclipse/Netbeans/IntelliJ)-查找此类问题(例如未包含jar)会容易得多。

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

mysql.connector-java-x.x.x-bin.jar添加到您的libraries文件夹中。不需要进口任何东西。祝你好运。

我也遇到了同样的问题:-

如何解决Linux系统的问题

1。)从给定链接或其他链接下载文件

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

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

java-cp.:mysql-connector-java-5.1.18-bin.jar您的文件名


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

如果您使用的是
Swing
您必须添加


否则,如果您使用的是
jsp servlet
,您必须添加外部jar并将该jar复制到WEB\u INF/lib项目文件夹中

您可以发布文件夹层次结构吗?
//最后一个用于关闭资源的块
-真的吗?那你为什么要关闭它们呢?也尝试格式化你的代码!!!谢谢你,这成功了!我在其他帖子中看到了同样的答案,但我没有从他们那里理解,并且在jar和ClientBase的完整类路径后添加了一个分号,从而输入了错误的答案。我也遇到了同样的问题:-我获取文件并将其粘贴到保存类文件的同一文件夹中,然后在我的linux java-cp中运行以下命令:mysql-connector-java-5.1.18-bin.jar FirstExample我正在通过NetBeans运行项目,如何将其配置为“default”,以便不必每次都传递命令行参数?请澄清“;”和“:”之间的区别:“它给我带来了麻烦。
c:\>javac Test.java
c:\>java -cp .;F:\CK\JavaTest\JDBCTutorial\mysql-connector-java-5.1.18-bin Test
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
// Notice, do not import com.mysql.jdbc.*
// or you will have problems!