Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment extraire la date et l'heure d'un horodatage de chaîne en Java

Utilisez java.text.SimpleDateFormat et java.util.TimeZone

Dans quel fuseau horaire se trouve la chaîne de date ? Remplacez le UTC ci-dessous fuseau horaire avec ce fuseau horaire

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

Remarque : Dans quel format l'heure est-elle (24 heures/12 heures) dans votre chaîne d'entrée ? L'exemple ci-dessus suppose qu'il est au format 24 heures car il n'y a aucune information AM/PM dans la chaîne d'entrée.

Si la chaîne d'entrée est également au format 12 heures, votre chaîne d'entrée doit également mentionner les informations AM/PM telles que 2014-02-15 05:18:08 PM . Dans ce cas, modifiez le sdf à new SimpleDateFormat("yyyy-MM-dd hh:mm:ss a")

=======================Modifié : ========================

Pour répondre à votre prochaine question en commentaire "Comment extraire la date et l'heure séparément"...

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);