Maison >base de données >tutoriel mysql >Voici quelques options de titre, axées sur le problème principal et la solution : Option 1 (directe et axée sur le problème) : * Pourquoi SimpleDateFormat.parse produit-il une sortie incohérente lors de la conversion des heures UNIX
Différence de format de sortie SimpleDateFormatter.parse
Lors de la tentative de conversion d'un horodatage UNIX dans un format de date spécifique à l'aide de SimpleDateFormat, les utilisateurs peuvent rencontrer des incohérences entre les sorties formatées et analysées.
L'une des raisons de cet écart est le potentiel de fuseaux horaires incompatibles. Assurez-vous que le fuseau horaire de SimpleDateFormat correspond au résultat attendu. De plus, vérifiez que l'horodatage de l'époque est représenté en millisecondes, comme l'exige le constructeur de Date.
Solution suggérée :
Pour éviter les problèmes de formatage potentiels et garantir la compatibilité de la base de données, il est recommandé de transmettre les objets date directement à MySQL au lieu des chaînes. Utilisez les classes java.time, telles que LocalDateTime, pour représenter les dates et les heures.
Voici un extrait de code mis à jour :
<code class="java">String ep = "a1527069600"; long epoch = Long.parseLong(ep.substring(1)); Instant instant = Instant.ofEpochSecond(epoch); LocalDateTime ldt = instant.atZone(ZoneId.of("Asia/Calcutta")).toLocalDateTime(); PreparedStatement ps = myDatabaseConnection.prepareStatement( "insert into my_table (my_date_time) values (?)"); ps.setObject(1, ldt);</code>
Cette approche garantit que la date est formatée en fonction de l'heure spécifiée. zone et est stocké en tant qu'objet dans la base de données, éliminant ainsi le risque d'erreurs de formatage.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!