⑦ split(string str,string par):返回值为array类型。select split('atguigu','g');["at","ui","u"]⑧concat_ws(string spl,string s1,string s2,...):返回值为string类型。select concat_ws('-','a','b','c');a-b-c ⑨ get_json_object(string json,string path):返回值为string类型。s...
第一步解析:json数组拆分成多行 sql语句: 复制 SELECTexplode(split(regexp_replace(regexp_replace('[{"user_id":"1","name":"小琳","age":16},{"user_id":"2","name":"小刘","age":18},{"user_id":"3","name":"小明","age":20}]','\\[|\\]',''),将json数组两边的中括号去掉'...
get_json_object('{"name":"zhangsan","age":18}','$.name'),get_json_object('{"name":"zhangsan","age":18}','$.age'); 但是如果要解析的字段有很多,再这样写就太麻烦了,所以就有了json_tuple这个函数。 2. json_tuple 语法:json_tuple(json_string, k1, k2 ...) 说明:解析json的字符串js...
然后我们可以结合get_json_object或json_tuple来解析里面的字段了: hive(default)>selectjson_tuple(json,'website','name')from(SELECTexplode(split(regexp_replace(regexp_replace('[{"website":"www.iteblog.com","name":"过往记忆"},{"website":"carbondateblog.com","name":"carbondata 中文文档"}]'...
-- 创建最终结果表CREATETABLEresult_table(result_data STRING)ROWFORMAT DELIMITEDFIELDSTERMINATEDBY'\t'STOREDASTEXTFILE;-- 炸裂 JSON 数组并插入到最终结果表INSERTINTOTABLEresult_tableSELECTexploded_dataFROMexploded_table LATERALVIEWexplode(split(exploded_data,','))explodedASexploded_data; ...
第一步解析:json数组拆分成多行 sql语句: 代码语言:javascript 复制 SELECTexplode(split(regexp_replace(regexp_replace('[{"user_id":"1","name":"小琳","age":16},{"user_id":"2","name":"小刘","age":18},{"user_id":"3","name":"小明","age":20}]','\\[|\\]',''),将json数...
第一步解析:json数组拆分成多行 sql语句: SELECT explode(split( regexp_replace( regexp_replace( '[ {"user_id":"1","name":"小琳","age":16}, {"user_id":"2","name":"小刘","age":18}, {"user_id":"3","name":"小明","age":20} ]', '\\[|\\]' , ''), 将json数组两边...
因为元素内的分隔也是逗号,如果不将元素之间的逗号换掉的话,后面用split函数分隔时也会把元素内的数据给分隔,这不是我们想要的结果。 上步已经把一个json数组转化为多个json字符串了,接下来结合son_tuple函数来解析json里面的字段: select json_tuple(explode(split( regexp_replace(regexp_replace('[{"website":...
因为元素内的分隔也是逗号,如果不将元素之间的逗号换掉的话,后面用split函数分隔时也会把元素内的数据给分隔,这不是我们想要的结果。 上步已经把一个json数组转化为多个json字符串了,接下来结合son_tuple函数来解析json里面的字段: ((( ((, ,),,),)) ...
为什么要将json数组元素之间的逗号换成分号? 因为元素内的分隔也是逗号,如果不将元素之间的逗号换掉的话,后面用split函数分隔时也会把元素内的数据给分隔,这不是我们想要的结果。 上步已经把一个json数组转化为多个json字符串了,接下来结合son_tuple函数来解析json里面的字段: ...