Egg学习_Setp1_初始化项目添加数据库

前言

本系列文章是Egg学习过程的一个记录,初步目标是写一个个人博客,会尽可能多使用Egg中提供的各种功能.
本文全部使用 async 请确保Node版本足够支持.
文中有不正确地方请指正.
GitHub地址: https://github.com/devil5263/...
Egg文档: https://eggjs.org/zh-cn/intro/

初始化项目

使用Egg脚手架初始化项目

$ npm instal egg-init -g
$ egg-init egg-example --type=simple // 选择初始化项目的类型
$ cd egg-example
$ npm install

项目目录结构

egg-project
├── package.json
├── app.js //自定义启动时的初始化工作
├── app
|   ├── router.js // 配置 URL 路由规则
│   ├── controller // 控制层
│   |   └── auth.js // 业务逻辑-注册登录实现
│   ├── service // 业务逻辑层
│   |   └── auth.js // 业务逻辑-注册登录实现
|   ├── model // 数据库表结构
│   |   └── user.js // 业务逻辑-user表
│   ├── middleware // 中间件
│   ├── schedule // 任务
│   └── extend // 框架的扩展
├── config // 初始化-所有配置文件
|   ├── plugin.js
|   ├── config.default.js
│   ├── config.prod.js
|   ├── config.test.js (可选)
|   ├── config.local.js (可选)
|   └── config.unittest.js (可选)
├── build // 前端webpack打包配置
|   ├── webpack.base.js
|   ├── webpack.dev.js
|   └── webpack.prod.js
├── resource// 前端源文件
|   ├── assets // 前端资源
|   ├── components // 前端组件
│   └── pages // 前端页面
|       └── page1 // 某一页面
|           ├── app.vue // vue单文件组件
|           ├── index.js // vue入口文件
|           ├── index.html // html页面
|           └── js (可选) // store/router js文件
└── test // 初始化-单元测试用例
    ├── middleware
    |   └── response_time.test.js
    └── controller
        └── home.test.js

MySQL配置

这里使用了两个Egg的插件

  • egg-mysql 用于连接MySQL(需要npm install egg-mysql)
  • egg-sequelize 用于定义model进行db层操作(需要安装egg-sequelizemysql2两个库)

数据库配置

// {work_dir}/config/config.default.js
const database = "egg"; // 数据库名字
module.exports = appInfo => {
  const config = {};
  config.keys = appInfo.name + "_1501817502166_7037";

  config.sequelize = { // egg-sequelize 配置
    dialect: "mysql", // db type
    database: database,
    host: "localhost",
    port: "3306",
    username: "root",
    password: ""
  };

  return config;
};

插件配置

// {work_dir}/config/plugin.js
exports.sequelize = {
    enable: true,
    package: "egg-sequelize"
};

启动时创建数据库表

// {work_dir}/app.js
module.exports = app => {
    app.beforeStart(async function () {
        await app.model.sync({ force: true });
    });
};

定义model

// {work_dir}/app/model/user.js
module.exports = app => {
  const { STRING, INTEGER, DATE } = app.Sequelize;

  const User = app.model.define("user", {
    login: STRING,
    id: {
      type: INTEGER,
      primaryKey: true,
      autoIncrement: true
    },
    name: STRING(30),
    password: STRING(32),
    age: INTEGER,
    last_sign_in_at: DATE,
    created_at: DATE,
    updated_at: DATE
  });

  return User;
};

目前为止,egg-example项目已初始化并添加了MySQL配置,成功启动后会发现数据库中已经有了定义的 model User

你可能感兴趣的:(node.js,javascript,后端开发)