MCPcopy Index your code
hub / github.com/JSQLParser/JSqlParser

github.com/JSQLParser/JSqlParser @jsqlparser-5.4

repository ↗ · DeepWiki ↗ · release jsqlparser-5.4 ↗ · + Follow
6,906 symbols 22,371 edges 666 files 447 documented · 6% 2 cross-repo links
README

JSqlParser 5.2 Website drawing

CI Coverage Status Codacy Badge Maven Central Javadocs Gitter

A huge thank you to our sponsor, Starlake.ai who simplifies data ingestion, transformation, and orchestration, enabling faster delivery of high-quality data. Starlake has been instrumental in providing Piped SQL and numerous test cases for BigQuery, Redshift, DataBricks, and DuckDB. Show your support for ongoing development by visiting Starlake.ai and giving us a star!

Summary

Please visit our WebSite for detailed information. JSqlParser is a RDBMS agnostic SQL statement parser. It translates SQL statements into a traversable hierarchy of Java classes (see Samples):

SELECT 1 FROM dual WHERE a = b

/* produces the following AST

SQL Text
 └─Statements: statement.select.PlainSelect
    ├─selectItems: statement.select.SelectItem
    │  └─LongValue: 1
    ├─Table: dual
    └─where: expression.operators.relational.EqualsTo
       ├─Column: a
       └─Column: b
*/
String sqlStr = "select 1 from dual where a=b";

PlainSelect select = (PlainSelect) CCJSqlParserUtil.parse(sqlStr);

SelectItem selectItem =
        select.getSelectItems().get(0);
Assertions.assertEquals(
        new LongValue(1)
        , selectItem.getExpression());

Table table = (Table) select.getFromItem();
Assertions.assertEquals("dual", table.getName());

EqualsTo equalsTo = (EqualsTo) select.getWhere();
Column a = (Column) equalsTo.getLeftExpression();
Column b = (Column) equalsTo.getRightExpression();
Assertions.assertEquals("a", a.getColumnName());
Assertions.assertEquals("b", b.getColumnName());

Support for Piped SQL

Work is progressing for parsing Piped SQL, a much saner and more logical way to write queries in its semantic order.

FROM Produce
|> WHERE
    item != 'bananas'
    AND category IN ('fruit', 'nut')
|> AGGREGATE COUNT(*) AS num_items, SUM(sales) AS total_sales
   GROUP BY item
|> ORDER BY item DESC;

For details, please see https://storage.googleapis.com/gweb-research2023-media/pubtools/1004848.pdf, https://cloud.google.com/bigquery/docs/reference/standard-sql/pipe-syntax and https://duckdb.org/docs/sql/query_syntax/from.html#from-first-syntax

Java Version

JSQLParser-4.9 was the last JDK8 compatible version. JSQLParser-5.0 and later depend on JDK11 and introduce API breaking changes to the AST Visitors. Please see the Migration Guide for the details.

Building JSQLParser-5.1 and newer with Gradle will depend on a JDK17 toolchain due to the used plugins.

Performance

Unfortunately the released JSQLParser-5.2 shows a performance deterioration caused by commit 30cf5d7 related to FunctionAllColumns(). This has been resolved in JSQLParser 5.3-SNAPSHOT and JMH benchmarks have been added to avoid such regressions in the future. Further all LOOKAHEADS have been revised one by one, and we have gained back a very good performance of the Parser.

Benchmark                               (version)  Mode  Cnt    Score   Error  Units
JSQLParserBenchmark.parseSQLStatements     latest  avgt   30   78.287 ± 4.730  ms/op <-- `FunctionAllColumns()` disabled
JSQLParserBenchmark.parseSQLStatements        5.2  avgt   30  400.876 ± 8.291  ms/op
JSQLParserBenchmark.parseSQLStatements        5.1  avgt   30   85.731 ± 1.288  ms/op

Supported Grammar and Syntax

JSqlParser aims to support the SQL standard as well as all major RDBMS. Any missing syntax or features can be added on demand.

RDBMS Statements
Oracle

MS SQL Server and Sybase

Postgres

MySQL and MariaDB

DB2

H2 and HSQLDB and Derby

SQLite | SELECT

INSERT, UPDATE, UPSERT, MERGE

DELETE, TRUNCATE TABLE

CREATE ..., ALTER ...., DROP ...

WITH ... | | Salesforce SOQL | INCLUDES, EXCLUDES | | Piped SQL (also known as FROM SQL) | |

JSqlParser can also be used to create SQL Statements from Java Code with a fluent API (see Samples).

Sister Projects

If you like JSqlParser then please check out its related projects:

Alternatives to JSqlParser?

General SQL Parser looks pretty good, with extended SQL syntax (like PL/SQL and T-SQL) and java + .NET APIs. The tool is commercial (license available online), with a free download option.

Alternatively the dual-licensed JOOQ provides a handwritten Parser supporting a lot of RDBMS, translation between dialects, SQL transformation, can be used as a JDBC proxy for translation and transformation purposes.

Documentation

  1. Samples
  2. Build Instructions and Maven Artifact
  3. Contribution
  4. Change Log
  5. Issues

License

JSqlParser is dual licensed under LGPL V2.1 or Apache Software License, Version 2.0.

Extension points exported contracts — how you extend this code

StatementListener (Interface)
@author Tobias Warneke (t.warneke@gmx.net) [194 implementers]
src/main/java/net/sf/jsqlparser/parser/StatementListener.java
SqlParserRunner (Interface)
(no doc) [5 implementers]
src/test/java/net/sf/jsqlparser/benchmark/SqlParserRunner.java
MergeOperation (Interface)
Marker interface to cover MergeDelete, MergeUpdate and MergeInsert [197 implementers]
src/main/java/net/sf/jsqlparser/statement/merge/MergeOperation.java
Statement (Interface)
(no doc) [238 implementers]
src/main/java/net/sf/jsqlparser/statement/Statement.java
ParenthesedStatement (Interface)
(no doc) [15 implementers]
src/main/java/net/sf/jsqlparser/statement/ParenthesedStatement.java
StatementVisitor (Interface)
(no doc) [36 implementers]
src/main/java/net/sf/jsqlparser/statement/StatementVisitor.java

Core symbols most depended-on inside this repo

append
called by 2034
src/main/java/net/sf/jsqlparser/expression/JsonFunction.java
get
called by 762
src/main/java/net/sf/jsqlparser/statement/Statements.java
accept
called by 443
src/main/java/net/sf/jsqlparser/statement/Statement.java
size
called by 318
src/main/java/net/sf/jsqlparser/statement/piped/FromQuery.java
parse
called by 255
src/main/java/net/sf/jsqlparser/parser/CCJSqlParserUtil.java
add
called by 205
src/main/java/net/sf/jsqlparser/parser/feature/ModifyableFeatureSet.java
getName
called by 171
src/main/java/net/sf/jsqlparser/util/validation/ValidationCapability.java
addAll
called by 159
src/main/java/net/sf/jsqlparser/statement/piped/FromQuery.java

Shape

Method 6,195
Class 610
Enum 67
Interface 34

Languages

Java100%

Modules by API surface

src/test/java/net/sf/jsqlparser/statement/select/SelectTest.java680 symbols
src/main/java/net/sf/jsqlparser/statement/alter/AlterExpression.java171 symbols
src/test/java/net/sf/jsqlparser/statement/alter/AlterTest.java147 symbols
src/main/java/net/sf/jsqlparser/statement/select/PlainSelect.java102 symbols
src/test/java/net/sf/jsqlparser/statement/create/CreateTableTest.java97 symbols
src/main/java/net/sf/jsqlparser/statement/update/Update.java68 symbols
src/test/java/net/sf/jsqlparser/statement/insert/InsertTest.java65 symbols
src/main/java/net/sf/jsqlparser/statement/select/Select.java64 symbols
src/test/java/net/sf/jsqlparser/util/TablesNamesFinderTest.java63 symbols
src/main/java/net/sf/jsqlparser/expression/Function.java63 symbols
src/main/java/net/sf/jsqlparser/expression/AnalyticExpression.java61 symbols
src/main/java/net/sf/jsqlparser/statement/select/Join.java59 symbols

Used by 2 indexed graphs manifest dependencies, hub-wide

Dependencies from manifests, versioned

com.h2database:h2[2.3.232,) · 1×
net.sourceforge.pmd:pmd-core
net.sourceforge.pmd:pmd-java
org.apache.commons:commons-lang33.17.0 · 1×
org.assertj:assertj-core3.25.3 · 1×
org.hamcrest:hamcrest-all1.3 · 1×
org.javacc.generator:java8.1.0-SNAPSHOT · 1×
org.javacc:core8.1.0-SNAPSHOT · 1×
org.junit.jupiter:junit-jupiter5.11.4 · 1×
org.mockito:mockito-core5.15.2 · 1×

For agents

$ claude mcp add JSqlParser \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact