sequelize的实例化/Model的定义、使用

在使用sequelize操作MySQL需要先做两件准备工作:
sequelize对象实例化

/*
 * Sequelize实例化
 * 
 * @Author: Junkai Chen 
 * @Date: 2017-10-30 19:11:39 
 * @Last Modified by: Junkai Chen
 * @Last Modified time: 2017-11-13 16:10:15
 */

const Sequelize = require('sequelize');
const config = require('../config/db');

// 创建sequelize实例
const sequelize = new Sequelize(config.database, config.user, config.password, Object.assign(config.options, {
  dialect: 'mysql',
  pool: {
    max: 5,
    min: 0,
    idle: 10000
  }
}));

module.exports = sequelize;

定义模型
主要是告诉sequelize如何映射数据库表:

/*
 * @Author: Junkai Chen
 * @Date: 2017-11-13 15:06:40
 * @Last Modified by: Gping
 * @Last Modified time: 2017-11-15 16:26:49
 */

const Sequelize = require('sequelize');
const db = require('../db');

const Repository = db.define('repository', {
  id: {
    type: Sequelize.INTEGER,
    autoIncrement: true,
    allowNull: false
  },
  repository_id: {
    field: 'repo_id',
    type: Sequelize.STRING,
    unique: true,
    allowNull: false,
    primaryKey: true,
  },
  document_name: {
    field: 'doc_name',
    type: Sequelize.STRING,
    allowNull: false
  },
  description: {
    type: Sequelize.STRING
  },
  repository_name: {
    field: 'repo_name',
    type: Sequelize.STRING,
    allowNull: false
  },
  repository_url: {
    field: 'repo_url',
    type: Sequelize.STRING,
    allowNull: false
  },
  delete_flag: {
    type: Sequelize.INTEGER
  },
  index_filename: {
    type: Sequelize.STRING
  },
  summary_filename: {
    type: Sequelize.STRING
  },
  is_downloaded: {
    type: Sequelize.INTEGER,
    allowNull:false,
    defaultValue: 0
  },
  create_time: {
    type: Sequelize.TIME
  },
  update_time: {
    type: Sequelize.TIME
  }
}, {
  createdAt: 'create_time',
  updatedAt: 'update_time',
  tableName: 'document_repo'
});

module.exports = Repository;

sequelize.define(modelName, attributes, [options]) -> Modal
这个实例方法用于定义一个新的model(模型)。model相当于数据库中的表,该对象不能通过构造函数实例化,而只能通过sequelize.define()或者sequelize.import()方法创建

第二个参数是指定列名和数据类型,如果是主键,需要更加详细的指定。第三个参数是额外的配置

接下来我们就可以往数据库中塞数据了

下面介绍几个常用的方法
create()——创建保存新实例
create(values, [options]) -> Promise.
构建一个新的模型实例,并进行保存。与build()方法不同的是,此方法除了创建新实例外,还会将其保存到对应的数据库表中。

sequelize的实例化/Model的定义、使用_第1张图片
参数

更新数据——save()方法
可以对查询到的实例调用save()方法

(async () => {
    var p = await queryFromSomewhere();
    p.gender = true;
    p.updatedAt = Date.now();
    p.version ++;
    await p.save();
})();

destroy()——删除记录
destroy(options) -> Promise.
删除多个实例,或设置deletedAt的时间为当前时间(当启用paranoid时候)
执行成功后返回被删除的行数

sequelize的实例化/Model的定义、使用_第2张图片
destroy

findAll()——查询多条数据
findAll([options]) -> Promise.>
查询多个实例(多条数据)
下面是例子:

Model.findAll({
  where: {
    attr1: 42,
    attr2: 'cake'
  }
})
// WHERE attr1 = 42 AND attr2 = 'cake'

在查询中使用大于、小于等

Model.findAll({
  where: {
    attr1: {
      $gt: 50
    },
    attr2: {
      $lte: 45
    },
    attr3: {
      $in: [1,2,3]
    },
    attr4: {
      $ne: 5
    }
  }
})
// WHERE attr1 > 50 AND attr2 <= 45 AND attr3 IN (1,2,3) AND attr4 != 5

findOne()——通过单条数据
findById(id, [options]) -> Promise.
查询单条实例(单条数据)。

sequelize的实例化/Model的定义、使用_第3张图片
参数

你可能感兴趣的:(sequelize的实例化/Model的定义、使用)