php sequelize,egg.js整合数据库ORM框架Sequelize
在上篇文章中我们写了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);
};
测试
php sequelize,egg.js整合数据库ORM框架Sequelize相关推荐
- Node.js ORM 框架 Sequelize 重要更新 v5 发布
Node.js ORM 框架 Sequelize v5 已正式发布,这也是 v4 推出一年多后的主要版本. Sequelize 是一个基于 promise 的 Node.js ORM,目前支持 Pos ...
- Node.js ORM框架-sequelize
Node.js ORM框架-sequelize 什么是ORM 什么是"持久化" 什么是持久层 ORM技术特点 什么是Sequelize Sequelize特点 使用方式 安装库 配 ...
- Nodejs ORM框架Sequelize
Nodejs ORM框架Sequelize (模型,关联表,事务,循环,及常见问题) 建立连接 const Sequelize = require('sequelize'); const sequel ...
- nestjs 优秀的ORM框架sequelize操作数据库
奉上最新代码: nestjs服务demo代码=>gitee地址.github地址 nodejs的ORM–sequelize 笔者在使用koa2开发后端服务的时候用的ORM框架是sequelize ...
- 专访死马:为什么说Egg.js是企业级Node框架
在 7 月 6 日的 ArchSummit 架构师峰会深圳站上,Egg.js 的主要开发者不四(网名死马)将给参会者带来<企业级 Node.js Web 框架研发与落地>的分享,借此机会, ...
- js mysql orm_nodejs ORM框架对比
name star sequelize 19.9k knex 10.5k Bookshelf 5.7k 以上数据截止2019.9.18 sequelize 文档齐全,Star最多. 支持数据库:pos ...
- mysql django构架图_Django框架之数据库ORM框架
首先,我来介绍一下什么是ORM框架: O是object,也就类对象的意思,R是relation,翻译成中文是关系,也就是关系数据库中数据表的意思,M是mapping,是映射的意思.在ORM框架中,它帮 ...
- java中轻量级数据库ORM框架:JOOQ
1.使用maven下载 <!-- https://mvnrepository.com/artifact/org.jooq/jooq --><dependency><gro ...
- koa+ts+mysql后台开发——(五)使用orm框架sequelize操作数据库,自定义格式校验、统一处理返回信息、分页格式
文章目录 前言 一.引包 二.初始化sequelize 三.添加模型层 四.添加服务层 五.添加控制层 (增删改查) 六.自定义数据校验 七.统一处理返回信息 八.统一处理分页格式 九.在路由中引入导 ...
最新文章
- 【error】error: field * has incomplete type
- 深度学习的多个loss如何平衡?
- 【WebGL】WebGL入门
- 8、python基础知识-用户输入
- 文件操作-读取文件后文件指针会发生变化
- Google和IMAX放弃VR相机
- 1-2:网络初识之了解OSI和TCP/IP及网络分层(物理层,数据链路层,网路层,传输层,应用层)
- Android中的USB中的UsbAccessory和UsbDevice的区别
- 屏幕居中(DIV/CSS) 的几种方法
- Vue——组件化开发
- 什么是可靠性测试,常见的可靠性测试标准有哪些?
- 计算机系统文件命名规则,Windows10系统怎样自定义副本文件默认命名规则
- 脾气与冲突--试用ymlf下wine跑windows程序有感
- java tic tac toe_Tic Tac Toe java
- 金龙云介绍——城轨云相关
- 个人对AutoResetEvent和ManualResetEvent的理解
- 顿号、分号;这些标点符号的用法
- 七周成为数据分析师01-数据分析思维
- 用Python实现URL Encoding和Decoding
- SQL 获取 weekday