Hive On Spark语法

内层对象定义之特殊数据类型

Array

sql 复制代码
DROP TABLE IF EXISTS test_table_datatype_array;
CREATE TABLE test_table_datatype_array
(
	ids array<INT>
)
LOCATION 'test/test_table_datatype_array';

SELECT
	names,
	names[1]
	`array`(names[2],names[3])
	names[5],
	names[-1],
	array_contains(names,'e'),
	array_contains(names,'b')
FROM 
(
	select `array`('a',3,'b','c',4) names
) t;

Map

sql 复制代码
select
	kv,kv["c"],
	kv["e"],
	array_contains(map_keys(kv),"g"),
	array_contains(map_keys(kv),"c")
from 
(
	select `map`("a","b","c","d","e","f") kv
)

Struct

sql 复制代码
select
	obj,
	obj.name
from
(
	select named_struct('name','zhangsan','age',30,'id',1001) obj
) t

mysql中的数据是写在磁盘中的

当修改数据时,会写到内存中,操作系统会周期性的写到磁盘,

但 不安全,所以会再写在binlog(顺写 json)文件中,备份一下,再写到datafile(随机写入)中

相关推荐
IMPYLH4 小时前
Linux 的 pinky 命令
linux·运维·服务器·bash
REDcker5 小时前
Linux iptables 与 Netfilter:原理、路径与运维要点
linux·运维·服务器
嵌入式×边缘AI:打怪升级日志7 小时前
Linux 驱动开发入门:从最简单的 hello 驱动到硬件交互
linux·驱动开发·交互
Bert.Cai8 小时前
Linux useradd命令详解
linux·运维
无忧.芙桃9 小时前
进程控制(上)
linux·运维·服务器
十年编程老舅9 小时前
深入 Linux 中断:原理详解 + 实战落地
linux·网络·linux内核·c/c++·中断
Bert.Cai9 小时前
Linux rm命令详解
linux·运维
知识浅谈10 小时前
OpenClaw保姆级安装教程:基于ubuntu系统
linux·ubuntu·node.js
hweiyu0010 小时前
Linux命令:suspend
linux·运维·服务器
cyber_两只龙宝10 小时前
【Docker】Docker的资源限制
linux·运维·服务器·docker·云原生·容器