gpt4 book ai didi

java.sql.SQLException : No suitable driver found 异常

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:55:51 26 4
gpt4 key购买 nike

我正在尝试使用下面的 DbQuery.java 类执行简单查询,该类使用 DbConnector 从 DriverManager 获取连接。

注意:

  1. 我已经将“mysql-connector-java-5.1.25-bin.jar”包含在我的类路径通过:导出CLASSPATH=$CLASSPATH:/home/me/ocpjp/chapter-10/mysql-connector-java-5.1.25/mysql-connector-java-5.1.25-bin.jar
  2. 我可以使用“mysql -uroot -ptcial”连接到 mysql地址簿”,如果重要的话。
  3. 也试过用'-cp'运行争论无济于事。
  4. 我可以让我的#3 DbConnect.java 类显示“已建立数据库连接”。
  5. 另外 #4 DbQueryWorking.java 没有问题并提供预期的输出。

你能帮我理解这里的问题是什么吗?

1) 数据库连接器.java

package com.me.ocpjp.chapter10;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DbConnector{
public static Connection connectToDb() throws SQLException{
String url = "jdbc:mysql//localhost:3306/";
String db = "addressBook";
String username = "root";
String password = "tcial";
return DriverManager.getConnection(url+db, username, password);
}

}

2) 数据库查询.java

package com.me.ocpjp.chapter10;

import java.sql.Connection ;
import java.sql.Statement ;
import java.sql.ResultSet ;
import java.sql.SQLException ;
import com.me.ocpjp.chapter10.DbConnector;

public class DbQuery{
public static void main(String[] args){
try(Connection connection = DbConnector.connectToDb();
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery("select * from contact")){
System.out.println("ID \tfName \tlName \temail \t\tphoneNo");
while(resultSet.next()){
System.out.println(resultSet.getInt("id") + "\t"
+ resultSet.getString("firstName") + "\t"
+ resultSet.getString("lastName") + "\t"
+ resultSet.getString("email") + "\t"
+ resultSet.getString("phoneNo") );
}

}catch(SQLException sqle){
sqle.printStackTrace();
System.exit(-1);
}

}
}

3) 数据库连接.java

package com.me.ocpjp.chapter10;

import java.sql.Connection;
import java.sql.DriverManager;



public class DbConnect{
public static void main(String[] args){

String url = "jdbc:mysql://localhost:3306/";
String database = "addressBook";
String userName = "root";
String password = "tcial";

try(Connection connection = DriverManager.getConnection(url+database, userName, password)){
System.out.println("Database connection established");
}catch(Exception e){
System.out.println("Database connectioni NOT established");
e.printStackTrace();
}

}

}

4) DbQueryWorking.java

package com.me.ocpjp.chapter10;

import java.sql.Connection ;
import java.sql.Statement ;
import java.sql.ResultSet ;
import java.sql.SQLException ;
import java.sql.DriverManager;

public class DbQuery{
public static void main(String[] args){
String url = "jdbc:mysql://localhost:3306/";
String database = "addressBook";
String userName = "root";
String password = "tcial";
try(Connection connection = DriverManager.getConnection(url + database, userName, password);
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery("select * from contact")){
System.out.println("ID \tfName \tlName \temail \t\tphoneNo");
while(resultSet.next()){
System.out.println(resultSet.getInt("id") + "\t"
+ resultSet.getString("firstName") + "\t"
+ resultSet.getString("lastName") + "\t"
+ resultSet.getString("email") + "\t"
+ resultSet.getString("phoneNo") );
}

}catch(SQLException sqle){
sqle.printStackTrace();
System.exit(-1);
}

}
}

最佳答案

看起来 DbConnector.java 中的 URL 是错误的。缺少一个冒号。网址必须是:

jdbc:mysql://localhost:3306/

而不是

jdbc:mysql//localhost:3306/

关于java.sql.SQLException : No suitable driver found 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17507449/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com