|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
[2017-01-27 10:38 UTC] smithlmk at gmail dot com
-PHP Version: 5.6.30
+PHP Version: 7
[2017-01-27 10:38 UTC] smithlmk at gmail dot com
[2017-02-01 13:30 UTC] andrew dot nester dot dev at gmail dot com
[2017-04-21 19:03 UTC] robert dot reinhard at bukwild dot com
[2020-01-03 18:30 UTC] cmb@php.net
-Status: Open
+Status: Feedback
-Assigned To:
+Assigned To: cmb
[2020-01-03 18:30 UTC] cmb@php.net
[2020-01-12 04:22 UTC] php-bugs at lists dot php dot net
|
|||||||||||||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Thu Nov 06 09:00:01 2025 UTC |
Description: ------------ Fractional seconds are supported in MySQL DateTime(x) field types. Writing such fields with fractional seconds via PDO into MySQL database is fully supported, however reading such fields directly via PDO won't return fractional seconds. A clumsy workaround is to wrap every DateTime field with a CONCAT function as shown in below test. Test script: --------------- (1) Create this table in MySQL: CREATE TABLE `test` ( `id` int(11) NOT NULL, `dt` datetime(3) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; (2) Connect db via PDO and do this: $pdo->query("REPLACE INTO test (id, dt) VALUES (1, '2017-1-1 12:30:00.123')"); $a = $pdo->query("SELECT dt FROM test WHERE id = '1'")->fetch(); $b = $pdo->query("SELECT CONCAT(dt) AS dt FROM test WHERE id = '1'")->fetch(); var_dump($a, $b); Expected result: ---------------- array(1) { 'dt' => string(23) "2017-01-01 12:30:00.123" } array(1) { 'dt' => string(23) "2017-01-01 12:30:00.123" } Actual result: -------------- array(1) { 'dt' => string(19) "2017-01-01 12:30:00" } array(1) { 'dt' => string(23) "2017-01-01 12:30:00.123" }