数据治理-表模型使用频率如何统计?来实现末尾淘汰?

原文来自:公众号:阿龙学堂

数据治理-表模型使用频率如何统计?来实现末尾淘汰?

1、统一查询

        当有了数据中台,所有查询请求就要进入到数据中台来进行查询。这个时候就要在权限控制,脱敏等方面进行安全法律控制,但数据中台从技术上来看,数据必须要更新迭代,不能一直入库,不能删除,数据量会越来越大。维护成本极高。为了解决这一问题,我们就要对数据查询的SQL就要进行监控,分析处理来得到他的信息。

2、模型使用频率监控

        解析SQL用到了哪些表,可以对表模型进行优胜虐汰,使用频率最低的top5在下个阶段下线处理。大SQL用啥解析了?

推荐使用 [SQL解释器(JSqlParser)]

3、SQL解释器(JSqlParser)使用

3.1、概述

        JSqlParser能够解析SQL语句翻译成一个Java类层次结构。它具有扩展的SQL语法,不仅限于一个数据库,而且还支持Oracle,SqlServer,MySQL,PostgreSQL等许多数据库。

3.2、入门操作

1、添加依赖

JSqlParser的依赖已经添加到了盘古common包中,使用时,引入common包即可。

<!--maven依赖 --><dependency>    <groupId>com.github.jsqlparser</groupId>    <artifactId>jsqlparser</artifactId>    <version>3.2</version></dependency>
2、使用方法

        解析SQL语句前需要先创建数据库操作类。CCJSqlParserManager类是用于创建对数据库操作接口类Statement。Statement包含了对数据库的查询、插入、修改等多种操作。此外,JSqlParser中也提供了工具类CCJSqlParserUtil,通过parse方法,也可以创建Statement类。下面介绍几种使用方式。

▪️查询表名 table

​​​​​​​

private static List<String> test_select_table(String sql) 
throws JSQLParserException {        Statement statement = CCJSqlParserUtil.parse(sql);        Select selectStatement = (Select) statement;        TablesNamesFinder tablesNamesFinder = new TablesNamesFinder();        return tablesNamesFinder.getTableList(selectStatement);    }
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值