gpt4 book ai didi

java - 获取日期差异的返回值?

转载 作者:行者123 更新时间:2023-11-30 02:28:56 25 4
gpt4 key购买 nike

所以我使用 DATEDIFF 有这个查询在 MS SQL Server 上运行吗?

SELECT DATEDIFF(DAY,(select StartDate from CarOrder where OrderID= 59),(select EndDate from CarOrder where OrderID= 59))

这个工作正常,结果是 10,但我不知道如何获取返回值并在这个 java 函数中使用它

public int getDateDiff(int OrderID){
Connection conn = DBConnection.getConnection();
int datediff;
String getdiffSQL = "SELECT DATEDIFF(DAY,(select StartDate from CarOrder where OrderID = ? ) ,(select EndDate from CarOrder where OrderID= ?) )";
try {
PreparedStatement pstm = conn.prepareStatement(getdiffSQL);
pstm.setInt(1, OrderID);
pstm.setInt(2, OrderID);
int nRows = pstm.executeUpdate();
return nRows;
} catch (SQLException ex) {
System.out.println("Error: " + ex.getMessage());
} finally {
DBConnection.closeConnection(conn);
}

}

我希望它返回日期差异编号,以便它成为我可以在 java 中使用的变量,我该怎么做?谢谢。

最佳答案

使用结果集

您需要捕获 ResultSet ,并访问该 ResultSet 的行(在本例中为单行)。如果您正在执行查询,请在 PreparedStatement 上调用 executeQuery,从而生成 ResultSet

使用现代的 try-with-resources自动关闭数据库资源的语法。您可以删除finally子句;无需对数据库资源调用 closeXXX,因为该杂务已为您处理。

没有尝试执行以下代码示例,但我希望它接近您的需要。我正在使用 Martin Smith 评论中建议的备用 SELECT 行;我没有考虑这一点,因为这不是你问题的核心。

String sql = "SELECT DATEDIFF( DAY , StartDate , EndDate ) FROM CarOrder WHERE OrderID = ? ;" ;

Integer diff = null ;
try (
Connection conn = myDataSource.getConnection() ;
PreparedStatement pstmt = conn.prepareStatement ( sql ) ;
) {
pstmt.setInt( 1 , orderId ) ;
try (
ResultSet rs = pstmt.executeQuery( sql ) ;
) {
while ( rs.next ( ) ) {
diff = rs.getInt( 1 ) ; // Auto-boxing `int` to `Integer`.
}
}
}
} catch ( SQLException e ) {
e.printStackTrace ( ); // Handle error condition however you see fit.
}

if( null == diff ) {
System.out.println( "mission failed." ) ;
} else {
System.out.println( "mission succeeded. Diff is: " + diff ) ;
}

对于实际工作,我还会进行测试以确保只返回一行(确保 while 循环恰好运行一次,而不是零次或多次)。

如果您对各种数据库资源(DataSource、Connection、PreparedStatement、ResultSet)不清楚,您应该记下 IDE并对 Oracle Tutorial on JDBC matters 进行更多研究,并针对该主题对 Stack Overflow 进行一些搜索/研究。

关于java - 获取日期差异的返回值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44748050/

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