xp-forge/sql-parser
Composer 安装命令:
composer require xp-forge/sql-parser
包简介
SQL Parser
README 文档
README
This library parses SQL statements.
Examples
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():
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')]]
统计信息
- 总下载量: 4
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: BSD-3-Clause
- 更新时间: 2020-11-07

