Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andrglo/pg-cr-layer
A postgres interface layer for common requests
https://github.com/andrglo/pg-cr-layer
Last synced: about 1 month ago
JSON representation
A postgres interface layer for common requests
- Host: GitHub
- URL: https://github.com/andrglo/pg-cr-layer
- Owner: andrglo
- License: mit
- Created: 2015-08-25T20:52:40.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-09-24T17:27:35.000Z (4 months ago)
- Last Synced: 2024-11-17T04:15:24.936Z (about 2 months ago)
- Language: JavaScript
- Size: 537 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
> A postgres interface layer for common requests. It uses [pg](https://github.com/brianc/node-postgres) to connect
and wraps it in a tiny layer using ES2015 promises with the goal to be simpler and compatible with [mssql](https://github.com/patriksimek/node-mssql)
via [mssql-cr-layer](https://github.com/andrglo/mssql-cr-layer)## Install
```sh
$ npm install --save pg-cr-layer
```## Usage
```js
var pgCrLayer = require('pg-cr-layer');var config = {
user: 'me',
password: 'my password',
host: 'localhost',
port: 5432,
pool: {
max: 25,
idleTimeout: 30000
}
};var layer = new PgCrLayer(config)
layer.connect()
.then(function() {
return layer.execute('CREATE TABLE products ( ' +
'product_no integer, ' +
'name varchar(10), ' +
'price numeric(12,2) )');
})
.then(function() {
return layer.transaction(function(t) {
return layer
.execute('INSERT INTO products VALUES (1, \'Cheese\', 9.99)', null, {transaction: t})
.then(function() {
return layer.execute('INSERT INTO products VALUES (2, \'Chicken\', 19.99)', null, {transaction: t})
})
.then(function() {
return layer
.execute('INSERT INTO products VALUES ($1, $2, $3)', [3, 'Duck', 0.99], {transaction: t})
});
})
})
.then(function() {
return layer.query('SELECT * FROM products WHERE product_no=@product_no',
{product_no: {value: 1, type: 'integer'}}) // or just {product_no: 1}
.then(function(recordset) {
console.log(recordset[0]); // => { product_no: 1, name: 'Cheese', price: '9.99' }
})
})
.then(function() {
return layer.close();
})
.catch(function(error) {
console.log(error);
});```
## License
MIT © [Andre Gloria](andrglo.com)
[npm-image]: https://badge.fury.io/js/pg-cr-layer.svg
[npm-url]: https://npmjs.org/package/pg-cr-layer
[travis-image]: https://travis-ci.org/andrglo/pg-cr-layer.svg?branch=master
[travis-url]: https://travis-ci.org/andrglo/pg-cr-layer
[daviddm-image]: https://david-dm.org/andrglo/pg-cr-layer.svg?theme=shields.io
[daviddm-url]: https://david-dm.org/andrglo/pg-cr-layer
[coveralls-image]: https://coveralls.io/repos/andrglo/pg-cr-layer/badge.svg
[coveralls-url]: https://coveralls.io/r/andrglo/pg-cr-layer