• 大数据分析之纳税人画像-实现和优化思路


    1.背景环境

    本文章来自最近做的项目模块的思考和总结,主要讲思路不涉及过多的基础和实现细节。

    需求:统计出来纳税人名称、行业、近一年业务量(办税服务厅、电子税务局、自助渠道),近一年业务量top5(办税服务厅、电子税务局、自助渠道)、近一年纳税金额、近一年申报数、近一年用票数。支持根据所属税务机关分页查询。


    看上去业务不复杂,但是数据来自多个系统,数据量很大。来来画个示意图展示下数据来源的复杂程度:
    未命名文件.png
    数据涉及5个厂商,数据库采用oracle,涉及几十张表,其中纳税人信息生产环境下有380多万,更不用说其他业务表的数据量有多大了,并且还需要分组,统计,排序。此时此刻心情如下:image.png

    2.实现方案

    2.1 视图(失败的方案)

    由于项目时间关系,想法很简单先采用视图,先实现再说。(其实在做的时候就有不详的预感,感觉这种方案不行)。于是开干,在实现的过程中我用到的
    关键技术点有:
    oracle wm_concat(column)函数实现查询相同id字段,内容以逗号分隔

    select id, wmsys.wm_concat(字段名)字段别名  from table group by id
    


    Oracle分组查询取每组排序后的前N条记录

    SELECT *   
    FROM  (
            SELECT 分组的字段名, ROW_NUMBER() OVER(PARTITION BY 分组的字段名 
            ORDER BY 排序的字段名) AS RN FROM 表名
    ) 
    WHERE RN <= 10   得到分组后,数据的前几条
    

    count、sum、group by 、join、dblink等等
    生产环境下验证结果
    测试环境还好,生产环境打开视图好久查不出来数据,临时表空间暴增30g. 来看下现场的执行计划
    image.pngimage.png

    冷静分析

    • 数据库是其他厂商的,我们没有权限去建索引,只给了查询权限。
    • 大量的hash join,这些操作都在内存中,内存不足会把临时计算结果放到磁盘导致临时表空间暴增。
    • 分组、排序类的特别耗时。
    • 问题的本质也就是类似于数据结构的:时间复杂度和空间复杂度。 通俗点说你愿意拿空间换时间还是时间换空间?
    • 大道至简、分而治之。当人类面临负责问题和巨大工程的时候,都喜欢切成一小块一小块的去处理,问题就迎刃而解。

    2.2 定时任务汇总(备选方案1)

    接着上文,其实我们可以提前把数据加工好,插入汇总表,不用每次用户查询的时候去计算就好了。
    技术实现关键点:

    • 可以用spring +quarter 定时任务
    • oracle中定时任务

    以上在汇总的过程中必须注意一次拉取小批量数据加工。
    由于时间紧急,定时任务需要开发代码,数据量大,数据批次需要处理等缺点放弃了

    2.3 物理视图(选用方案2)

    因为有比较多的查询汇总,考虑到速度,最后选择了物理视图方案。下面简单介绍下物理视图。
    物化视图也是种视图。Oracle的物化视图是包括一个查询结果的数据库对像,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据,也可以称为快照。
    物化视图可以查询表,视图和其它的物化视图。
    特点:
    (1) 物化视图在某种意义上说就是一个物理表(而且不仅仅是一个物理表),这通过其可以被user_tables查询出来,而得到确认;
    (2) 物化视图也是一种段(segment),所以其有自己的物理存储属性;
    (3) 物化视图会占用数据库磁盘空间,这点从user_segment的查询结果,可以得到佐证;
    创建语句:create materialized view mv_name as select * from table_name
    创建过程一波三折
    把方案一种的视图sql改称物理视图,到生产环境下创建。尼玛又出状况了

    一个sql执行了8个小时,居然失败了,怎么办?
    冷静分析

    • 仔细看sql,去掉了不必要的关联查询。
    • 拆分物理视图,一个拆三,分而治之。

    最后在3个小时左右,成功创建了5个物理视图。
    又出状况、一波四折
    **
    测试库是11.2.0.1.0的,WMSYS.WM_CONCAT( )函数返回的是varchar类型,而正式库是11.2.0.4.0的,返回的是CLOB类型的。为了兼容,所以解决办法是:TO_CHAR(WMSYS.WM_CONCAT(param )); 只要用to_char()函数转换一下就可以了。。。
    好吧,重新来过,最后在3个小时左右,成功创建了5个物理视图。

    2.4 hadoop(做梦的方案,杀鸡蔫用牛刀)

    据说PB级别的数据,才上hadoop。为了卖弄一下我也懂点大数据技术(毕竟也读过几本书),简单的列一下实现思路:
    0.搭建hadoop平台
    1.sqoop导入数据到hive
    2.利用hive进行分析
    3.sqoop把分析结果导入Oracle汇总表
    4.持续运维
    为什么不采用的原因:
    1.数据量远远不够
    2.客户是否给你那么多机器来组集群。
    3.公司缺乏相关技术的开发和运维,成本代价高。

    3.结论

    • 大道至简、分而治之
    • 思路总比问题多,不抛弃不放弃。


    总结不易欢迎在看或转发,更多精彩关注微信公众号【lovepythoncn】

  • 相关阅读:
    sysbench安装部署for postgresql
    sysbench安装部署for mysql
    pg创建dblink访问另外的库下的表
    11grac配置EM
    重新配置grid(ocr有备份,采用ocr备份进行恢复)
    rac资源显示脚本
    重新配置grid(已经有数据库的情况)ocr没有备份
    Can't locate Env.pm in @INC
    比特币-隔离见证(Segwit)
    传智播客 .NET面试宝典(2014版)
  • 原文地址:https://www.cnblogs.com/qingmiaokeji/p/13060907.html
Copyright © 2020-2023  润新知