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

本文探讨了在MySQL5.7中使用虚拟列功能时遇到的问题,特别是DATE/DATETIME/TIMESTAMP类型的虚拟列在尝试从JSON字段提取数据时的错误。通过引入json_unquote()函数,解决了JSON值转换为日期类型的问题。
部署运行你感兴趣的模型镜像

在使用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}');

您可能感兴趣的与本文相关的镜像

Dify

Dify

AI应用
Agent编排

Dify 是一款开源的大语言模型(LLM)应用开发平台,它结合了 后端即服务(Backend as a Service) 和LLMOps 的理念,让开发者能快速、高效地构建和部署生产级的生成式AI应用。 它提供了包含模型兼容支持、Prompt 编排界面、RAG 引擎、Agent 框架、工作流编排等核心技术栈,并且提供了易用的界面和API,让技术和非技术人员都能参与到AI应用的开发过程中

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值