mysql json类型的一些说明

mysql json类型的一些说明,第1张

以前最讨厌英语了,然而没有想到有一天居然要看英文文档学习东西的时候,只想说MMP。下面就是一些学习的东西的记录啦。

之前听小伙伴说他们用的 pgsql ,pgsql 是如何如何牛逼,支持json。然后就去学习了下,但是公司用的是mysql,然后某个项目mysql用了5720版本,这个版本支持json,所以就又学习了一波。吐槽完毕,下面就是正文了。

mysql57版本支持json,具体说的是578开始。这是需要注意的,然后可以的话大家还是看下官方文档吧。

mysql 57 josn官方文档地址

我这里 json_content 就定义的是json类型,下面就是基本的 *** 作,后续会写一些json函数

这算是一个比较复杂的json了,array里面放的是一个数组,other放了另一个对象。下面我再插入几条数据

下面两条的数据和第一条不一样,是为了做一些说明用。lisi这条数据所有的字段都有,但是数据和张三略有不同,而wangwu这条数据就有些字段没有。

说明下,我原来用的navicat发现查josn的时候是空 select 的时候定义的json字段会不显示,然后换了新版本就好了。

结果如下:

上面两条sql都是通过json对象中flag=0的数据,然后上面两条sql是等价的。JSON_EXTRACT函数的语法为:JSON_EXTRACT(字段名,‘$key’),这个函数可以在条件中使用,也可以在查询的时候使用。如下:

结果如下:

嗯哼,没错 JSON_EXTRACT 这个函数是用来获取json对象中指定key的值的。这是一个很常用的函数。

上面既然提到了time,那么就用time来展示下吧。json对象中的时间,可以直接拿来比较,sql如下:

结果如下:

我的条件限定的是 2018-06-05 15:49:00 之后,获取到了2条数据,是不是很神奇呢。这里就要说明下了,这里涉及到了json对象里面对key对应的value进行比较的时候会有一个优先级,mysql会按照这个优先级来转换,然后进行比较,这里只贴一下优先级情况,各个类型的比较的规则自己去文档里面看吧。

下面再介绍两个查询时候会用到的函数JSON_CONTAINS() 和 JSON_CONTAINS_PATH()。

下面就是具体的例子:

结果如下:

结果如下:

结果如下:

结果如下:

用法还是比较简单的,嗯,可能有小伙伴会问我要查询不满足条件的数据呢?很简单,比如上面的sql,修改成:

查询暂时就介绍这么多吧,后续可能会补充,现在介绍下修改。

JSON修改的函数比较多,这里介绍一些应该会常用到的。

id=2的数据结果变为:

id=2的数据结果变为:

说明:假设这里key已经存在,那么本次已经存在的将不会被修改,同时可以添加多个。

id=2的数据结果变为:

id=2的数据结果变为:

说明下,如果指定的key不存在,那么不存在的修改无效,存在的会被修改。

id=2的数据结果变为:

说明下,JSON_SET已经存在的会被修改,不存在的会被增加。

下面介绍一些其他函数。

暂时就写这么多吧,后续再进行补充。本人也是刚开始接触mysql的json,如果有问题请指教~

PHP取Mysql数据并转换为json格式,这很简单 过程分为取数据-保存为数组-json格式输出三步 取数据分为连接与查询(条件等),参考下面文章 保存为数组也容易,array_push就行 json格式的输换最为便捷,只需echo json_encode($myArr); 输出的就

数据处理中,一遇到json就头大,很长一段时间里,明知lateral view函数是个好东西,但就是很抗拒去学,都是找数仓的同事先理好字段直接用,顺便以菜鸡的身份,同情和膜拜一下埋头洗脏数的数仓同学,大佬辛苦。。

前段时间加入到一个数据建设的项目中作为先锋军打头阵,没办法遇到json还是硬着头皮终于学会了lateral view用法,感受:困难只是心中的一座大山!也不过如此!

我肯定我过不了几天一定会忘掉(其实已经忘掉一点了。。),没有好记性拿起烂笔头,记录在这里吧。

假设T表中有个json_txt字段取值格式如下:

如果我要得到每个学生的所有信息字段,则需要将json中的信息解析出来。

得到结果如下:

但是score和rank是以数列形式存储在同一行,不方便计算,用trans_array()函数可以解决啦:

得到的结果就是纵列的分数明细:

import javaioStringWriter;

import javautilHashMap;

import javautilList;

import javautilMap;

import orgcodehausjacksonJsonFactory;

import orgcodehausjacksonJsonGenerator;

import orgcodehausjacksonJsonParserFeature;

import orgcodehausjacksonmapJsonSerializer;

import orgcodehausjacksonmapObjectMapper;

import orgcodehausjacksonmapSerializationConfigFeature;

import orgcodehausjacksontypeTypeReference;

public class JsonUtils

{

private static ObjectMapper mapper = null;

static { mapper = new ObjectMapper();

mapperconfigure(SerializationConfigFeatureFAIL_ON_EMPTY_BEANS, false);

mapperconfigure(JsonParserFeatureALLOW_BACKSLASH_ESCAPING_ANY_CHARACTER, true);

}

public static String toJson(Object target)

{

String json = "";

try {

StringWriter sw = new StringWriter();

JsonGenerator gen = new JsonFactory()createJsonGenerator(sw);

mapperwriteValue(gen, target);

genclose();

json = swtoString();

}

catch (Exception e) {

throw new UnexpectedException("对象转换Json字符串出错," + targettoString(), e);

}

return json;

}

}

从复杂json中提取关心的字段数据,利用ROW的方式, 可以让复杂的json转变为可 *** 作的schema,然后可以通过 field as xxxxxx 来使用

version flink 1130

参考

>

数据库只是用来存储数据的,为什么不把处理数据的部分放在后台?

在这里你需要了解以下几个知识点。

在sqlserver 中存储json ,需要用字符串类型进行存储,一般用nvarchar()或 varchar()进行存储。

openJson:打开Json字符串

IsJson:判断一个字符串是不是合法的Json格式。是返回1,否返回0,null返回null。

Json_Value:从Json字符串中提取值。

Json_Query:Json字符串中提取对象或数组。

Json_Modify:更新Json字符串中的属性值,并返回更新的Json字符串

然后参考的需求,获取输入key值中的value字段可以得到如下sql语句。

从JSON中获取输入B的JSON对象

SELECT JSON_QUERY(json, CONCAT('$',key)) INTO K_VAL;

从B的JSON对象中,获取value字段的值

SELECT JSON_VALUE(K_VAL, '$value') INTO JSONVALUE;

最终我们的声明的函数大概是:

CREATE FUNCTION PARSEJSON(json VARCHAR(2000), key VARCHAR(200))

RETURNS VARCHAR

BEGIN

declare JSONVALUE VARCHAR;

declare K_VAL VARCHAR;

SELECT JSON_QUERY(json, CONCAT('$',key)) INTO K_VAL;

SELECT JSON_VALUE(K_VAL, '$value') INTO JSONVALUE;

return JSONVALUE;

END

以上就是关于mysql json类型的一些说明全部的内容,包括:mysql json类型的一些说明、怎么把sql的文件转换成json、SQL:LATERAL VIEW函数解析多嵌套的json等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/web/9419315.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存