ORM库 Sequelize 简单使用小结


title: ORM库 Sequelize 简单使用小结
date: 2019-01-21 22:12:50
tags: [Node.JS]
categories: Node.JS


什么是 ORM 库

先说一下数据库,比如 MySQL 就是。我们可以使用现成的 MySQL 模块来操作数据库,但需要写 SQL 语句来操作数据库,比较麻烦。
所以就有人封装了 ORM 库,就像一个隔离层一样,我们只需要调用某个语法比如 Note.create()它的底层就会自动生成对应的 SQL 语句
Sequelize 就是一个 ORM 库
另外,像 MongoDBMongoose 也是类似的关系。

安装并引入

安装

$ npm install --save sequelize
// 此处也可选择安装mysql或其他,本文以sqlite为例
$ npm install --save sqlite3

引入

const Sequelize = require('sequelize')
const path = require('path')

建立数据库

const sequelize = new Sequelize('database', 'username', 'password', {  // 这三个参数也可填 undefined
  host: 'localhost',    // 数据库地址
  dialect: 'sqlite',    // 数据库类型

  pool: {
    max: 5,             // 连接池最大连接数量
    min: 0,             // 连接池最小连接数量
    acquire: 30000,     // 在抛出错误前尝试连接的最大时间为30秒
    idle: 10000         // 如果一个线程超过10秒钟没有被使用过就释放该线程
  },

  // 只有用 SQLite 时要配置此项
  storage: path.join(__dirname, '../database/database.sqlite')  // 假如该目录下没有该文件,会自动创建
});

测试连接

sequelize
  .authenticate()
  .then(() => {
    console.log('Connection has been established successfully.');
  })
  .catch(err => {
    console.error('Unable to connect to the database:', err);
  });

运行该文件node test.js,连接成功则会 log 成功。

创建 Model

// 创建 Model
const Note = sequelize.define('note', {  // 表名为 note
  text: {    // 字段名
    type: Sequelize.STRING    // 字段类型
  }
})

// 创建或同步表
// User.sync() 会返回一个 Promise 对象
// force = true 时会把存在的表先 drop 掉再创建
Note.sync({force: true})

// 现在就可以增删改查了

增删改查

// 增
Note.create({
    text: 'hello'
})

// 查
Note.findAll({raw: true, where: {id: 1}}).then(notes => {
    console.log(notes)
})

小结

至此,一个基本的数据库就完成了。更多用法还是得参考 Sequelize 的官方文档

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 32,090评论 2 89
  • 原文地址 本文简单的介绍了数据库,以及如何在 Node/Express 中应用他们。之后展示如何使用Mongoos...
    前端幼儿班阅读 5,216评论 1 5
  • 一. Java基础部分.................................................
    wy_sure阅读 3,867评论 0 11
  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,870评论 0 44
  • 我的心里住着个幼稚鬼 感受不到太多伤悲 你泪眼朦胧的美 却轻易将我击溃 该怎么安慰 从你脸颊滑下一颗泪 就在我心里...
    何望天阅读 280评论 1 12