概述
参考文章:KUDU&Impala基本操作
使用impala对kudu进行DML操作
kudu insert data api
kudu官网impala操作kudu表
说明
通过Java client等其他方式在kudu中创建了某个表,要想对该表进行操作,需要在impala中创建外部表,将其映射到impala当中
SQL操作
通过impala对kudu进行sql操作
数据库操作
--描述表
DESCRIBE tabel_name;
--查看分区情况
SHOW PARTITIONS table_name;
--查看当前使用数据库
SELECT current_database();
--查看建表语句
SHOW CREATE TABLE table_name
创建数据库(creat db)
--impala创建数据库与hive一样,create database db_name,
--但是这个数据库只是一个impala端的namespace,
--kudu官网中没有提到数据库的概念,猜测可能是没有这个概念
--impala中创建表的时候比如在test数据库中创建table_test对应在kudu中为 test:table_test
--创建数据库
CREATE DATABASE IF NOT EXISTS POC_TEST;
--进入数据库
use POC_TEST;
创建表(creat table)
创建表的注意事项
(0) 创建外部表,内部表
--创建外部表
--假设已经通过Java client等其他方式在kudu中创建了某个表,
--要想对该表进行操作,需要在impala中创建外部表,将其映射到impala当中,例如:
CREATE EXTERNAL TABLE my_mapping_table
STORED AS KUDU
TBLPROPERTIES('kudu.table_name' = 'my_kudu_table');
--创建内部表
--假设要通过impala创建一个新的kudu表,需要在impala中创建一个内部表,例如:
CREATE TABLE testinkudu(…………)
partition by hash partitions 8
STORED AS KUDU [AS SELECT * FROM OTHER_TABLE];
--注:创建内部表时,类似partition by ………stored as kudu的分区声明语句是必须的。
--无论是 通过client创建的kudu表还是通过impala创建的表,
--都可以在master节点的UI界面的tables选项中查看
Kudu中的分区方法主要有两种:partition by hash和partition by range
(1) Hash分区
-- 基于hash的分区方法的基本原理是:基于primary key的hash值将每个row划分到相应的tablet当中,
-- 分区的个数即tablet的个数必须在创建表语句中指定
-- 如果未指定基于某个字段的hash值进行分区,默认以主键的hash值进行分区
--主键两个字段,分区字段未指定 hash分区
create table kudu_first_table(
id int,
name string,
age int,
gender string,
primary key(id,name)
)
partition by hash partitions 4
stored as kudu;
--主键一个字段,分区字段未指定 hash分区
CREATE TABLE my_first_table
(
id BIGINT,
name STRING,
PRIMARY KEY(id)
)
PARTITION BY HASH PARTITIONS 16
STORED AS KUDU;
--表不存在则创建, 主键一个字段, 分区字段未指定 hash分区
CREATE TABLE IF NOT EXISTS POC_TEST.sdc(
id string,
name string,
PRIMARY KEY (id)
)
PARTITION BY HASH(id) PARTITIONS 2
STORED AS KUDU;
TBLPROPERTIES('kudu.master_addresses'='master.msxf.hadoop:7051','kudu.num_tablet_replicas' = '1');
--主键两个字段,分区字段指定,hash分区
create table specify_partition_column(
id int,
name string,
age int,
gender string,
primary key(id,name)
) partition by hash(id) partitions 3
stored as kudu;
--主键两个字段,分区字段指定一个字段,hash分区
create table specify_partition_one_column(
id int,
name string,
age int,
gender string,
primary key(id)
) partition by hash(id) partitions 3
stored as kudu;
--区别:未指定分区字段时,其分区字段默认是主键,若主键有两个列则分区字段为两个,指定分区字段时,
-- 需要分区列是主键的子集;否则会报错「 Only key columns can be used in PARTITION BY」
--不指定分区:表依然会创建,但是只有一个分区,会提示「Unpartitioned Kudu tables are ineff
(2) range分区:主要针对时间进行range分区
-- 基于range的分区方法的基本原理是:基于指定主键的取值范围将每个row划分到相应的tablet当中,
-- 用于range分区的主键以及各个取值范围都必须在建表语句中声明
CREATE TABLE cust_behavior (
_id BIGINT PRIMARY KEY,
salary STRING,
edu_level INT,
usergender STRING,
`group` STRING,
city STRING,
postcode STRING,
last_purchase_price FLOAT,
last_purchase_date BIGINT,
category STRING,
sku STRING,
rating INT,
fulfilled_date BIGINT
)
PARTITION BY RANGE (_id)
(
PARTITION VALUES < 1439560049342,
PARTITION 1439560049342 <= VALUES < 1439566253755,
PARTITION 1439566253755 <= VALUES < 1439572458168,
PARTITION 1439572458168 <= VALUES < 1439578662581,
PARTITION 1439578662581 <= VALUES < 1439584866994,
PARTITION 1439584866994 <= VALUES < 1439591071407,
PARTITION 1439591071407 <= VALUES
)
STORED AS KUDU;
--优势:可以根据数据的具体情况建立分区,比如:建立2017年之前的分区,2017-2018,2018-2019,2019-2020,2020-2021,。。。
--劣势:如果使用单级range分区的话,容易产生数据热点问题(可混合hash分区使用)、
-- 在range分区中,如果有不止一个字段作为分区字段的话也可以,语法暂时不清楚;
-- 如果插入一条主键的值不落在任何range区间时会插入失败,并报错
(3) 混合分区
create table tw_details4(
user_id string,
event_date string,
event string,
properties string,
customer_id int,
project_id int,
primary key(event_date,event,user_id)
) partition by hash(user_id) partitions 3, range(event_date)(
partition values < '2017-01-01',
partition '2017-01-01' <= values < '2018-01-01',
partition '2018-01-01' <= values < '2019-01-01',
partition '2019-01-01' <= values < '2020-01-01',
partition '2020-01-01' <= values < '2021-01-01'
) stored as kudu;
--优势:可以根据时间进行检索,来减少需要scan的tablet,插入的时候不会只有一个tabletserver产生热点
(4) CTAS方式创建表
CREATE TABLE kudu_ti_event_fact_copy
primary key(user_id,event_date)
partition by hash(user_id) partitions 3
stored as kudu
as select user_id,event_date,properties from auto3.ti_event_fact;
删除表和删除数据库
DROP TABLE [表名];
DROP DATABASE [数据库名];
删除试图
DROP VIEW [视图名];
插入(insert)
impala 允许使用标准 SQL 语句将数据插入 Kudu
--单行插入:
insert into my_first_table(time, uid, event_id, action_value) values(123,"v2", "123", 2)
insert into table1 values(v1,v2,v3)
-- 多行插入:
INSERT INTO my_first_table(time, uid, event_id, action_value) VALUES (1, "john"), (2, "jane"), (3, "jim");
-- 批量插入(Batch Insert)
--从 Impala 和 Kudu 的角度来看,通常表现最好的方法通常是使用 Impala 中的 SELECT FROM 语句导入数据
INSERT INTO my_kudu_table SELECT * FROM legacy_data_import_table;
insert into table1 select v1,v2,v3 from table2;
插入(upsert)
--根据主键判定,若已经存在则更新,若不存在则插入
upsert into table1 values(v1,v2,v3)
更新(update)
--单行更新
UPDATE my_first_table SET name="bob" where id = 3;
--批量更新
UPDATE my_first_table SET name="bob" where id > 2;
--where条件后面的column不是主键也可以,但是更改的范围会扩大
--主键中不支持更改,只能删除后重新添加
UPDATE kudu_first_table set age = 32 where id= 2;
UPDATE kudu_first_table set age = 31 where gender= 'female';
查询操作
Impala String函数大全
更多参考官网
--获取某一天的时间(时间类型转string类型,在截取时间)
select substr(cast(CREATE_DATE as string),1,10)
from CBEE_ELIST WHERE substr(cast(CREATE_DATE as string),1,10) = '2001-02-01'
删除(delete)
DELETE FROM my_first_table WHERE id < 3;
更改表
--修改表名,修改的只是表在impala中的映射名
alter table kudu_ti_event_fact_copy rename to kudu_ti_event_fact_copy_rename;
--修改kudu存储的表名,但是不会改变在impala端的映射表名,也就是在impala中依然访问更改之前的表名
ALTER TABLE kudu_ti_event_fact_copy_rename
SET TBLPROPERTIES('kudu.table_name' = 'kudu_ti_event_fact_copy');
--修改列属性
-- --**不支持---
--添加列
alter table kudu_ti_event_fact_copy_rename add columns(method string,time_stamp string);
--删除列
ALTER table kudu_ti_event_fact_copy_rename drop column method;
--删除分区
ALTER TABLE range_partition_table DROP RANGE PARTITION VALUES < '2017-01-01';
--添加分区
alter table range_partition_table add range partition values < '2017-01-01';
最后
以上就是踏实大象为你收集整理的Kudu之SQL操作(KUDU&Impala基本操作)说明SQL操作的全部内容,希望文章能够帮你解决Kudu之SQL操作(KUDU&Impala基本操作)说明SQL操作所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复