我想尝试一个示例JDBC练习,所以我使用Maven Quickstart Archetype创建了一个项目。
public class App {
static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
static final String DB_URL = "jdbc:mysql://localhost:3306/testdb";
static final String USER = "root";
static final String PASS = "password";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try{
Class.forName("com.mysql.jdbc.Driver");
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
System.out.println("Creating statement...");
stmt = conn.createStatement();
. . . .
. . . .
当我尝试运行它时,
mvn package
java -cp target/simple-java-1.0-SNAPSHOT.jar com.test.App
我明白了:
java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Unknown Source)
at com.test.App.main(App.java:24)
但是,如果我只是尝试直接运行应用程序,比如在IntelliJ中将其作为应用程序运行,它可以正常工作。 我试过添加一个罐子,但它仍然没有用。
我在这里缺少什么?
答案 0 :(得分:0)
我遇到了同样的问题。我可以通过添加MySQL连接器Maven dependency来解决。 (我添加的唯一插件是Tomcat Maven插件。)
您不再需要Class.forName("com.mysql.jdbc.Driver");
。