16.0.0 • Published 2 years ago

@fkaempfer/libpg-query v16.0.0

Weekly downloads
-
License
LICENSE IN LICENS...
Repository
github
Last release
2 years ago

libpg-query

The real PostgreSQL parser, exposed for nodejs.

Primarily used for the node.js parser and deparser pgsql-parser

Fork

This is a fork I created while waiting for v16 to be released.

Building a binary distribution

  • Install requirements (npm i)
  • npx node-pre-gyp rebuild package
  • With appropriate AWS credentials configured, npx node-pre-gyp publish

Or you can run the scripts

npm run binary:build
npm run binary:publish

Installation

npm install libpg-query

Documentation

query.parseQuery(sql)/parseQuerySync

Parses the sql and returns a Promise for the parse tree (or returns the parse tree directly in the sync version). May reject with/throw a parse error.

The return value is an array, as multiple queries may be provided in a single string (semicolon-delimited, as Postgres expects).

query.parsePlPgSQL(funcsSql)/query.parsePlPgSQLSync(funcsSql)

Parses the contents of a PL/PGSql function, from a CREATE FUNCTION declaration, and returns a Promise for the parse tree (or returns the parse tree directly in the sync version). May reject with/throw a parse error.

Example

const parser = require('libpg-query');
parser.parseQuery('select 1').then(console.log);

Versions

Our latest is built with 15-latest branch from libpg_query

PostgreSQL Major Versionlibpg_queryStatusnpm
1515-latestSupportedlatest
1414-latestSupportedlibpg-query@14.0.0
1313-latestSupportedlibpg-query@13.3.1
12(n/a)Not supported
11(n/a)Not supported
1010-latestNot supported@1.3.1 (tree)

Related

Credit

This is based on the output of libpg_query. This wraps the static library output and links it into a node module for use in js.

All credit for the hard problems goes to Lukas Fittl.

Additional thanks for node binding Ethan Resnick.

Original Code and License