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.<Instance>
构建一个新的模型实例,并进行保存。与build()方法不同的是,此方法除了创建新实例外,还会将其保存到对应的数据库表中。

参数

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

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

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

destroy

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

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.<Instance>
查询单条实例(单条数据)。

参数

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352

推荐阅读更多精彩内容