mysql 如何使用JSON_EXTRACT() 取json值

mysql 如何使用JSON_EXTRACT() 取json值,第1张

mysql 如何使用JSON_EXTRACT() 取json值 目录
  • mysql取json字符串字段下的某个键的值
    • 1.使用replace()做替换
    • 2.使用 JSON_UNQUOTE()
  • mysql处理json字符串,JSON_EXTRACT()提取内容
    • MySQL自5.7之后开始支持json类型

mysql取json字符串字段下的某个键的值

要求:mysql版本5.7及以上

SELECT JSON_EXTRACT('{"uid":"asas02234"}', "$.uid");

由于json的键值是带双引号。所以需要去掉双引号。

1.使用replace()做替换
select 
    replace(JSON_EXTRACT(infoJson,'$.uid'),'"','') uid
from users

laravel 里使用JSON_EXTRACT

$applyList = DB::table('invoice')
            ->select('applied_at','total_amount','invoice_form','invoice_file','reject_reason')
            ->selectRAW('replace(JSON_EXTRACT(invoice_detail,"$.owner_name"),\'"\',\'\') as owner_name')
            ->where('uid',Auth::id())->get();

2.使用 JSON_UNQUOTE()
SELECT JSON_UNQUOTE(JSON_EXTRACT('{"id":"3"}', "$.id"));
$applyList = DB::table('invoice')
            ->select('applied_at','total_amount','invoice_form','invoice_file','reject_reason')
            ->selectRAW('JSON_UNQUOTE(JSON_EXTRACT(invoice_detail,"$.owner_name")) as owner_name')
            ->where('uid',Auth::id())->get();

mysql处理json字符串,JSON_EXTRACT()提取内容

MySQL自5.7之后开始支持json类型

相应的解析函数主要是JSON_EXTRACT():

SELECT JSON_EXTRACT('{"ID":"1"}','$.ID');

执行结果:

JSON_EXTRACT('{"ID":"1"}','$.ID')
"1"

去除引号使用函数JSON_UNQUOTE():

SELECT JSON_UNQUOTE(JSON_EXTRACT('{"ID":"1"}','$.ID'));

执行结果:

JSON_UNQUOTE(JSON_EXTRACT('{"ID":"1"}','$.ID'))
1

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/2996633.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-09-26
下一篇 2022-09-26

发表评论

登录后才能评论

评论列表(0条)

保存