| Crates.io | arborium-sql |
| lib.rs | arborium-sql |
| version | 2.12.4 |
| created_at | 2025-12-04 22:22:06.509833+00 |
| updated_at | 2026-01-18 11:10:11.190966+00 |
| description | SQL grammar for arborium (tree-sitter bindings) |
| homepage | https://github.com/bearcove/arborium |
| repository | https://github.com/bearcove/arborium |
| max_upload_size | |
| id | 1967207 |
| size | 39,881,658 |
SQL grammar for tree-sitter.
Structured Query Language for relational databases; standardized by ANSI/ISO, see ISO/IEC 9075 (paywalled) and SQLite documentation as an open reference.
| Inventor | Donald D. Chamberlin and Raymond F. Boyce |
| Year | 1974 |
use arborium_sql::language;
use tree_sitter_patched_arborium::Parser;
let mut parser = Parser::new();
parser.set_language(&language()).expect("Error loading sql grammar");
let source_code = "/* your sql code here */";
let tree = parser.parse(source_code, None).unwrap();
println!("{}", tree.root_node().to_sexp());
For most use cases, prefer the main arborium crate:
[dependencies]
arborium = { version = "*", features = ["sql"] }
Or use this crate directly:
[dependencies]
arborium-sql = "*"
This crate is part of Arborium, a collection of tree-sitter grammars packaged as Rust crates, maintained by Amos Wenger.
This crate packages a parser.c file generated by the tree-sitter CLI. It exports a language() function returning the tree-sitter Language for sql.
Why separate crates? Tree-sitter parsers can be large (some exceed 1MB of generated C). Splitting languages into separate crates means you only compile what you need, and parallel/incremental builds are more effective.
cc cratewasm32-unknown-unknown (with custom sysroot)| Repository | DerekStride/tree-sitter-sql |
| Commit | fe77f6868d6cdea593052a6af390116495093dc1 |
| License | MIT |
To regenerate after upstream updates:
cargo xtask gen --name sql
Found a grammar bug? Please report it to the upstream repository.
This crate uses unsafe for FFI bindings to the tree-sitter C library. The unsafe surface is minimal and limited to what tree-sitter requires. The generated parser code is produced by tree-sitter's own code generator.
Crate versions track Arborium releases, not upstream grammar versions. The upstream commit is recorded above. A major version bump occurs when grammar changes affect node names or structure (breaking for query consumers).
parser.c): MIT (from upstream grammar)