mysql STR_TO_DATE无效

Thi*_*han 3 mysql str-to-date

我有一个varchar名为列的表birthday

CREATE TABLE IF NOT EXISTS `test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `birthday` varchar(30) COLLATE utf16_unicode_ci NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf16 COLLATE=utf16_unicode_ci AUTO_INCREMENT=5 ;

INSERT INTO `test` (`id`, `birthday`) 
VALUES (1, '20041225'),
       (2, '2004-12-25'),
       (3, '19941225'),
       (4, '19941201');
Run Code Online (Sandbox Code Playgroud)

我尝试运行此查询:

SELECT str_to_date(birthday,"%Y%m%d") 
FROM `test` 
WHERE 1
Run Code Online (Sandbox Code Playgroud)

但它总是返回具有空值的行.

如果我运行查询:

SELECT str_to_date('20141225',"%Y%m%d") 
FROM `test` 
WHERE 1
Run Code Online (Sandbox Code Playgroud)

它会回来 2014-12-25

那我的查询有什么问题?

Rob*_*ill 6

让它更简单的功能.DATE()以YYYY-MM-DD格式返回字符串的日期部分:

SELECT DATE(birthday) FROM `test`
Run Code Online (Sandbox Code Playgroud)

结果:

2004-12-25      
2004-12-25      
1994-12-25      
1994-12-01      
Run Code Online (Sandbox Code Playgroud)

您的代码不起作用的原因是STR_TO_DATE()需要相同的输入和输出格式,例如STR_TO_DATE('2014-08-29', '%Y-%m-%d').请查看文档中的示例.此函数主要用于将日期或时间从一种格式转换为另一种格式,其中原始格式来自MySQL外部,您希望将数据导入MySQL的日期格式,例如,在这种情况下,您将知道原始格式是什么日期格式是.

例:

SELECT STR_TO_DATE('20041225', '%Y-%m-$d');   -- null - formats don't match
SELECT STR_TO_DATE('2004-12-25', '%Y-%m-%d'); -- 2004-12-25 - formats match
Run Code Online (Sandbox Code Playgroud)