https://github.com/xp-forge/sql-parser
SQL Parser
https://github.com/xp-forge/sql-parser
Last synced: about 1 year ago
JSON representation
SQL Parser
- Host: GitHub
- URL: https://github.com/xp-forge/sql-parser
- Owner: xp-forge
- Created: 2020-11-06T18:52:59.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-03-24T13:26:20.000Z (over 2 years ago)
- Last Synced: 2025-03-12T23:02:12.628Z (over 1 year ago)
- Language: PHP
- Size: 65.4 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: ChangeLog.md
Awesome Lists containing this project
README
SQL Parser
==========
[](https://github.com/xp-forge/sql-parser/actions)
[](https://github.com/xp-framework/core)
[](https://github.com/xp-framework/core/blob/master/LICENCE.md)
[](http://php.net/)
[](http://php.net/)
[](https://packagist.org/packages/xp-forge/sql-parser)
This library parses SQL statements.
Examples
--------
```php
use text\sql\{Parser, SyntaxError};
$p= new Parser();
try {
$statement= $p->parse('select * from user where user_id = 1');
} catch (SyntaxError $e) {
// Handle
}
// new Select(
// [new All()],
// [new Table('user')],
// new Comparison(new Field(null, 'uid'), '=', new Number(1))
// )
```
Support
-------
This library is not yet complete. Currently, the following are supported:
* USE database selection
* SELECT, INSERT, UPDATE and DELETE statements
* CREATE / DROP TABLE schema modification
* ALTER TABLE ADD / DROP COLUMN table modification
Other statements may be added via `extend()`:
```php
use text\sql\Parser;
$p= new Parser();
// Incomplete implementation of https://dev.mysql.com/doc/refman/8.0/en/show.html
$p->extend('show', function($parse, $token) {
return ['show' => $parse->match([
'events' => function($parse, $token) { return 'events'; },
'variables' => function($parse, $token) {
if ('like' === $parse->token->symbol->id) {
$parse->forward();
return ['variables' => $parse->expression()];
} else {
return ['variables' => null];
}
}
])];
});
$statement= $p->parse('show variables like "sql_mode"');
// ['show' => ['variables' => new Text('sql_mode')]]
```