您现在的位置是:网站首页> 编程资料编程资料
mysql 如何使用JSON_EXTRACT() 取json值_Mysql_
2023-05-26
485人已围观
简介 mysql 如何使用JSON_EXTRACT() 取json值_Mysql_
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
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
相关内容
- 一文了解MySQL事务隔离级别_Mysql_
- 关于mysql中的json解析函数JSON_EXTRACT_Mysql_
- MySQL中json_extract()函数的使用实例_Mysql_
- mysql8.0 JSON_CONTAINS的使用说明_Mysql_
- 哪些情况会导致 MySQL 索引失效_Mysql_
- MySQL中的日期时间类型与格式化方式_Mysql_
- 一文搞懂Mysql中的共享锁、排他锁、悲观锁、乐观锁及使用场景_Mysql_
- MySQL组合索引(多列索引)使用与优化案例详解_Mysql_
- 提高MySQL深分页查询效率的三种方案_Mysql_
- mysql between实现选取介于两个值之间的数据范围_Mysql_
