简介
为什么使用eggjs自不必言说,前端开发者想搞一下服务器接口啥的,最低学习成本的就是nodejs。加之koa是nodejs的封装库,使得nodejs更加好用。然而在eggjs的约定大于配置的前提下,对koa做了封装,使得上手成本更低,固然选择eggjs来作为写接口的框架。数据库使用sequelize的缘由自不必说了,让多人开发合作更加简单规范!!!
eggjs快速上手
生成项目
快速生成基础项目,提高开发效率,这里推荐使用脚手架快速生成项目。具体命令如下:
1 | mkdir egg-example && cd egg-example |
项目目录介绍
1 | egg-project |
如上,由框架约定的目录:
app/router.js
用于配置 URL 路由规则,具体参见 Router。app/controller/**
用于解析用户的输入,处理后返回相应的结果,具体参见 Controller。app/service/**
用于编写业务逻辑层,可选,建议使用,具体参见 Service。app/middleware/**
用于编写中间件,可选,具体参见 Middleware。app/public/**
用于放置静态资源,可选,具体参见内置插件 egg-static。app/extend/**
用于框架的扩展,可选,具体参见框架扩展。config/config.{env}.js
用于编写配置文件,具体参见配置。config/plugin.js
用于配置需要加载的插件,具体参见插件。test/**
用于单元测试,具体参见单元测试。app.js
和agent.js
用于自定义启动时的初始化工作,可选,具体参见启动自定义。关于agent.js
的作用参见Agent机制。
由内置插件约定的目录:
app/public/**
用于放置静态资源,可选,具体参见内置插件 egg-static。app/schedule/**
用于定时任务,可选,具体参见定时任务。
若需自定义自己的目录规范,参见 Loader API
app/view/**
用于放置模板文件,可选,由模板插件约定,具体参见模板渲染。app/model/**
用于放置领域模型,可选,由领域类相关插件约定,如 egg-sequelize。
由此一个基础项目已经创建完成,详细的eggjs如何使用可自行查看官方文档https://eggjs.org/zh-cn/
eggjs使用sequelize
- 安装并配置 egg-sequelize 插件(它会辅助我们将定义好的 Model 对象加载到 app 和 ctx 上)和 mysql2 模块:
- 安装
1 | npm install --save egg-sequelize mysql2 |
- 在
config/plugin.js
中引入 egg-sequelize 插件
1 | exports.sequelize = { |
- 在
config/config.default.js
中编写 sequelize 配置
1 | config.sequelize = { |
我们可以在不同的环境配置中配置不同的数据源地址,用于区分不同环境使用的数据库,例如我们可以新建一个 config/config.unittest.js
配置文件,写入如下配置,将单测时连接的数据库指向 egg-sequelize-doc-unittest
。
1 | exports.sequelize = { |
完成上面的配置之后,一个使用 sequelize 的项目就初始化完成了。egg-sequelize 和 sequelize 还支持更多的配置项,可以在他们的文档中找到。
- sequelize 提供了 sequelize-cli 工具来管理,我们也可以在 egg 项目中引入 sequelize-cli。
- 安装 sequelize-cli
1 | npm install --save-dev sequelize-cli |
在 egg 项目中,我们希望将所有数据库 Migrations 相关的内容都放在 database
目录下,所以我们在项目根目录下新建一个 .sequelizerc
配置文件:
1 | 'use strict'; |
然后查看下sequelize-cli的所有命令
1 | sequelize <命令> |
接下来就简单介绍下使用方式
使用命令操作数据库
- 初始化数据库相关
1 | npx sequelize init |
这将创建以下文件夹:
- config, 包含配置文件,它告诉CLI如何连接数据库
- models,包含您的项目的所有模型
- migrations, 包含所有迁移文件
- seeders, 包含所有种子文件
在建立模型之前,应先修改database/config.json,以告诉 CLI 如何连接到数据库。database/config.json内容如下:
1 | { |
- 使用如下命令创建数据库:
1 | npx sequelize db:create |
- 使用如下命令删除数据库:
1 | npx sequelize db:drop |
创建模型
我们将使用 model:generate 命令。 此命令需要两个选项:
- name, 模型的名称
- attributes, 模型的属性列表
创建一个名叫 User 的模型:
1 | npx sequelize model:generate --name User --attributes firstName:string,lastName:string,email:string |
这将创建一下文件:
- 在 models 文件夹中创建了一个 user 模型文件
- 在 migrations 文件夹中创建了一个名字像 XXXXXXXXXXXXXX-create-user.js 的迁移文件
注意: _Sequelize 将只使用模型文件,它是表描述。另一边,迁移文件是该模型的更改,或更具体的是说 CLI 所使用的表。 处理迁移,如提交或日志,以进行数据库的某些更改。
这里感觉这样用命令创建模型有点繁琐,主要是如果字段太多,命令行岂不是要写很多,我的理解是这样的不知道有其他好的方法不,初次使用这个。
我是先创建migrations文件,然后在手动创建模型文件。具体如下
1 | npx sequelize migration:generate --name=init-users |
执行完后会在 database/migrations
目录下生成一个 migration 文件(${timestamp}-init-users.js
),我们修改它来处理初始化 users
表:
1 | 'use strict'; |
执行 migrate 进行数据库变更
1 | # 升级数据库 |
执行之后,我们的数据库初始化就完成了。
现在终于可以开始编写代码实现业务逻辑了,首先我们来在 app/model/
目录下编写 user 这个 Model:
1 | 'use strict'; |
然后就可以结合eggjs的模式来进行数据库的处理了。
说下可以使用的cli命令
1 | npx sequelize db:migrate:status // 看一下当前状态 |
撤销迁移
db:migrate:undo - 撤销上一次的迁移操作
db:migrate:undo:all - 撤销所有的迁移操作
db:migrate:undo –name 具体迁移脚本
我们现在要添加一个字段 lastname,新建一个迁移文件
1 | npx sequelize migration:create --name addLastname |
queryInterface文档: https://sequelize.org/master/class/lib/dialects/abstract/query-interface.js~QueryInterface.html
种子文件
种子文件
迁移文件是用来构建数据库以及表结构的,种子文件是用来构建数据的
seed:generate –name demo-user (自定义的名字)
种子文件脚本与迁移脚本类似,由up于down函数组成,传入的参数也是一致的
先生成种子文件 name 后边接的是自定义的名字
1 | npx sequelize seed:generate --name userseed |
会在database/seeders下创建一个种子文件以userseed结尾,然后手动修改这个文件添加点测试数据
1 | module.exports = { |
执行种子
db:seed 指定种子文件 运行指定种子文件
db:seed:all 运行所有种子文件
1 | npx sequelize db:seed:all |
然后查看数据库,添加上了一条数据
撤销种子执行
db:seed:undo –seed 指定种子文件 撤销指定种子文件
db:seed:undo:all 撤销所有种子文件
1 | npx sequelize db:seed:undo:all |
具体使用请查看官方文档