gpt4 book ai didi

java - 如何使用Java从Oracle数据库中获取记录

转载 作者:行者123 更新时间:2023-12-02 08:58:13 28 4
gpt4 key购买 nike

我正在使用 JDBC 通过 Java 学习数据库。在阅读了互联网上关于 JDBC 的一些文章后,我创建了一个非常基本的程序。我的代码没有给出任何错误,但我也没有得到输出。这是我的代码:

这是我的连接代码:DataService

    import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.logging.Level;
import java.util.logging.Logger;

public class DataService {
static Connection con;
public static void main(String args[]){
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
con=DriverManager.getConnection(
"jdbc:oracle:thin:@localhost:1521:xe","system","scott");
}
catch(Exception e){
System.out.println(e);
}
}

public ResultSet getRecords() {
System.out.println("inside getRecords()");
ResultSet rs=null;
try {
System.out.println("Inside Rs loop");
Statement stmt=con.createStatement();
rs=stmt.executeQuery("select * from emp");
System.out.println("RS before entering while: "+rs);
while(rs.next())
System.out.println("Inside while loop");
System.out.println("Data: " +rs.getInt(0)+" "+rs.getString(1));
} catch (SQLException ex) {
Logger.getLogger(DataService.class.getName()).log(Level.SEVERE, null, ex);
}
System.out.println("Before sending: "+rs);
return rs;
}
}

这是我的应用程序MainFrame.java

public class MainFrame extends Application {

...

@Override
public void start(Stage primarystage) {
...
try {
System.out.println("Inside try");
DataService dataservice = new DataService();
System.out.println("Result set: "+dataservice.getRecords());
} catch (Exception e) {
//TODO: handle exception
}
}
}

我得到这个输出:

Inside try

inside getRecords()

Inside Rs loop

我看不到任何与记录相关的输出。我还检查了select * from emp。该表中已经有行。我在这里错过了一些非常重要的事情。请纠正我。

最佳答案

创建 DataService 实例时 DataService dataservice = new DataService(); 方法 main() 不会被调用,因此变量 conn 未初始化并保持为 null。此后,当调用Statement stmt=con.createStatement();时,会抛出 NullPointerException (NPE)。此 NPE 既不会在此 catch block catch (SQLException ex) 中捕获,因为它仅捕获 SQLException,也不会在这个 catch (Exception e) 中捕获,因为没有处理逻辑提供。

使代码正常工作的第一步是在 MainFrame 类的 start() 方法中添加一些异常处理逻辑(永远不要留下空的 catch block ,它被视为反模式)。

然后将连接初始化的逻辑移至 getRecords() 方法,使其成为局部变量或移至 DataService 构造函数,以便在访问变量 conn 时对其进行初始化。

下一个大问题是在完成使用连接、语句和结果集变量后关闭它们。从java 7开始你可以使用try-with-resources处理此类资源的语法。

此外,我建议在 getRecords() 方法内部处理 ResultSet,而不将其暴露在 DataService 类之外。该类充当 Data Access Object (DAO)并且最好将实现细节保留在内部。相反,您可以创建一些简单的 Employee 类,该类的实例可以在 while(rs.next()) 循环内初始化,用结果集中的值填充并添加到某个集合中。该集合可以从 getRecords() 方法返回。

关于java - 如何使用Java从Oracle数据库中获取记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60360765/

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