eggjs连接MySQL数据库

 前言:eggjs连接MySQL数据库,我摸索了各种方式。下面这篇文章能正确链上。

 


增删查改SQL语法如下:

'use strict';
const Controller = require('egg').Controller;
​
class UserController extends Controller {
  async userList() {
      // 1.增加数据
      let addData = { username: "userName", password: "password",sort:1 }
      let addRes = await this.app.mysql.insert(
       "user", addData
      );
      // 2.查询单条数据 
      let userData = await this.app.mysql.get(
       'user', { id: 1 }
      );
      // 3.查询多条数据,正序
      let userDataAll = await this.app.mysql.select(
       'user', { orders: [['sort', 'asc']] }
      );
      // 4.修改
      let updRes = await this.app.mysql.update('user',{ id:1, username:'test' });
      // 5.删除
      let delRes= await this.app.mysql.delete('user',{ id:1 });
  }
module.exports = UserController;

 

 更多代码:

https://blog.csdn.net/kaimo313/article/details/121905734

 

 

 

我犯过的几个错误:

1,config/plugin.js中我填写错误,这是最致命的,导致直接读不到MySQL。官方文档不靠谱,如下所示

// config/plugin.js
exports.mysql = {
    enable: true,
    package: 'egg-mysql',
};

其实不应该这么写,而是

module.exports = {
// had enabled by egg
// static: {
// enable: true,
// }
mysql: {
enable: true,
package: 'egg-mysql',
}
};

2,config/config.default.js中配置MySQL的格式。官方文档不靠谱,写法古怪。

// config/config.${env}.js
exports.mysql = {
  // 单数据库信息配置
  client: {
    // host
    host: 'mysql.com',
    // 端口号
    port: '3306',
    // 用户名
    user: 'test_user',
    // 密码
    password: 'test_password',
    // 数据库名
    database: 'test',
  },
  // 是否加载到 app 上,默认开启
  app: true,
  // 是否加载到 agent 上,默认关闭
  agent: false,
};

应该:

const config = exports = {
    mysql: {
      // 单数据库信息配置
      client: {
        // host
        host: 'localhost',
        // 端口号
        port: '3306',
        // 用户名
        user: 'root',
        // 密码
        password: 'web3devops',
        // 数据库名
        database: 'Contracts',
      },
      // 是否加载到 app 上,默认开启
      app: true,
      // 是否加载到 agent 上,默认关闭
      agent: false,
    },
  };

 

3,同时添加config/config.default.js和config/config.local.js也不行。官方文档不靠谱,说在 config/config.${env}.js 中添加。

 

 

 

 

以下是正文:

 

创建项目之后, 我们就开始配置怎么通过egg-mysql连接并操作mysql数据库啦

安装egg-mysql插件
cnpm i -S egg-mysql
开启插件

config/plugin.js

module.exports = {
  mysql: {
    enable: true,
    package: 'egg-mysql'
  }
};
配置数据库连接信息

可以配置单数据源也可以配置多数据源, 下面我们这里只讲配置但数据源
在/config/config.default.js中增加数据库配置

'use strict';

/**
 * @param {Egg.EggAppInfo} appInfo app info
 */
module.exports = appInfo => {
  /**
   * built-in config
   * @type {Egg.EggAppConfig}
   **/
  const config = exports = {
    // 数据库配置
    mysql: {
      // 单数据库信息配置
      client: {
        // host
        host: 'ip地址',
        // 端口号
        port: '3306',
        // 用户名
        user: 'root',
        // 密码
        password: '123456',
        // 数据库名
        database: 'test',
      },
      // 是否加载到 app 上,默认开启
      app: true,
      // 是否加载到 agent 上,默认关闭
      agent: false,
    }
  };

  // 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,
  };
};
编写Service层代码

这这里我们通过刚才配置的mysql直接和数据库交互
app/service/user.js

'use strict';

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

class UserService extends Service {
  async getUserById(id) {
    // 根据id查询用户信息
    return await this.app.mysql.get('users', {id: id});
  }
}
module.exports = UserService;

编写Controller层代码

在这里, 我们调用Service层的代码间接和数据库交互
app/controller/user.js

'use strict';

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

class UserController extends Controller {
  async index() {
    // 根据id查询用户信息
    let users = await this.ctx.service.user.getUserById(2);
    this.ctx.body = users;
  }
}
module.exports = UserController;
最好编写我们的路由规则

app/router.js

module.exports = app => {
  const { router, controller } = app;
  // http://127.0.0.1:7001/user 会映射到app/controller/user.js 的index方法上
  router.get('/user', controller.user.index);
};

到这里我们就写完了, 一起测试一把吧
访问: http://127.0.0.1:7001/user

{"id":2,"name":"测试2","age":11,"created_at":"2019-07-10T03:49:11.000Z","updated_at":"2019-07-24T03:49:14.000Z"}


posted @ 2023-06-29 19:30  走走停停走走  Views(244)  Comments(0Edit  收藏  举报