MySQL5.7虚拟列:Invalid JSON value for CAST to DATE/TIME/DATETIME/TIMESTAMP from column json_extract

在使用MySQL5.7虚拟列功能时,发现DATE/DATETIME/TIMESTAMP类型的虚拟列无法插入数据,问题如下:

CREATE TABLE `test` (
    `json` TEXT NULL,
    `date` DATETIME NULL DEFAULT NULL,
    `v_date` DATE AS (json_extract(`json`,'$.date')) VIRTUAL
);


INSERT INTO test (json) VALUES ('{"date":"2019-01-21 00:00:00"}');

ERROR 3156 (22018): Invalid JSON value for CAST to DATE/TIME/DATETIME/TIMESTAMP from column json_extract at row 1




后来发现了MySQL提供的函数:json_unquote(),作用是去除json的引号。采用该函数后可以正常插入日期类型

CREATE TABLE `test_virtual_column` (
    `json` JSON NULL DEFAULT NULL,
    `date` DATETIME NULL DEFAULT NULL,
    `v_date` DATETIME AS (json_unquote(json_extract(`json`,'$.date'))) VIRTUAL
)



INSERT INTO `test`.`test_virtual_column` (`json`) VALUES ('{"date": 20191221}');

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值