我正在尝试开发Swing应用程序,它包含与MySQL 5数据库的连接。所以,我使用Maven提取了mysql连接器依赖,但我仍然得到java.lang.ClassNotFoundException:mysql-connector-java-5.1.6.jar。
我的代码: 的pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</project>
连接方法:
public Connection connect() throws ClassNotFoundException, SQLException {
Class.forName("com.mysql.jdbc.driver");
Connection connection= DriverManager.getConnection(
"jdbc:mysql://localhost:3306/myDatabase","root","");
return connection;
}
我得到例外:
java.lang.ClassNotFoundException: com.mysql.jdbc.driver
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:264)
at Test.connect(Main.java:29)
at Test.<init>(Main.java:21)
at Main.main(Main.java:11)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:144)
我甚至将连接器jar添加到项目类路径中。我正在使用Intellij IDE 但由于某种原因,它不会连接。有什么建议吗?
答案 0 :(得分:0)
您需要通过pom.xml为mysql-connector-java提供依赖项。添加
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
</dependencies>
到你的pom.xml(应该命名为pom.xml而不是maven.xml)。
您自己的groupId,artifactId和版本当然应该反映您自己的项目 - 所以最后您将拥有以下pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>mygroup</groupId>
<artifactId>myartifact</artifactId>
<version>1.0.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
</dependencies>
</project>
顺便说一下:5.1.6已经过时了 - 检查当前的https://mvnrepository.com/artifact/mysql/mysql-connector-java(当前为6.0.5)
并且 - 正如user2004685指出它应该是Class.forName(&#34; com.mysql.jdbc.driver&#34;)