字符串 - > java.util.Date - > java.sql.Date(带时间戳) [英] String -> java.util.Date -> java.sql.Date (with time stamp)
问题描述
这是我的问题:
我有一个用户输入一个日期像:2012-12-24(string)
我连接一个时间到该字符串,并转换为java.util.Date
我的代码看起来像:
Here is my problem: I have a user input a date like: 2012-12-24 (string) I concatenate a time to that string, and convert to java.util.Date My code looks like:
String tempstartdate = startdte; //startdte is the string value from a txtfield
tempstartdate += " 00:01:00";
String tempenddate = startdte;
tempenddate += " 23:59:59";
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
java.util.Date validstartdte = null;
java.util.Date validenddte = null;
validstartdte = df.parse(tempstartdate); //validstartdte is a util.Date (and works)
validenddte = df.parse(tempenddate);
我的问题是,当我拿这个util.Date,并希望使它成为一个sql.Date:
My problem is, when I take that util.Date and want to make it an sql.Date:
java.sql.Date sqlstartDate = new java.sql.Date(validstartdte.getTime());
java.sql.Date sqlendDate = new java.sql.Date(validenddte.getTime());
它不会给我分配的时间戳,它只会返回yyyy- MM-dd(如2012-12-23)。
It will not give me the timestamp I assigned, it will only return the date in the form yyyy-MM-dd (such as 2012-12-23).
为什么!我很沮丧。
注意:我注意到,当我使用断点时,我能够扩展sqlendDate,看到有一个值在cdate中返回:2012-12-12T23:59: 59.000-0500
我使用的数据库是PostgreSQL。
WHY!? I'm so frustrated.
Note: I noticed that when I used breakpoints, I was able to expand sqlendDate and see there is a value in there called cdate that returns: 2012-12-12T23:59:59.000-0500
The database I'm using is PostgreSQL.
请帮忙!非常感谢。
推荐答案
java.sql.Date
没有时间。
使用 java.sql.Timestamp
。
这篇关于字符串 - > java.util.Date - > java.sql.Date(带时间戳)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!