JSqlParser 解析 sql

目录

前言

JSqlParser是一个 SQL 语句解析器。它将 SQL 语句转换为可遍历的 Java 类层次结构,可以方便的用代码对 SQL 语句进行解析,修改等操作。

官网 api 文档和 github 地址如下:

jsqlparser API 文档

jsqlparser github 地址

一、Maven依赖

xml 复制代码
        <!-- 4.9版本是适用于jdk8的最后一个版本-->
        <dependency>
            <groupId>com.github.jsqlparser</groupId>
            <artifactId>jsqlparser</artifactId>
            <version>4.9</version>
        </dependency>

二、获取sql中的表名

java 复制代码
import net.sf.jsqlparser.JSQLParserException;
import net.sf.jsqlparser.util.TablesNamesFinder;
import java.util.Set;

public class MainServer {
    public static void main(String[] args) throws JSQLParserException {
        String sql = "SELECT e.employee_id, e.first_name, e.last_name, d.department_name, e.salary " +
                "FROM employees e " +
                "LEFT JOIN departments d ON e.department_id = d.department_id " +
                "WHERE e.salary > ( " +
                "    SELECT AVG(salary) " +
                "    FROM staff " +
                "    WHERE department_id = e.department_id " +
                ");";
        Set<String> tableNames = TablesNamesFinder.findTables(sql);
		//输出: staff, departments, employees
        System.out.println(tableNames);
    }
}

三、获取sql中的具体信息

java 复制代码
import javassist.CannotCompileException;
import net.sf.jsqlparser.JSQLParserException;
import net.sf.jsqlparser.parser.CCJSqlParserUtil;
import net.sf.jsqlparser.statement.Statement;
import net.sf.jsqlparser.statement.select.PlainSelect;
import net.sf.jsqlparser.statement.select.Select;


public class MainServer {
    public static void main(String[] args) throws CannotCompileException, JSQLParserException {
	
        String sql = "SELECT DISTINCT e.employee_id, e.first_name, e.last_name, d.department_name, e.salary " +
                "FROM employees e " +
                "LEFT JOIN departments d ON e.department_id = d.department_id " +
                "WHERE e.salary > ( " +
                "    SELECT AVG(salary) " +
                "    FROM staff " +
                "    WHERE department_id = e.department_id " +
                ") " +
                "GROUP BY d.department_id, e.employee_id, e.first_name, e.last_name, d.department_name, e.salary " +
                "HAVING COUNT(*) = 1  " +
                "ORDER BY d.department_name " +
                "LIMIT 10 OFFSET 20;";
        Statement statement = CCJSqlParserUtil.parse(sql);

        //如果是 select 语句
        if (statement instanceof Select) {
            Select selectStatement = (Select) statement;
            PlainSelect plainSelect = selectStatement.getPlainSelect();
            System.out.println("【DISTINCT 子句】:" + plainSelect.getDistinct());
            System.out.println("【查询字段】:" + plainSelect.getSelectItems());
            System.out.println("【FROM 表】:" + plainSelect.getFromItem());
            System.out.println("【JOIN 子句】:" + plainSelect.getJoins());
            System.out.println("【WHERE 子句】:" + plainSelect.getWhere());
            System.out.println("【GROUP BY 子句】:" + plainSelect.getGroupBy());
            System.out.println("【HAVING 子句】:" +plainSelect.getHaving());
            System.out.println("【ORDER BY 子句】:" + plainSelect.getOrderByElements());
            System.out.println("【LIMIT 子句】:" + plainSelect.getLimit());
            System.out.println("【OFFSET 子句】:" + plainSelect.getOffset());
        }
    }
}

输出:

java 复制代码
【DISTINCT 子句】:DISTINCT
【查询字段】:[e.employee_id, e.first_name, e.last_name, d.department_name, e.salary]
【FROM 表】:employees e
【JOIN 子句】:[LEFT JOIN departments d ON e.department_id = d.department_id]
【WHERE 子句】:e.salary > (SELECT AVG(salary) FROM staff WHERE department_id = e.department_id)
【GROUP BY 子句】:GROUP BY d.department_id, e.employee_id, e.first_name, e.last_name, d.department_name, e.salary
【HAVING 子句】:COUNT(*) = 1
【ORDER BY 子句】:[d.department_name]
【LIMIT 子句】: LIMIT 10
【OFFSET 子句】: OFFSET 20

参考:
JSqlParser实战指南
JSQLParser 解析复杂SQL
JSqlParser入门系列
jsqlparser基本使用

相关推荐
伊成2 分钟前
一文详解Spring Boot如何配置日志
java·spring boot·单元测试
若兰幽竹7 分钟前
【HBase整合Hive】HBase-1.4.8整合Hive-2.3.3过程
数据库·hive·hbase
lybugproducer9 分钟前
浅谈 Redis 数据类型
java·数据库·redis·后端·链表·缓存
青山是哪个青山10 分钟前
Redis 常见数据类型
数据库·redis·bootstrap
廖圣平21 分钟前
美团核销 第三方接口供应商 (含接口文档)
开发语言·数据库·php
purrrew35 分钟前
【Java ee初阶】网络编程 UDP socket
java·网络·网络协议·udp·java-ee
@解忧杂货铺39 分钟前
MySQL历史版本下载及安装配置教程
数据库·mysql
hnlucky1 小时前
《基于 Kubernetes 的 WordPress 高可用部署实践:从 MariaDB 到 Nginx 反向代理》
运维·数据库·nginx·云原生·容器·kubernetes·mariadb
dgiij1 小时前
excel大表导入数据库
数据库·mysql·node.js·excel
上海合宙LuatOS1 小时前
全栈工程师实战手册:LuatOS日志系统开发指南!
java·开发语言·单片机·嵌入式硬件·物联网·php·硬件工程