Rak*_*esh 4 java mysql datetime date
我String TIMESTAMP以这种格式从服务器获取MySQL的日期和时间:
2014-02-15 05:18:08
Run Code Online (Sandbox Code Playgroud)
我想要的是以DD-MM-YYYY格式提取日期和格式时间HH:MM:SS AM/PM.此时间戳的时区也不同,我希望它在印度时区(IST).
记住timestamp是String数据类型.
使用java.text.SimpleDateFormat和java.util.TimeZone
日期字符串在哪个时区?用该UTC时区替换以下时区
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
sdf.setTimeZone(TimeZone.getTimeZone("UTC"));
Date date = sdf.parse("2014-02-15 05:18:08");
SimpleDateFormat sdf2 = new SimpleDateFormat("dd-MM-yyyy hh:mm:ss a");
sdf2.setTimeZone(TimeZone.getTimeZone("IST"));
String dateStr = sdf2.format(date); // Output: 15-02-2014 10:48:08 AM
Run Code Online (Sandbox Code Playgroud)
注意:输入字符串中的小时是以哪种格式(24小时/ 12小时)?上面的示例假定它是24小时格式,因为输入字符串中没有AM/PM信息.
如果输入字符串也是12小时格式,那么输入字符串也应该提到AM/PM信息,例如2014-02-15 05:18:08 PM.在这种情况下,修改sdf为new SimpleDateFormat("yyyy-MM-dd hh:mm:ss a")
======================== 编辑: =====================
在评论"如何分别提取日期和时间"中回答您的下一个问题...
SimpleDateFormat sdfDate = new SimpleDateFormat("dd-MM-yyyy");
sdfDate.setTimeZone(java.util.TimeZone.getTimeZone("IST"));
SimpleDateFormat sdfTime = new SimpleDateFormat("hh:mm:ss a");
sdfTime.setTimeZone(java.util.TimeZone.getTimeZone("IST"));
String dateStr = sdfDate.format(date);
String timeStr = sdfTime.format(date);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10969 次 |
| 最近记录: |