SQL:Convert()函数<<BLOB>>问题解决

文章讨论了在业务中遇到的一个需求,即从JSON格式的字段中导出特定字段。当使用SQL查询时,无引号的输出被识别为<BLOB>二进制文件,而非期望的字符串类型。为了解决这个问题,文章提出了使用Convert()函数,结合UTF8编码来正确地转换和导出字段值,使其以无引号的字符串形式呈现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

业务中有个需求,导出一个字段(字段存储形式为JSON)的某个字段;
例如字段A存储这样数据

 {
    "JP1规模":"4000",
    "乙方2":"四川云豪电子商务有限公司",
    "合同等级":"JP1"
}

使用

SQL就可以这样写

-- ->输出有引号,->>没有
 SELECT
  eci.variable_value ->> '$."乙方"',
  eci.variable_value -> '$."乙方"'
FROM
  ess_contract_info eci
WHERE
  `contract_id` in (167826607801000098)

在这里插入图片描述

问题

可以看出无引号输出变成了<<BLOB>>二进制文件,我们的目标是 无引号的字符串类型;
使用Convert()函数配置编码解决

 SELECT
  eci.variable_value ->> '$."乙方"',
  eci.variable_value -> '$."乙方"',
  Convert(eci.variable_value ->> '$."乙方"' using utf8)
FROM
  ess_contract_info eci
WHERE
  `contract_id` in (167826607801000098)

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值