简体   繁体   English

将 java.util.Date 转换为 java.sql.Date

[英]Convert java.util.Date to java.sql.Date

I am trying to get date in my database that have format like this "dd/MM/yyyy" and compare them to get latest date..我正在尝试在我的数据库中获取具有类似“dd/MM/yyyy”格式的日期并比较它们以获取最新日期..

I was surprised to find that it couldn't do the conversion implicitly or explicitly - but I don't even know how I would do this, as the Java API is still fairly new to me.我很惊讶地发现它不能隐式或显式地进行转换 - 但我什至不知道我将如何做到这一点,因为 Java API 对我来说仍然是相当新的。 Any suggestions?有什么建议? It seems like this should be an easy feat to accomplish.看起来这应该是一个容易完成的壮举。

from String last_updatedArr[] 's array result :来自String last_updatedArr[]的数组结果:

12/11/2015
12/11/2015
12/11/2015
12/11/2015
12/11/2015
13/11/2015

Method:方法:

public String latestDate(){

    String last_updated=null;
    try {
        String last_updatedDb=null;

        String query = "SELECT Last_updated FROM Mattress";
        PreparedStatement pst = conn.prepareStatement(query);

        ResultSet rs= pst.executeQuery();

        String last_updatedArr[]=new String[100];
        while(rs.next()){
            int i = 0;
            last_updatedDb=rs.getString("Last_updated");
            System.out.println(last_updatedDb);
            last_updatedArr[i]=last_updatedDb;
            i++;
        }

        SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
        java.sql.Date date1,date2;
        for(int i =0;i<last_updatedArr.length;i++){

            date1 = (java.sql.Date)sdf.parse(last_updatedArr[i]);
            date2 = (java.sql.Date)sdf.parse("1/1/2010");

            if(date1.after(date2)){
                //Date1 is after Date2
                last_updated= sdf.format(date1);
            }

            if(date1.before(date2)){
                //Date1 is before Date2
                last_updated= sdf.format(date2);
            }

            if(date1.equals(date2)){
                //Date1 is equal Date2
                last_updated= sdf.format(date1);
            }
        }
    } catch (ParseException e) {
        e.printStackTrace();
    }catch (SQLException e) {
        e.printStackTrace();
    }
    return last_updated;

}

Your loop resets i on every iteration.您的循环会在每次迭代时重置i Move the declaration of i in your while loop.while循环中移动i的声明。 Or just use a for loop.或者只是使用for循环。 Like,喜欢,

for(int i = 0; rs.next(); i++) {
    last_updatedDb = rs.getString("Last_updated");
    System.out.println(last_updatedDb);
    last_updatedArr[i] = last_updatedDb;
}

or something like,类似的东西,

int i = 0;
while(rs.next()){
    // int i = 0;
    last_updatedArr[i] = rs.getString("Last_updated");
    System.out.println(last_updatedArr[i]);
    i++;
}

SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
java.sql.Date date1,date2;
// reuse i from while loop...
for(i = 0; i < last_updatedArr.length; i++){

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM