利用hive的内置函数做长数据的运算
1.需求
统计每个月每天出现的情况,比如下面两串数字
0100010101000101010100101010101
1101010101010101010100101010100
这两串数字一共31位的,每一位代表某个月的某一天,如电信的号码某一天有使用流量记录就置成1,没有为0
现在是想把这两串数字拼起来,我需要的数字是两个标识同一天有1的就置为1,两个1也置为1,得出的结果最好不要有科学计数的出现,我想要结果是这样的 1101010101010101010100101010101。---------按位或 运算
2.进程
因为数字长度有31位,普通的数字类型不能存下这么长的数据,所以建表的时候,我利用string类型存储了这两行数据。
在进行或运算的时候,我需要将string类型转换成整型,我利用bigint来进行存储,但是问题是,我是用cast函数进行转换的过程中,发现开头为0的字符串抓换完以后,不能保留开头的0数字。所以得出的结果不正确。
求助大佬帮我利用内置函数来将这个string类型转换过后的数据保留0,并且还能进行运算。