feathers-knex is a database adapter for KnexJS, an SQL query builder for Postgres, MySQL, MariaDB, SQLite3, and Oracle designed to be flexible, portable, and fun to use.
npm install --save mysql knex feathers-knex
ProTip: You also need to install the database driver for the DB you want to use. If you used the Feathers generator then this was already done for you.
You can create a SQL Knex service like this:
const knex = require('knex');
const service = require('feathers-knex');
const db = knex({
client: 'sqlite3',
connection: {
filename: './db.sqlite'
}
});
// Create the schema
db.schema.createTable('messages', table => {
table.increments('id');
table.string('text');
table.boolean('read');
});
app.use('/messages', service({
Model: db,
name: 'messages'
}));
This will create a messages
endpoint and connect to a local messages
table on an SQLite database in data.db
.
The following options can be passed when creating a Knex service:
Model
(required) - The KnexJS database instancename
(required) - The name of the tableid
(default:id
) [optional] - The name of the id property.paginate
[optional] - A pagination object containing adefault
andmax
page size (see the Pagination chapter)
Here's a complete example of a Feathers server with a messages
SQLite service. We are using the Knex schema builder
$ npm install feathers feathers-rest feathers-socketio body-parser feathers-knex knex sqlite3
// app.js
const feathers = require('feathers');
const rest = require('feathers-rest');
const socketio = require('feathers-socketio');
const bodyParser = require('body-parser');
const service = require('feathers-knex');
const knex = require('knex');
const db = knex({
client: 'sqlite3',
connection: {
filename: './db.sqlite'
}
});
// Create a feathers instance.
const app = feathers()
// Enable REST services
.configure(rest())
// Enable Socket.io services
.configure(socketio())
// Turn on JSON parser for REST services
.use(bodyParser.json())
// Turn on URL-encoded parser for REST services
.use(bodyParser.urlencoded({ extended: true }));
// Create Knex Feathers service with a default page size of 2 items
// and a maximum size of 4
app.use('/messages', service({
Model: db,
name: 'messages',
paginate: {
default: 2,
max: 4
}
}));
// Clean up our data. This is optional and is here
// because of our integration tests
db.schema.dropTableIfExists('messages').then(function() {
console.log('Dropped messages table');
// Initialize your table
return db.schema.createTable('messages', function(table) {
console.log('Creating messages table');
table.increments('id');
table.string('text');
table.boolean('complete');
});
}).then(function() {
// Create a dummy Message
app.service('messages').create({
text: 'Server message',
complete: false
}).then(function(message) {
console.log('Created message', message);
});
});
// Start the server.
const port = 3030;
app.listen(port, function() {
console.log(`Feathers server listening on port ${port}`);
});