MySQL中的JSON字段List成员检查_Mysql

来源:脚本之家  责任编辑:小易  
目录
JSON字段List成员检查MySQL中JSON字段操作基本改变Json函数

JSON字段List成员检查

文档

https://dev.mysql.com/doc/refman/8.0/en/json.htmlhttps://dev.mysql.com/doc/refman/8.0/en/json-search-functions.html

方法

JSON_CONTAINS(target, candidate[, path])

value MEMBER OF(json_array)

查询示例

mysql> set @list = JSON_ARRAY(1, 2);
Query OK, 0 rows affected (0.01 sec)

mysql> select 1 MEMBER OF(@list);
+--------------------+
| 1 MEMBER OF(@list) |
+--------------------+
| ? ? ? ? ? ? ? ? ?1 |
+--------------------+
1 row in set (0.00 sec)


mysql> SELECT JSON_CONTAINS(@list, '1');
+---------------------------+
| JSON_CONTAINS(@list, '1') |
+---------------------------+
| ? ? ? ? ? ? ? ? ? ? ? ? 1 |
+---------------------------+
1 row in set (0.01 sec)

MySQL中JSON字段操作

Mysql 自5.7之后增加了很多函数用于处理Json字串。方便实用。

基本改变

Json数组:

["abc", 10, null, true, false]

Json对象:

{"k1": "value", "k2": 10}

JSON数组元素和JSON对象键值内允许嵌套

Json函数

JSON_TYPE():返回json字串类型
mysql> SELECT JSON_TYPE('["a", "b", 1]');
+----------------------------+
| JSON_TYPE('["a", "b", 1]') |
+----------------------------+
| ARRAY ? ? ? ? ? ? ? ? ? ? ?|
+----------------------------+
?
mysql> SELECT JSON_TYPE('"hello"');
+----------------------+
| JSON_TYPE('"hello"') |
+----------------------+
| STRING ? ? ? ? ? ? ? |
+----------------------+
?
mysql> SELECT JSON_TYPE('hello');
ERROR 3146 (22032): Invalid data type for JSON data in argument 1
to function json_type; a JSON string or JSON type is required.

 MySQL使用utf8mb4字符集和utf8mb4_bin排序规则处理JSON上下文中使用的字符串 。其他字符集中的字符串将utf8mb4根据需要转换。(对于ascii或 utf8字符集中的字符串,无需进行转换,因为ascii和utf8是的子集utf8mb4。一般将数据库字符集设置为utf8mb4)

JSON_ARRAY():将数值包装为json数组
mysql> SELECT JSON_ARRAY('a', 1, NOW());
+----------------------------------------+
| JSON_ARRAY('a', 1, NOW()) ? ? ? ? ? ? ?|
+----------------------------------------+
| ["a", 1, "2015-07-27 09:43:47.000000"] |
+----------------------------------------+
JSON_OBJECT():将数值包装为json对象
mysql> SELECT JSON_OBJECT('key1', 1, 'key2', 'abc');
+---------------------------------------+
| JSON_OBJECT('key1', 1, 'key2', 'abc') |
+---------------------------------------+
| {"key1": 1, "key2": "abc"} ? ? ? ? ? ?|
+---------------------------------------+
JSON_MERGE():将多个json合并为一个
mysql> SELECT JSON_MERGE('["a", 1]', '{"key": "value"}');
+--------------------------------------------+
| JSON_MERGE('["a", 1]', '{"key": "value"}') |
+--------------------------------------------+
| ["a", 1, {"key": "value"}] ? ? ? ? ? ? ? ? |
+--------------------------------------------+

Json字符串中的key-value访问

使用column-path运算符 ->得到字段中json某个key的值,但是值中的"""和"\"都会显示,如果不想显示,使用->>。

#创建表
CREATE TABLE facts (ids JSON);
?
#插入数据 ?这里要注意是否启用了服务器SQL模式,插入数据时要注意特殊符号
INSERT INTO facts VALUES (JSON_OBJECT('mascot', 'Our mascot is a dolphin named "Sakila".'));
?
#查看数据
mysql> select ids from facts;
+---------------------------------------------------------+
| ids ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+---------------------------------------------------------+
| {"mascot": "Our mascot is a dolphin named \"Sakila\"."} |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT ids->'$.mascot' FROM facts;
+---------------------------------------------+
| ids->'$.mascot' ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+---------------------------------------------+
| "Our mascot is a dolphin named \"Sakila\"." |
+---------------------------------------------+
1 row in set (0.00 sec)
?
mysql> SELECT ids->>'$.mascot' FROM facts;
+-----------------------------------------+
| ids->>'$.mascot' ? ? ? ? ? ? ? ? ? |
+-----------------------------------------+
| Our mascot is a dolphin named "Sakila". |
+-----------------------------------------+
?
#注意,这里访问json字段key使用单引号还是双引号取决于sql模式

读取json字段中某个key的值

SELECT JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name');
+---------------------------------------------------------+
| JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name') |
+---------------------------------------------------------+
| "Aztalan" ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+---------------------------------------------------------+
?
#去除值双引号
mysql> SELECT JSON_UNQUOTE(JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name'));
+-----------------------------------------------------------------------+
| JSON_UNQUOTE(JSON_EXTRACT('{"id": 14, "name": "Aztalan"}', '$.name')) |
+-----------------------------------------------------------------------+
| Aztalan ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+-----------------------------------------------------------------------+

小结:

‘$.*’返回全部json
‘$.title’返回key=”title”的数据
‘$**.text’返回所有最底层key=”text”的数据
‘$.content[*].item1[*]’返回key=content的list的key=item1的list的所有内容

官网参考地址

以上为个人经验,希望能给大家一个参考,也希望大家多多支持真格学网。 

您可能感兴趣的文章:Mysql?json类型字段Java+Mybatis数据字典功能的实践方式mysql解析json数据组获取数据组所有字段的方法实例mysql中json类型字段的基本用法实例MySQL之JSON类型字段的使用技巧分享

  • 本文相关:
  • mysql在linux系统中隐藏命令行中的密码的方法
  • mysql installer web community 5.7.21.0.msi安装图文教程
  • mysql数据库中字符集乱码问题原因及解决
  • 阿里云ecs centos6.8下安装配置mysql5.7的教程
  • mysql限制查询和数据排序介绍
  • mysql同步复制搭建方法指南详细步骤
  • jdbc连接mysql5.7的方法
  • mysql数据库如何实现亿级数据快速清理
  • mysql 性能分析器 explain 用法实例分析
  • mysql中coalesce()的使用技巧小结
  • mysql json字段中数值的加减
  • mysql5.7 不能添加JSON类型字段?
  • mysql json类型数据
  • mysql数据库某个字段下写入大量json数据,现在想修改单独修改...
  • 查询Mysql表之后将结果转换为json时如何能够保持字段的原有...
  • 详解Mysql中的JSON系列操作函数
  • MySQL5.7中的JSON基本操作指南
  • c#如何将mysql数据库中的数据转换成json字符串
  • json怎么从mysql数据库中的数据
  • mysql数据库中的中文不能转化为json
  • c#使用Newtonsoft.Json将json字符串中的数据输入到MySQL数...
  • mysql5.7的json列,怎么对数组格式查询
  • php mysql 查询输出json_encode
  • mongodb和mysql5.7的json哪个更好,优缺点比较
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mysqlmysql?json类型字段java+mybatis数据字典功能的实践方式mysql解析json数据组获取数据组所有字段的方法实例mysql中json类型字段的基本用法实例mysql之json类型字段的使用技巧分享mysql在linux系统中隐藏命令行中的密码的方法mysql installer web community 5.7.21.0.msi安装图文教程mysql数据库中字符集乱码问题原因及解决阿里云ecs centos6.8下安装配置mysql5.7的教程mysql限制查询和数据排序介绍mysql同步复制搭建方法指南详细步骤jdbc连接mysql5.7的方法mysql数据库如何实现亿级数据快速清理mysql 性能分析器 explain 用法实例分析mysql中coalesce()的使用技巧小结mysql安装图解 mysql图文安装教程(详细说明)can""""t connect to mysql servwindows下mysql5.6版本安装及配置过程附有截图和mysql字符串截取函数substring的用法说明mysql提示:the server quit withoumysql之timestamp(时间戳)用法详解mysql创建用户与授权方法mysql——修改root密码的4种方法(以windows为mysql查看版本号的几种方式mysql日期数据类型、时间类型使用总结centos7下安装mysql的教程mysql数据库事务隔离级别介绍(transaction isolationmysql的?ddl和dml和dql的基本语法详解mysql server层四个日志的实现基于mysql的存储引擎与日志说明(全面讲解)mysql设置global变量和session变量的两种方法详解mysql变量用法实例分析【系统变量、用户变量】mysql字符串字段判断是否包含某个字符串的2种方法mysql 5.7.11 winx64安装配置方法图文教程java数据类型与mysql数据类型对照表
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved