Skip to content

Bookshelf plugin for adding returning clause to insert/update queries

License

Notifications You must be signed in to change notification settings

joshswan/bookshelf-returning

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bookshelf-returning

NPM Version Build Status Dependency Status Dev Dependency Status

Bookshelf plugin for PostgreSQL, MSSQL, and Oracle databases that allows for specifying a "returning" clause for insert and update queries. The model is updated with the updated values of the columns specified, giving you an updated representation of your model without needing a subsequent fetch. Delete queries are also supported for returning the state of the model being deleted without requiring it to be fetched first.

Installation

npm install bookshelf-returning --save

Usage

Apply the plugin:

const returning = require('bookshelf-returning');

bookshelf.plugin(returning);

And use returning in your save options:

const User = bookshelf.Model.extend({
  tableName: 'users',
});

User.forge({ id: 1 }).save({ first_name: 'Josh' }, { returning: '*' })
  .then((updated) => {
    console.log(updated.get('first_name')); // Josh
  });