hive语法树分析,判断 sql语句中有没有select *

pom依赖参考以下博文
java 通过 IMetaStoreClient 取 hive 元数据信息-CSDN博客

1 节点处理器类

import lombok.Getter;
import org.apache.hadoop.hive.ql.lib.Dispatcher;
import org.apache.hadoop.hive.ql.lib.Node;
import org.apache.hadoop.hive.ql.parse.ASTNode;
import org.apache.hadoop.hive.ql.parse.HiveParser;
import org.apache.hadoop.hive.ql.parse.SemanticException;
import java.util.Stack;/*** 节点处理器*/
public class SelectAllDispatcher implements Dispatcher {@Getterprivate boolean isContainsSelectstar = false;@Overridepublic Object dispatch(Node node, Stack<Node> stack, Object... objects) throws SemanticException {//强转成 ASTNodeASTNode astNode = (ASTNode) node;if (astNode.getType() == HiveParser.TOK_ALLCOLREF) {isContainsSelectstar = true;}return null;}}

2 sql语法树解析类

import org.apache.hadoop.hive.ql.lib.DefaultGraphWalker;
import org.apache.hadoop.hive.ql.lib.Dispatcher;
import org.apache.hadoop.hive.ql.lib.GraphWalker;
import org.apache.hadoop.hive.ql.parse.ASTNode;
import org.apache.hadoop.hive.ql.parse.HiveParser;
import org.apache.hadoop.hive.ql.parse.ParseDriver;
import org.springframework.util.StringUtils;
import java.util.Collections;public class SqlParser {/*** 遍历到每个节点时,对节点的处理。* 我们可以通过 自定义 Dispatcher 完成对节点的处理。** @param dispatcher 自定义节点处理器* @param sql        待分析的sql*/public static void sqlParse(Dispatcher dispatcher, String sql) {if (!StringUtils.hasText(sql)) {return;}try {// 解析 Hive SQLParseDriver parseDriver = new ParseDriver(); //创建解析引擎//执行解析  得到根节点ASTNode ast = parseDriver.parse(sql);//  找到查询的根节点下的TOK_QUERY节点,视为有效根节点while (ast.getToken() == null || ast.getToken().getType() != HiveParser.TOK_QUERY) {ast = (ASTNode) ast.getChild(0);}// 把节点处理器注入一个图形遍历器   使用自定义处理器遍历抽象语法树GraphWalker ogw = new DefaultGraphWalker(dispatcher);// 用遍历器遍历整个语法树ogw.startWalking(Collections.singletonList(ast), null);} catch (Exception e) {throw new RuntimeException(e);}}
}

3 测试

public class Test_12345 {public static void main(String[] args) {String sql1 = "SELECT * FROM table_name";String sql2 = "SELECT column1, column2 FROM table_name";String sql3 = "SELECT * FROM (SELECT * FROM another_table) t";String sql4 = "SELECT aa,bb FROM (SELECT * FROM another_table) t";String sql5 = "SELECT * FROM (SELECT bb FROM another_table) t";String sql6 = "SELECT a.* FROM table_a a JOIN table_b b ON a.id = b.id";String sql7 = "SELECT distinct * FROM table_a ";SelectAllDispatcher ggsdgsg = new SelectAllDispatcher();SqlParser.sqlParse(ggsdgsg,sql1);System.out.println("是否包括select * :" + ggsdgsg.isContainsSelectstar());System.out.println();ggsdgsg = new SelectAllDispatcher();SqlParser.sqlParse(ggsdgsg,sql2);System.out.println("是否包括select * :"  + ggsdgsg.isContainsSelectstar());System.out.println();ggsdgsg = new SelectAllDispatcher();SqlParser.sqlParse(ggsdgsg,sql3);System.out.println("是否包括select * :" + ggsdgsg.isContainsSelectstar());System.out.println();ggsdgsg = new SelectAllDispatcher();SqlParser.sqlParse(ggsdgsg,sql4);System.out.println("是否包括select * :"  + ggsdgsg.isContainsSelectstar());System.out.println();ggsdgsg = new SelectAllDispatcher();SqlParser.sqlParse(ggsdgsg,sql5);System.out.println("是否包括select * :"  + ggsdgsg.isContainsSelectstar());System.out.println();ggsdgsg = new SelectAllDispatcher();SqlParser.sqlParse(ggsdgsg,sql6);System.out.println("是否包括select * :"  + ggsdgsg.isContainsSelectstar());System.out.println();ggsdgsg = new SelectAllDispatcher();SqlParser.sqlParse(ggsdgsg,sql7);System.out.println("是否包括select * :"  + ggsdgsg.isContainsSelectstar());}
}


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/762989.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

org.springframework.boot:type=Admin,name=SpringApplication异常

javax.management.InstanceNotFoundException: org.springframework.boot:typeAdmin,nameSpringApplication 问题描述&#xff1a; IDEA 新建 SpringBoot 项目&#xff0c;启动时后台报错&#xff1a; javax.management.InstanceNotFoundException: org.springframework.boot…

windows搭建Elasticsearch环境

windows搭建Elasticsearch环境 本章搭建Elasticsearch ik分词器插件 kibana三个环境.三个版本都是7.8.0 1.安装Elasticsearch 安装网址: https://www.elastic.co/cn/downloads/past-releases#elasticsearch 下载解压后直接进入bin目录&#xff0c;双击运行elasticsearch.…

基于springboot的牙科就诊管理系统

技术&#xff1a;springbootmysqlvue 一、系统背景 当前社会各行业领域竞争压力非常大&#xff0c;随着当前时代的信息化&#xff0c;科学化发展&#xff0c;让社会各行业领域都争相使用新的信息技术&#xff0c;对行业内的各种相关数据进行科学化&#xff0c;规范化管理。这样…

粤嵌6818开发板如何理解Linux文件IO?

一、文件IO的概述 1、什么是文件&#xff1f; Linux下一切皆文件。普通文件、目录文件、管道文件、套接字文件、链接文件、字符设备文件、块设备文件。 2、什么是IO&#xff1f; input output&#xff1a;输入输出 3、什么是文件IO&#xff1f; 对文件的输入输出&#xff0c;把…

轻松找回丢失数据EasyRecovery数据恢复软件让你无后顾之忧

轻松找回丢失数据&#xff0c;EasyRecovery数据恢复软件让你无后顾之忧&#xff0c;电脑数码行业必备工具&#xff0c;让你的数据安全有保障 &#xff01; 一、EasyRecovery数据恢复软件简介 在我们的日常生活中&#xff0c;无论是工作还是学习&#xff0c;都离不开电脑和数据…

Terraform实战(四)-资源打标签

1 腾讯云 1.1 tf配置 标签&#xff08;Tag&#xff09;是腾讯云提供的云资源管理工具&#xff0c;以键值对 key:values 的形式存在&#xff0c;用于关联您的大多数云资源&#xff0c;对于资源的分类、搜索和聚合十分有用。 在 Terraform 中&#xff0c;通过 Map 来定义一个资…

Linux/Perfection

Enumeration nmap 用 nmap 扫描了常见的端口&#xff0c;发现对外开放了 22,80&#xff0c;扫描一下详细信息&#xff0c;如下所示 ┌──(kali㉿kali)-[~/vegetable/HTB/Perfection] └─$ nmap -sC -sV -p 22,80 10.10.11.253 -oA nmap Starting Nmap 7.93 ( https://nmap…

目标检测——DOTA航拍数据集

DOTA数据集是一个用于航空图像中目标检测的大规模数据集&#xff0c;旨在帮助研究人员开发和评估航空图像中的目标检测算法。该数据集具有广泛的应用价值&#xff0c;尤其在计算机视觉和遥感技术领域。 DOTA数据集的特点主要体现在以下几个方面&#xff1a;首先&#xff0c;其…

科研文献阅读方法

阅读科研文献是科研工作者的重要工作之一&#xff0c;以下是一些阅读科研文献的方法&#xff1a; 确定阅读目的&#xff1a;在阅读科研文献之前&#xff0c;确定你的阅读目的&#xff0c;是为了了解某一领域的最新进展&#xff0c;还是为了找到支持自己研究的理论和实证依据。…

408学习笔记-14-C-数据在内存中的存储

1、整数型存储 整数型存储就是所有整型家族里的数据类型的存储方式&#xff0c;也就是说包含了字符类型的存储&#xff08;因为字符的操作符的返回值是ASCII码值&#xff0c;故实际上存储的是整数&#xff09;。 1.1、有符号整数 有符号整数包含char&#xff0c;short&#x…

如何做接口测试?

今天来聊聊接口测试&#xff0c;现在是2024年了&#xff0c;打开招聘网站随便点开一个招聘帖子&#xff0c;几乎都可以看到岗位JD要求写着有接口测试经验优先。其重要性可见一斑&#xff01; 目前&#xff0c;凡是好一点稍具规模的公司哪怕是大厂外包也几乎都要求会接口测试&a…

解决mysql连接数据太多,“Too many connections“ 解决办法

解决mysql连接数据太多,"Too many connections" 解决办法 mysql出现Too many connections提示一般原因就是你网站连接数超过了你msyql配置的连接数据了,解决办法就是修改一下mysql配置文件中的max_connections参数或修改你程序连接直接及时处理.。 先搞清楚MySQL的…

一、typescript基础数据类型

1&#xff0c;布尔 let isDone:boolean false;2, 数字&#xff0c; 所有数字都是浮点数 let n:number 1;3,字符串 let name:string "mily", sex:string 女;4.数组 let arr1:number[] [1, 2, 3] let arr2:Array<number> [1, 2, 3]5,元祖&#xff0c; …

QT(6.5) cmake构建C++编程,调用python

一、注意事项 explicit c中&#xff0c;一个参数的构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数)&#xff0c;承担了两个角色&#xff0c;构造器、类型转换操作符&#xff0c; c提供关键字explicit&#xff0c;阻止转换构造函数进行的隐式转换的发生&#…

使用Docker搭建YesPlayMusic网易云音乐播放器并发布至公网访问

目录 ⛳️推荐 1. 安装Docker 2. 本地安装部署YesPlayMusic 3. 部署公有云YesPlayMusic播放器 3.1 安装cpolar内网穿透 3.2 固定YesPlayMusic公网地址 ⛳️推荐 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一…

【区间、栈】算法例题

目录 六、区间 48. 汇总区间 ① 49. 合并区间 ② 50. 插入区间 ② 51. 用最少数量的箭引爆气球 ② 七、栈 52. 有效的括号 ① 53. 简化路径 ② 54. 最小栈 ② 55. 逆波兰表达式求值 ② √- 56. 基本计算器 ③ 六、区间 48. 汇总区间 ① 给定一个 无重复元素 的 …

C# WPF编程-XAML

C# WPF编程-XAML XAML简述XAML子集XAML编译XAML基础XAML名称空间XAML中的属性和事件属性事件使用其他名称空间中的类型 加载和编译XAML XAML简述 XAML(Extensible Application Markup Language的简写&#xff0c;发音"zammel")是用于实例化.NET对象的标记语言。XAML…

LeetCode # 199. 二叉树的右视图

199. 二叉树的右视图 题目 给定一个二叉树的 根节点 root&#xff0c;想象自己站在它的右侧&#xff0c;按照从顶部到底部的顺序&#xff0c;返回从右侧所能看到的节点值。 示例 1: 输入: [1,2,3,null,5,null,4] 输出: [1,3,4] 示例 2: 输入: [1,null,3] 输出: [1,3] 示例 3…

大规模电商平台数据采集难点分析♫

▁▃▅▇主要包括以下几方面&#xff1a; API工具 ◆◆数据量巨大 任何系统&#xff0c;在不同的数据量面前&#xff0c;需要的技术难度都是完全不同的。 如果单纯是将数据采到&#xff0c;可能还比较好完成&#xff0c;但采集之后还需要处理&#xff0c;因为必须考虑数据的规…

如何根据业务需求选择合适的电子合同平台?

在数字化转型的浪潮中&#xff0c;电子合同已经成为企业运营中不可或缺的一部分。然而&#xff0c;面对市场上众多的电子合同平台&#xff0c;企业如何根据自身的业务需求做出合适的选择呢&#xff1f;本文将为您一一解答。 在电子合同的签署过程中&#xff0c;数字证书颁发机…