今天也要学习呐 2022-08-02 12:01 采纳率: 68.2%
浏览 222
已结题

hive怎么拼接单引号

问题遇到的现象和发生背景

我希望把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怎么拼接单引号或者用其他什么方法能实现我的需求。

  • 写回答

7条回答 默认 最新

  • sinJack 2022-08-02 12:42
    关注

    不能用拼接,拼接之后用不了in,in是判断左边的字段是否在右边内容(集合)中,拼接的是一个字符串整体,不是集合。

    SELECT sku_key,warehouse_key,SUM(quantity) FROM wln_dw_zb.t_dwd_sale_outstorage_order
    WHERE shop_key in (SELECT regexp_replace(NVL(shop_keys,""),"[\\s]+|[\u3000]+|[']+","") FROM shop_group_pattern WHERE parent_name = '店铺组别1')
    

    这个应该是满足你需求的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
  • 今天也要学习呐 2022-08-02 13:37
    关注

    我维表中的shop_key是数字,字母和特殊符号都有的,并不单是一串数字

    评论
  • 啊啊清欢 2022-08-02 13:38
    关注

    SELECT company_key,pt,concat_ws(',',collect_set(key)) as shop_keys FROM t_dim_shop
    少了个字段

    评论
  • 笑看风云路 大数据领域优质创作者 2022-08-02 15:26
    关注
    
    SELECT sku_key,SUM(quantity) FROM t_dwd_trade
    WHERE shop_key in (SELECT split(shop_keys,',') shop_keys FROM shop_group)
    GROUP BY sku_key
    
    评论
  • 反派的大佬 2022-08-02 15:53
    关注

    SELECT sku_key,SUM(quantity) FROM t_dwd_trade
    WHERE shop_key in (SELECT split(shop_keys,',') shop_keys FROM shop_group)
    GROUP BY sku_key

    评论
  • 王大师王文峰 企业官方账号 2022-08-02 18:57
    关注

    这个可以拼接,望采纳,谢谢
    输入:
    select concat(‘abc’,'def’,'gh’) from lxw_dual;
    输出:
    abcdefgh

    评论
  • 与猿共舞 2022-08-06 10:20
    关注

    不以并接

    评论
查看更多回答(6条)

报告相同问题?

问题事件

  • 系统已结题 8月17日
  • 已采纳回答 8月9日
  • 修改了问题 8月2日
  • 修改了问题 8月2日
  • 展开全部

悬赏问题

  • ¥15 VB6.0中PICTUREBOX加载本地图片无法显示
  • ¥100 关于游戏app session获取的问题
  • ¥15 MYSQL数据库建表
  • ¥15 爬虫程序爬取TTGChina网站文章代码
  • ¥35 由于系统缓冲区空间不足或队列已满,不能执行套接字上的操作。
  • ¥15 如何用下图方法在AMESim中搭建离心泵模型
  • ¥15 C#连接服务器,请求时报Ssl/Tsl未能建立安全通道
  • ¥15 xcode15build的c++ dylib在10.15上不兼容
  • ¥15 CPLD如何实现在线逻辑分析
  • ¥15 控制面板卸载无权限!!