问题遇到的现象和发生背景
我希望把shop维表中的shop_key拼接在一起,然后在其他表中用shop_key in (我拼接的shop_key)来实现条件筛选。代码及具体思路在下面的代码框里。
问题相关代码,请勿粘贴截图
--1.首先创建一个表来放拼接的shop_key
CREATE TABLE if not EXISTS shop_group(
company_key BIGINT ,
pt BIGINT ,
shop_keys STRING ,
parent_name STRING
);
INSERT OVERWRITE TABLE shop_group
SELECT company_key,pt,concat_ws(',',collect_set(key)) as shop_keys,parent_name FROM t_dim_shop
WHERE 1 = 1
GROUP BY company_key,pt,parent_name;
--shop_group表中的一条数据为:'963852741','11','2:1169A6B553EB32C5B1031,2:147360931FB33404B22B,2:19FD6A7EF8AF3193956,2:226B7BF854D838ACBB19','店铺组别1'
--2.然后在其他表中应用,希望拿每一个parent_name下的所有我拼接起来的shop_keys(我这里写的不对,没有分别拿每个parent_name下的shop_keys)
SELECT sku_key,SUM(quantity) FROM t_dwd_trade
WHERE shop_key in (SELECT shop_keys FROM shop_group)
GROUP BY sku_key;
运行结果及报错内容
第二段代码运行出来是没有结果的,因为会把我拼接的所有shop_key合在一起作为一个STRING,而不是每个shop_key作为一个STRING。
我想要达到的结果
想请教一下hive怎么拼接单引号或者用其他什么方法能实现我的需求。