In SQL Server, you can use CONVERT function to convert a string with the specified format to a DATETIME value. In MariaDB, you can use STR_TO_DATE function if you need a specific format, or CONVERT if you need the default format.
Note that the order of parameters in SQL Server and MariaDB CONVERT functions is different.
SQL Server:
-- 3rd parameter specifies 121 style (ODBC 'YYYY-MM-DD HH:MI:SS.FFF' format with milliseconds) SELECT CONVERT(DATETIME, '2012-11-29 18:21:11.123', 121); # 2012-11-29 18:21:11.123 SELECT CONVERT(DATETIME, GETDATE()); # 2017-04-07 09:55:40.550
MariaDB:
-- Specify string format using format specifiers SELECT STR_TO_DATE('2012-11-29 18:21:11.123', '%Y-%m-%d %T.%f'); # 2012-11-29 18:21:11.123000 SELECT CONVERT(NOW(), DATETIME); # 2017-04-07 09:55:40
When you convert CONVERT function to STR_TO_DATE you have to map the SQL Server style to the appropriate format string in MariaDB:
SQL Server Style | MariaDB Format String | String Example | |
101 | US - MM/DD/YYYY | '%m/%d/%Y' | '11/29/2012' |
112 | ISO - YYYYMMDD | '%Y%m%d' | '20230119' |
120 | ODBC - YYYY-MM-DD HH:MI:SS | '%Y-%m-%d %T' | '2021-04-18 18:21:11' |
121 | ODBC - YYYY-MM-DD HH:MI:SS.FFF | '%Y-%m-%d %T.%f' | '2012-11-29 18:21:11.123' |
Conversion examples:
SQL Server | MariaDB |
CONVERT(DATETIME, '11/29/2012', 101) | STR_TO_DATE('11/29/2012', '%m/%d/%Y') |
CONVERT(DATETIME, '20230119', 112) | STR_TO_DATE('20230119', '%Y%m%d') |
CONVERT(DATETIME, '2021-04-18 18:21:11', 120) | STR_TO_DATE('2021-04-18 18:21:11', '%Y-%m-%d %T') |
CONVERT(DATETIME, '2012-11-29 18:21:11.123', 121) | STR_TO_DATE('2012-11-29 18:21:11.123', '%Y-%m-%d %T.%f') |
In SQL Server SMALLDATETIME data type stores a datetime value with 00 seconds. You can use the expression below to keep 00 seconds after using the CONVERT function in MariaDB:
SQL Server:
-- SMALLDATETIME is always with 00 seconds SELECT CONVERT(SMALLDATETIME, GETDATE()); # 2017-04-07 10:05:00
MariaDB:
SELECT CONVERT(DATE_FORMAT(NOW(), '%Y-%m-%d %H-%i-00'), DATETIME); # 2017-04-07 10:05:00