nodeJs 服務(wù)器以及中間層實踐(二)

二藕赞、服務(wù)器與數(shù)據(jù)庫

https://github.com/bartflyian/wx-front-with-server/tree/master/ 文件代碼地址当娱。
第一篇已經(jīng)使用koa對不同請求做不同的路由處理,如 GET /纯陨、POST /add坛芽;當(dāng)在客戶端頁面請求這些地址時,我們想其返回帶有數(shù)據(jù)庫數(shù)據(jù)的json翼抠。那么首先咙轩,需要建立數(shù)據(jù)庫連接:
1. 安裝mysql,數(shù)據(jù)庫視圖管理工具我用的是Navicat
2. 新建一個名為 koa 的數(shù)據(jù)庫,創(chuàng)建新的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. 服務(wù)器想要操作數(shù)據(jù)庫表阴颖,需要書寫對應(yīng)的sql語句活喊,在這里我用到Node的ORM框架Sequelize,即是創(chuàng)建與數(shù)據(jù)庫的映射,當(dāng)然也有自己的書寫規(guī)范量愧,所以還需要看看sequelize文檔了解一下钾菊,不過在這只用到基礎(chǔ)的增刪改查。
    依賴包添加"sequelize": "3.24.1",或者直接npm install
    (1) 創(chuàng)建 config文件夾偎肃,其下創(chuàng)建DBconfig.js:
image.png

(2) 創(chuàng)建 lib 文件夾煞烫,其下創(chuàng)建mysql.js,在此使用sequelize連接數(shù)據(jù)庫,并作數(shù)據(jù)表的映射sequelize先new一個Sequelize對象連接數(shù)據(jù)庫累颂,然后用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統(tǒng)一處理數(shù)據(jù)庫表中通用的字段如id...,最后return出一個sequelize.define方法紊馏,這樣我們在創(chuàng)建sequelize數(shù)據(jù)表映射時料饥,可以簡潔許多)。

(3) 創(chuàng)建 models 文件夾, 存放所有數(shù)據(jù)表映射朱监,我們先創(chuàng)建user.js:

image

(都使用剛剛封裝的defineModel方法)

新建model.js,對models文件夾下的文件作自動化的讀取和導(dǎo)出岸啡;

image

(4) 創(chuàng)建service 文件夾, 存放對數(shù)據(jù)庫的操作文件赫编。我們先創(chuàng)建user.js:

image

并引入model巡蘸,現(xiàn)在里面已經(jīng)存在自動化導(dǎo)出的user對象;

我在這里只做數(shù)據(jù)查找擂送,添加和刪除悦荒。這樣在之前koa創(chuàng)建的controller中,引入user团甲,使用await對數(shù)據(jù)庫做處理后返回數(shù)據(jù)。

運(yùn)行 node app.js,在瀏覽器輸入localhost:3000黍聂。在輸入框輸入新用戶名躺苦,點(diǎn)擊添加按鈕發(fā)送post請求身腻,刷新后發(fā)現(xiàn)下面已經(jīng)顯示數(shù)據(jù)庫中存在的用戶列表。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末匹厘,一起剝皮案震驚了整個濱河市嘀趟,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌愈诚,老刑警劉巖她按,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異炕柔,居然都是意外死亡酌泰,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門匕累,熙熙樓的掌柜王于貴愁眉苦臉地迎上來陵刹,“玉大人,你說我怎么就攤上這事欢嘿∷ニ觯” “怎么了?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵炼蹦,是天一觀的道長羡宙。 經(jīng)常有香客問我,道長掐隐,這世上最難降的妖魔是什么狗热? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮瑟枫,結(jié)果婚禮上斗搞,老公的妹妹穿的比我還像新娘。我一直安慰自己慷妙,他們只是感情好僻焚,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著膝擂,像睡著了一般虑啤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上架馋,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天狞山,我揣著相機(jī)與錄音,去河邊找鬼叉寂。 笑死萍启,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播勘纯,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼局服,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤拯田,失蹤者是張志新(化名)和其女友劉穎眯漩,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了唐责。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡来庭,死狀恐怖妒蔚,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情月弛,我是刑警寧澤肴盏,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站帽衙,受9級特大地震影響菜皂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜厉萝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一恍飘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧谴垫,春花似錦章母、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至前弯,卻和暖如春蚪缀,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背恕出。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工询枚, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人浙巫。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓金蜀,卻偏偏與公主長得像刷后,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子渊抄,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348