博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php sequelize,egg.js整合数据库ORM框架Sequelize
阅读量:1531 次
发布时间:2019-04-21

本文共 3470 字,大约阅读时间需要 11 分钟。

在上篇文章中我们写了egg.js怎么连接mysql数据库, 而在一些较为复杂的应用中,我们可能会需要一个 ORM 框架来帮助我们管理数据层的代码。Java中有Mybatis、Hibernate、Spring Data Jpa, 在Php中Thinkphp框架也集成ORM框架功能, 而在 Node.js 中,sequelize 是一个我们广泛使用的 ORM 框架,它支持 MySQL、PostgreSQL、SQLite 和 MSSQL 等多个数据源

安装

cnpm i -S egg-sequelize mysql2

开启sequelize插件

config/plugin.js

module.exports = {

sequelize: {

enable: true,

package: 'egg-sequelize',

}

};

配置sequelize

我们这里连接mysql数据库

/* eslint valid-jsdoc: "off" */

'use strict';

/**

* @param {Egg.EggAppInfo} appInfo app info

*/

module.exports = appInfo => {

/**

* built-in config

* @type {Egg.EggAppConfig}

**/

const config = exports = {

// sequelize配置

sequelize: {

dialect: 'mysql',

host: 'ip地址',

port: 3306,

database: 'test',

username: 'root',

password: '123456'

}

};

// use for cookie sign key, should change to your own and keep security

config.keys = appInfo.name + '_1565058424941_6691';

// add your middleware config here

config.middleware = [];

// add your user config here

const userConfig = {

// myAppName: 'egg',

};

return {

...config,

...userConfig,

};

};

数据库迁移(Migrations)

在实际开发中, 大部分情况下是多人协作的, 在项目的演进过程中, 每一次迭代都可能对数据库结构做变更, 怎么解决这个问题? 这时候我们就需要Migrations来帮我们管理数据结构的变更了

sequelize提供了sequelize-cli工具来实现Migrations

先安装sequelize-cli

cnpm i --save-dev sequelize-cli

在根目录创建.sequelizerc文件

'use strict';

const path = require('path');

module.exports = {

config: path.join(__dirname, 'database/config.json'),

'migrations-path': path.join(__dirname, 'database/migrations'),

'seeders-path': path.join(__dirname, 'database/seeders'),

'models-path': path.join(__dirname, 'app/model'),

};

初始化 Migrations 配置文件和目录

// 执行下面两条命令, 会根据根目录下我们刚才创建的.sequelizerc生成Migrations 配置文件和目录

npx sequelize init:config

npx sequelize init:migrations

执行完上面两条命令, 根目录多了个database文件夹

database

├── migrations

└── config.json

到这里, sequelize-cli和相关配置都初始化好了

创建表

在 Migration 文件来创建我们的表users

执行下面的命令

npx sequelize migration:generate --name=init-users

执行完后会在 database/migrations 目录下生成一个 migration 文件(${timestamp}-init-users.js),我们修改它来处理初始化 users 表

我这里生成的是20190806050532-init-users.js, 修改该文件内容

'use strict';

module.exports = {

// 在执行数据库升级时调用的函数,创建 users 表

up: async (queryInterface, Sequelize) => {

const { INTEGER, DATE, STRING } = Sequelize;

await queryInterface.createTable('users', {

id: { type: INTEGER, primaryKey: true, autoIncrement: true },

name: STRING(30),

age: INTEGER,

created_at: DATE,

updated_at: DATE,

});

},

// 在执行数据库降级时调用的函数,删除 users 表

down: async queryInterface => {

await queryInterface.dropTable('users');

},

};

执行 migrate 进行数据库变更

# 升级数据库

npx sequelize db:migrate

# 如果有问题需要回滚,可以通过 `db:migrate:undo` 回退一个变更

# npx sequelize db:migrate:undo

# 可以通过 `db:migrate:undo:all` 回退到初始状态

# npx sequelize db:migrate:undo:all

执行npx sequelize db:migrate之后, 我们现在去查看数据库多两张表SequelizeMeta和users

接下来我们就可以编写代码进行数据库操作了

创建app/model/user.js

'use strict';

module.exports = app => {

const { STRING, INTEGER, DATE } = app.Sequelize;

const User = app.model.define('users', {

id: { type: INTEGER, primaryKey: true, autoIncrement: true },

name: STRING(30),

age: INTEGER,

created_at: DATE,

updated_at: DATE,

});

return User;

};

这里创建的Model模型可以在Controller和Service中通过app.model.User或ctx.model.User访问

我们创建一个app/controller/user.js

const Controller = require('egg').Controller;

class UserController extends Controller {

async index() {

// 查询所有用户信息

ctx.body = await this.ctx.model.User.findAll();

}

}

module.exports = UserController;

最后一步配置路由

app/router.js

module.exports = app => {

const { router, controller } = app;

router.get('/user', controller.user.index);

};

测试

转载地址:http://irkdy.baihongyu.com/

你可能感兴趣的文章
【转】SAP地产业正青春
查看>>
根据指定行数拆分内表
查看>>
根据长文本拆分至内表
查看>>
隐藏标准选择界面按钮
查看>>
【转】排除被冲销的物料凭证
查看>>
防止程序重复执行
查看>>
使用程序创建数据库表
查看>>
备份表到存在的表或者自动新建表
查看>>
Win系统自定义屏保教程
查看>>
[性能] SAP销售订单取数逻辑优化---索引表
查看>>
BADI EXIT等增强报W警告类消息
查看>>
SAP 凭证冲销可以使用BAPI_ACC_DOCUMENT_REV_POST或者BDC录制FB08来做
查看>>
Informatica 初学日记全
查看>>
几种 ETL 工具的比较(Kettle,Talend,Informatica 等)
查看>>
ETL工具大全
查看>>
ETL安装前的准备 - 数据库创建方法
查看>>
ora-12528 : message 12528 not found; product=RDBMS ; facility=ora
查看>>
Dialog中Screen logic的处理逻辑原则
查看>>
【推荐】SAP关闭正在执行的缓慢的程序
查看>>
优化定制化abap代码必须遵守的经典黄金规则
查看>>