本文实例讲述了mysql5.7 新增的json字段类型用法。分享给大家供大家参考,具体如下:

一、我们先创建一个表,准备点数据

CREATE TABLE `json_test` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID', `json` json DEFAULT NULL COMMENT 'json数据', PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

二、检索json列的字段

通过使用 -> 或 ->> 运算符检索json列的字段

select id, json->'$[0].items[0].name' from json_test;
select id, json->>'$[0].items[0].name' from json_test;

使用 -> 和 ->> 的区别是结果用了引号包裹。

三、处理json的一些函数

JSON_PRETTY(json_val) 以优雅的格式显示json值

select id, JSON_PRETTY(json) from json_test\G;

注意,注意,注意,这里的candidate如果是数字,需要用单引号包裹,如果是字符串,单引号里再加上双引号包裹。

select JSON_CONTAINS(json->'$[0].name', '"1号篮子"') from json_test;select JSON_CONTAINS(json, '"1号篮子"', '$[0].name') from json_test;
select JSON_CONTAINS_PATH(json, 'one', '$[0].name', '$[0].test') from json_test;
select JSON_CONTAINS_PATH(json, 'all', '$[0].name', '$[0].test') from json_test;

JSON_SET(json_doc, path, val[, path, val] ...)插入或更新数据并返回结果

select JSON_SET(json, '$[0].name', '2号篮子', '$[0].test', 'test') from json_test;

JSON_INSERT(json_doc, path, val[, path, val] ...)插入数据并返回结果,但不替换现有值。

select JSON_INSERT(json, '$[0].name', '2号篮子', '$[0].exts', '扩展') from json_test;

JSON_REPLACE(json_doc, path, val[, path, val] ...) 替换现有值并返回结果

select JSON_REPLACE(json, '$[0].name', '替换') from json_test;

JSON_REMOVE(json_doc, path[, path] ...)删除数据并返回结果

select JSON_REMOVE(json, '$[0].name') from json_test;

JSON_KEYS(json_doc[, path]) 获取json文档中的所有键

select JSON_KEYS(json, '$[0]') from json_test;

JSON_LENGTH(json_doc[, path]) 获取json文档的长度

select JSON_LENGTH(json, '$[0]') from json_test;

JSON_EXTRACT(json_doc, path[, path] ...) 返回json文档中的数据

select JSON_EXTRACT(json, '$[0]') from json_test;select JSON_EXTRACT(json, '$[0].name') from json_test;

JSON_ARRAY([val[, val] ...]) 创建json数组

select JSON_ARRAY(1, '2', true, 5.6, null, now());
select JSON_OBJECT('name', 'xiaoxu', 'age', 28, 'height', 1.72);

JSON_MERGE_PATCH(json_doc, json_doc[, json_doc] ...) 合并json文档,如果有重复键,后面的数据覆盖前面的

select JSON_MERGE_PATCH('{"name":"test1"}', '{"name":"test2"}');
select JSON_MERGE_PRESERVE('{"name":"test1"}', '{"name":"test2"}');
select JSON_QUOTE('你好"世界"');
select JSON_UNQUOTE('你好\\t\"世界\"');

希望本文所述对大家MySQL数据库计有所帮助。

更多相关文章

  1. 《Android和PHP最佳实践》官方站
  2. android用户界面之按钮(Button)教程实例汇
  3. TabHost与RadioGroup结合完成的菜单【带效果图】5个Activity
  4. Android(安卓)UI开发第十七篇——Android(安卓)Fragment实例(Lis
  5. Android——Activity四种启动模式
  6. Android布局(序章)
  7. Android(安卓)初识Retrofit
  8. Android发送短信方法实例详解
  9. Android(安卓)读取资源文件实例详解

随机推荐

  1. [zz] 分析Android(安卓)根文件系统启动过
  2. Oprofile在Android中的应用
  3. Android shell 系统命令
  4. android常用框架
  5. android attr.xml文件
  6. Android: Linear Layout and weight
  7. Android用户权限大全
  8. ToggleButton
  9. Android 画椭圆
  10. 开发者必看|Android(安卓)8.0 新特性及开