1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
use sqlparser::parser::ParserError;
use sqlparser::{ast::Statement, dialect::PostgreSqlDialect, parser::Parser};

const DIALECT: PostgreSqlDialect = PostgreSqlDialect {};

/// Parse a string to a collection of statements.
///
/// # Example
/// ```rust
/// use kip_sql::parser::parse_sql;
/// let sql = "SELECT a, b, 123, myfunc(b) \
///            FROM table_1 \
///            WHERE a > b AND b < 100 \
///            ORDER BY a DESC, b";
/// let ast = parse_sql(sql).unwrap();
/// println!("{:?}", ast);
/// ```
pub fn parse_sql<S: AsRef<str>>(sql: S) -> Result<Vec<Statement>, ParserError> {
    Parser::parse_sql(&DIALECT, sql.as_ref())
}