java项目中的MySQL驱动程序

时间:2017-01-05 18:52:34

标签: java mysql jdbc

我正在尝试开发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)

目录结构: Directory structure

我甚至将连接器jar添加到项目类路径中。我正在使用Intellij IDE 但由于某种原因,它不会连接。有什么建议吗?

1 个答案:

答案 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;)