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 的官方文档。

你可能感兴趣的:(ORM库 Sequelize 简单使用小结)