有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java项目中的MySQL驱动程序

我正在尝试开发Swing应用程序,它包含到MySQL 5数据库的连接。所以,我使用Maven提取了mysql连接器依赖项,但我仍然使用java。lang.ClassNotFoundException:mysql-connector-java-5.1.6。罐子

我的代码: 波姆。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) 个答案

  1. # 1 楼答案

    您需要通过pom向mysql连接器java提供依赖关系。xml。加上

    <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所指出的,它应该是类。forName(“com.mysql.jdbc.driver”)