![](/img/trans.png)
[英]Netbeans doesn't recognize import com.mysql.jdbc.jdbc2.optional.MysqlDataSource?
[英]ClassNotFoundException: com.mysql.jdbc.jdbc2.optional.MysqlDataSource
我在我的項目中使用Hikari庫進行MySQL連接。 當我嘗試運行該程序時,我得到一個ClassNotFoundException:com.mysql.jdbc.jdbc2.optional.MysqlDataSource錯誤。 我想我必須在我的項目中包含mysql-connector庫。
這是我的pom.xml
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.34</version>
</dependency>
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP-java6</artifactId>
<version>2.0.1</version>
</dependency>
<dependency>
<groupId>org.javassist</groupId>
<artifactId>javassist</artifactId>
<version>3.18.1-GA</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.7.5</version>
</dependency>
<dependency>
<groupId>io.netty</groupId>
<artifactId>netty-all</artifactId>
<version>4.1.0.Beta3</version>
<scope>compile</scope>
</dependency>
</dependencies>
<build>
<finalName>GridControl</finalName>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.4</version>
<configuration>
<archive>
<manifestEntries>
<Main-Class>net.thegridmc.control.GridControl</Main-Class>
</manifestEntries>
</archive>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.3</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<minimizeJar>true</minimizeJar>
<createDependencyReducedPom>false</createDependencyReducedPom>
<artifactSet>
<includes>
<include>mysql:*</include>
<include>org.slf4j:*</include>
<include>com.zaxxer:*</include>
<include>org.javassist:javassist</include>
<include>io.netty:netty-all</include>
</includes>
</artifactSet>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
jar已成功構建,但仍會出現錯誤。 非常感謝任何幫助。 謝謝。
試試com.mysql.cj.jdbc.MysqlDataSource
。 它適用於
mysql-connector-java 6.0.4
我設法通過將“minimizeJar”設置為false來解決此問題。 我不太熟悉maven,所以我不知道這是怎么解決的,但確實如此。
所以升級Spring
版本后我遇到了同樣的問題。 問題已經有了正確的答案,但缺乏細節。 要連接到數據源(例如: MySQL
),您需要有適當的驅動程序。 以前Driver
曾經在com.mysql.jdbc.Driver
但現在它位於com.mysql.cj.jdbc.Driver
。 因此,您需要更新數據源定義。
<bean id="dataSource" class="com.mysql.cj.jdbc.MysqlDataSource"
destroy-method="close">
<property name="url" value="${jdbc.url}" /> <!-- Loaded from application.properties file -->
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="maxIdle" value="1" />
</bean>
Hikari示例:
<bean id="hikariConfig" class="com.zaxxer.hikari.HikariConfig">
<property name="poolName" value="springHikariCP" />
<property name="connectionTestQuery" value="SET NAMES utf8mb4" />
<property name="dataSourceClassName" value="com.mysql.cj.jdbc.MysqlDataSource" />
<property name="dataSourceProperties">
<props>
<prop key="url">${jdbc.url}</prop> <!-- Loaded from application.properties file -->
<prop key="user">${jdbc.username}</prop>
<prop key="password">${jdbc.password}</prop>
</props>
</property>
</bean>
<bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource"
destroy-method="close">
<constructor-arg ref="hikariConfig" />
</bean>
HikariCP聲明不使用驅動程序配置,您應該為MySQL定義jdbcUrl:
MySQL Connector / J com.mysql.jdbc.jdbc2.optional.MysqlDataSource
已知MySQL數據源在網絡超時支持方面被打破。 請改用jdbcUrl配置。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.