java 使用JSqlParser和CCJSqlParser 解析sql

maven

java 复制代码
<dependency>
    <groupId>com.github.jsqlparser</groupId>
    <artifactId>jsqlparser</artifactId>
    <version>4.9</version>
</dependency>

解析SQL

java 复制代码
String sql = "select aa,bb from b";
Statement statement=CCJSqlParserUtil.parse(sql);
Select selectStatement = (Select) statement;
PlainSelect plainSelect = selectStatement.getPlainSelect();
//plainSelect可以获取sql各个部分 如属性集合
List<SelectItem<?>> selectItems0 = plainSelect.getSelectItems();

分析

Statement 被设计成一个接口满足CURD各个处理方式

1、查询PlainSelect继承Select

java 复制代码
        1.1//字段起别名  SELECT aa AS ALIAS1, bb AS ALIAS2 FROM b
        AddAliasesVisitor instance = new AddAliasesVisitor();
        instance.setPrefix("alias");
        selectStatement.accept(instance);
        1.2//加字段SELECT aa AS ALIAS1, bb AS ALIAS2, field FROM b
        SelectUtils.addExpression(selectStatement, new Column("field"));
        1.3//加字段表达式 SELECT aa AS ALIAS1, bb AS ALIAS2, field, 5 + 6 FROM b
                Addition add = new Addition();
        add.setLeftExpression(new LongValue(5));
        add.setRightExpression(new LongValue(6));
        SelectUtils.addExpression(selectStatement, add);
        1.4//加join  
        //SELECT aa AS ALIAS1, bb AS ALIAS2, field, 5 + 6 FROM b LEFT JOIN mytable2 ON a = b
        
        EqualsTo equalsTo = new EqualsTo();
        Statement select = (PlainSelect) test(sql);
        equalsTo.setLeftExpression(new Column("a"));
        equalsTo.setRightExpression(new Column("b"));
        Join addJoin = SelectUtils.addJoin(selectStatement, new Table("mytable2"), equalsTo);
        addJoin.setLeft(true);
        //SelectUtils构建一个SQL语句
                Select selectbuild = SelectUtils.buildSelectFromTableAndExpressions(new Table("mytable"), new Column("a"), new Column("b"));
       //SELECT a, b, c FROM mytable
       SelectUtils.addExpression(selectbuild, new Column("c"));
        //where 条件设置
        EqualsTo equalsTo1 = new EqualsTo();
        equalsTo1.setLeftExpression(new Column("id"));
        equalsTo1.setRightExpression(new Column("1"));
        PlainSelect plainSelect1 = selectbuild.getPlainSelect();
        plainSelect1.setWhere(equalsTo1);
        更多条件访问 https://blog.csdn.net/a250152/article/details/128610616

2、插入Insert

3、更新Update

4、删除Delete

相关推荐
程序员清风14 分钟前
快手二面:乐观锁是怎么用它来处理多线程问题的?
java·后端·面试
曦樂~29 分钟前
【Qt】信号与槽(Signal and Slot)- 简易计算器
开发语言·数据库·qt
一线大码29 分钟前
SpringBoot 优雅实现接口的多实现类方式
java·spring boot·后端
花伤情犹在34 分钟前
Java Stream 高级应用:优雅地扁平化(FlatMap)递归树形结构数据
java·stream·function·flatmap
yaoxin5211231 小时前
212. Java 函数式编程风格 - Java 编程风格转换:命令式 vs 函数式(以循环为例)
java·开发语言
ZYMFZ1 小时前
python面向对象
前端·数据库·python
摇滚侠1 小时前
Spring Boot 3零基础教程,WEB 开发 Thymeleaf 属性优先级 行内写法 变量选择 笔记42
java·spring boot·笔记
滑水滑成滑头1 小时前
**发散创新:多智能体系统的探索与实践**随着人工智能技术的飞速发展,多智能体系统作为当今研究的热点领域,正受到越来越多关注
java·网络·人工智能·python
摇滚侠1 小时前
Spring Boot 3零基础教程,WEB 开发 Thymeleaf 总结 热部署 常用配置 笔记44
java·spring boot·笔记
十年小站1 小时前
一、新建一个SpringBoot3项目
java·spring boot