nodeJs 服务器以及中间层实践(二)

二、服务器与数据库

https://github.com/bartflyian/wx-front-with-server/tree/master/ 文件代码地址。
第一篇已经使用koa对不同请求做不同的路由处理,如 GET /、POST /add;当在客户端页面请求这些地址时,我们想其返回带有数据库数据的json。那么首先,需要建立数据库连接:
1. 安装mysql,数据库视图管理工具我用的是Navicat
2. 新建一个名为 koa 的数据库,创建新的users表:

      use koa;

      create table users (

          id varchar(50) not null,

          name varchar(100) not null,

          gender bool not null,

          birth varchar(10) not null,

          createdAt bigint not null,

          updatedAt bigint not null,

          version bigint not null,

          primary key (id)

      ) engine=innodb;
  1. 服务器想要操作数据库表,需要书写对应的sql语句,在这里我用到Node的ORM框架Sequelize,即是创建与数据库的映射,当然也有自己的书写规范,所以还需要看看sequelize文档了解一下,不过在这只用到基础的增删改查。
    依赖包添加"sequelize": "3.24.1",或者直接npm install
    (1) 创建 config文件夹,其下创建DBconfig.js:
image.png

(2) 创建 lib 文件夹,其下创建mysql.js,在此使用sequelize连接数据库,并作数据表的映射sequelize先new一个Sequelize对象连接数据库,然后用sequelize.define对具体的表作映射处理。在这里将这两个过程封装到mysql.js中:

const Sequelize = require('sequelize');

const config = require('../config/DBconfig');

console.log('init sequelize...');

var sequelize = new Sequelize(config.database, config.username, config.password, {

    host: config.host,

    dialect: 'mysql',

    pool: {

        max: 5,

        min: 0,

        idle: 30000

    }

});

const ID_TYPE = Sequelize.STRING(50);

function defineModel(name, attributes) {

    var attrs = {};

    for (let key in attributes) {

        let value = attributes[key];

        if (typeof value === 'object' && value['type']) {

            value.allowNull = value.allowNull || false;

            attrs[key] = value;

        } else {

            attrs[key] = {

                type: value,

                allowNull: false

            };

        }

    }

    attrs.id = {

        type: ID_TYPE,

        primaryKey: true

    };

    attrs.createdAt = {

        type: Sequelize.BIGINT,

        allowNull: false

    };

    attrs.updatedAt = {

        type: Sequelize.BIGINT,

        allowNull: false

    };

    attrs.version = {

        type: Sequelize.BIGINT,

        allowNull: false

    };

    return sequelize.define(name, attrs, {

        tableName: name,

        timestamps: false,

        hooks: {

            beforeValidate: function (obj) {

                let now = Date.now();

                if (obj.isNewRecord) {

                    if (!obj.id) {

                        obj.id = generateId();

                    }

                    obj.createdAt = now;

                    obj.updatedAt = now;

                    obj.version = 0;

                } else {

                    obj.updatedAt = Date.now();

                    obj.version++;

                }

            }

        }

    });

}

var db = {

    sync: () => {

        if (process.env.NODE_ENV !== 'production') {

            sequelize.sync({ force: true });

        } else {

            throw new Error('Cannot sync() when NODE_ENV is set to \'production\'.');

        }

    }

};

db.defineModel = defineModel;

const TYPES = ['STRING', 'INTEGER', 'BIGINT', 'TEXT', 'DOUBLE', 'DATEONLY', 'BOOLEAN'];

for (let type of TYPES) {

    db[type] = Sequelize[type];

}

db.ID = ID_TYPE;

module.exports = db;

(defineModel统一处理数据库表中通用的字段如id...,最后return出一个sequelize.define方法,这样我们在创建sequelize数据表映射时,可以简洁许多)。

(3) 创建 models 文件夹, 存放所有数据表映射,我们先创建user.js:

image

(都使用刚刚封装的defineModel方法)

新建model.js,对models文件夹下的文件作自动化的读取和导出;

image

(4) 创建service 文件夹, 存放对数据库的操作文件。我们先创建user.js:

image

并引入model,现在里面已经存在自动化导出的user对象;

我在这里只做数据查找,添加和删除。这样在之前koa创建的controller中,引入user,使用await对数据库做处理后返回数据。

运行 node app.js,在浏览器输入localhost:3000。在输入框输入新用户名,点击添加按钮发送post请求,刷新后发现下面已经显示数据库中存在的用户列表。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342