caching sequelize result using redis
https://www.npmjs.com/package/sequelize-use-cache
npm install --save redis # prerequisite
npm install --save sequelize-use-cache
All select queries
model.findOne({
// ...options,
cache: true, // use cache or not, boolean
expire: 10, // expire time(seconds), integer
})
import Sequelize from 'sequelize'
import Redis from 'redis'
import useCache from 'sequelize-use-cache'
const redis = Redis.createClient()
const sequelize = new Sequelize()
// import models
sequelize.define('projects', {
title: Sequelize.TEXT,
description: Sequelize.TEXT,
})
useCache(sequelize, redis)
const { projects } = sequelize.models
projects.findAll({
cache: true,
expire: 5,
})
console.log(sequelize.cacheHit) // false
projects.findAll({
cache: true,
expire: 5,
})
console.log(sequelize.cacheHit) // true
MIT