HIVE 转义字符与特殊字符处理

Hadoop和Hive都是用UTF-8编码的,hive用java写的,所以同Java一样都是'\'转义

很多函数会用到转义字符,比如split、regexp_replace等

但是有时候需要两个转义字符"\\",或者四个转义字符“\\\\”

  • 单转义符'\':常规的为'\'进行字符串的转义
  • 双转移符'\\':正则表达式匹配或者split函数中包含转义符
  • 四个转义符'\\\\':split函数中存在转义符'\'为分隔符
  • 分号:';'无法识别和转义,需要使用ASCII码处理(只要使用到了函数就会报错)

具体案例应用:

select 'a\b' as case1 
,'a\\b' as case2 
,'\134' as case3 
,'\\' as case4 
,'\;' as case5
,'\073' as case6 
,split('a\\b','\\\\') as case7
,split('a\134b','\134\134') as case8
,split('a\;b','\;') as case9
,split('a\073b','\073') as case10

-- 使用针对需要转义的符号需要使用\进行转义
-- 使用ASCII码可以免除转义过程,但在函数中可能存在二次编码转义

 查询结果:

  • 2
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值