node.js通過Sequelize 連接MySQL的方法
一.通過koa2腳手架構(gòu)建項(xiàng)目
1.1 安裝koa-generator
在終端輸入:
$ npm install -g koa-generator
1.2 使用koa-generator生成koa2項(xiàng)目
$ koa2 HelloKoa2
成功創(chuàng)建項(xiàng)目后,進(jìn)入項(xiàng)目目錄,并執(zhí)行npm install命令
$ cd HelloKoa2 $ npm install
1.3 啟動項(xiàng)目
在終端輸入:
$ npm start
項(xiàng)目啟動后,默認(rèn)端口號是3000,在瀏覽器中運(yùn)行可以得到下圖的效果說明運(yùn)行成功。
二.創(chuàng)建連接
2.1剛剛創(chuàng)建的文件使用webstorm打開
新建一個db目錄

2.2查看Sequelize文檔
使用npm安裝Sequelize
npm install --save sequelize
你還必須手動為所選數(shù)據(jù)庫安裝驅(qū)動程序選擇一個方法之一:
# 選擇以下之一: $ npm install --save pg pg-hstore # Postgres $ npm install --save mysql2 $ npm install --save mariadb $ npm install --save sqlite3 $ npm install --save tedious # Microsoft SQL Server
我這里下載得是MySQL2
2.3連接數(shù)據(jù)庫
再剛剛創(chuàng)建得db文件加里面添加**config.js**
添加連接代碼:
module.exports = {
dbsMysql: 'mysql://root:123456@localhost:3306/new'
//root是數(shù)據(jù)庫管理員賬號,‘123546'是密碼 3306是端口號(MySQL默認(rèn)是3306) school_admin是數(shù)據(jù)庫名稱
}
繼續(xù)在db文件夾里面添加mysql.js
添加連接以及添加日記:
const Sequelize = require('sequelize');
const mysqlurl = require('./config').dbsMysql
const sequelize = new Sequelize(mysqlurl, {
// 選擇一種日志記錄參數(shù)
logging: console.log // 默認(rèn)值,顯示日志函數(shù)調(diào)用的第一個參數(shù)
});
// //每次啟動server刷新數(shù)據(jù)庫
// (async ()=>{
// await sequelize.sync({ force: true });
// })()
module.exports = sequelize
三.創(chuàng)建模型
3.1模型定義
在db目錄下添加models文件夾再添加一個new2.js
定義模型:
const { Sequelize, DataTypes, Model } = require('sequelize');
const sequelize = require('../mysql');
const new2 = sequelize.define('t_new2', {
name: {
type: DataTypes.STRING,
allowNull: false
},
},
{
// 這是其他模型參數(shù)
freezeTableName: true
});
// 定義的模型是類本身
module.exports= new2
四.添加路由
4.1創(chuàng)建new2路由
在routes文件夾中添加new2.js
//引入kob得routes模塊
const router = require('koa-router')()
//定義模型為剛剛創(chuàng)建得new2.js
let Model = require("../db/models/new2");
//正常來說啟動端口為http://localhost:3000 添加/new2就可以進(jìn)入new2路由
router.prefix('/new1')
// 進(jìn)入new2路由以后可以打印this is a users response!
router.get('/', function (ctx, next) {
ctx.body = 'this is a users response!'
})
//設(shè)置增加add接口
router.post('/add', async function (ctx, next) {
console.log(ctx.request.body)
const new2 = await Model.create(ctx.request.body);
ctx.body = {
code:200,
data:new2
}
})
//設(shè)置查詢find接口
router.post('/find', async function (ctx, next) {
const new2 =await Model.findAll({include: []})
console.log(1111)
ctx.body = {
code: 200,
data: new2
}
})
//設(shè)置通過id得到所需信息的get接口
router.post('/get', async function (ctx, next) {
// let users = await User.
// find({})
console.log(ctx.request.body)
let new2 = await Model.findOne({
// attributes: ['name', 'where']
where: {
id: ctx.request.body.id
}
});
ctx.body = {
code:200,
data:new2
}
})
//設(shè)置修改update接口
router.post('/update', async function (ctx, next) {
console.log(ctx.request.body)
// let pbj = await Model.update({ _id: ctx.request.body._id }, ctx.request.body);
let new2 = await Model.update(ctx.request.body, {
where: {
id: ctx.request.body.id
}
});
ctx.body = new2
})
//設(shè)置刪除delete接口
router.post('/delete', async function (ctx, next) {
console.log(ctx.request.body)
// 刪除所有名為 "Jane" 的人
await Model.destroy({
where: { id: ctx.request.body.id }
});
ctx.body = 'shibai '
})
// //每次啟動server刷新數(shù)據(jù)庫
// (async ()=>{
// await sequelize.sync({ force: true });
// })()
module.exports = router
4.2在app.js里面添加路由


//引入剛剛創(chuàng)建的new2路由
const new2 =require('./routes/new2')
//使用我們的路由 app.use(new2.routes(),new2.allowedMethods())
4.3啟動項(xiàng)目

在數(shù)據(jù)庫中查看

5.測試
5.1使用瀏覽器查看
輸入url:http://localhost:3000/new2

5.2.使用postman測試接口
測試find接口(因?yàn)槲覀儗懙膄ind方法使用的post方法所以記得將get換成post):
http://localhost:3000/new2/find

測試get接口

展示一下最后的目錄

到此這篇關(guān)于node.js通過Sequelize 連接MySQL的文章就介紹到這了,更多相關(guān)node.js連接MySQL內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
NodeJS連接MongoDB數(shù)據(jù)庫時(shí)報(bào)錯的快速解決方法
下面小編就為大家?guī)硪黄狽odeJS連接MongoDB數(shù)據(jù)庫時(shí)報(bào)錯的快速解決方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考2016-05-05
Nodejs Playwright 2Captcha 驗(yàn)證碼識別實(shí)現(xiàn)自動登陸功能
日常工作當(dāng)中,為了提高工作效率,我們可能會寫腳本來自動執(zhí)行任務(wù),有些網(wǎng)站因?yàn)樾枰脩舻顷?所以腳本的自動登陸功能必不可少,這篇文章主要介紹了Nodejs Playwright 2Captcha 驗(yàn)證碼識別實(shí)現(xiàn)自動登陸功能,需要的朋友可以參考下2024-05-05
Node.js實(shí)現(xiàn)下載文件的兩種實(shí)用方式
最近優(yōu)化了幾個新人寫出的動態(tài)表格文件下載接口的性能瓶頸,感覺非常有必要總結(jié)一篇文章作為文檔來拋磚引玉,這篇文章主要給大家介紹了關(guān)于Node.js實(shí)現(xiàn)下載文件的兩種實(shí)用方式,需要的朋友可以參考下2022-09-09
nodejs項(xiàng)目windows下開機(jī)自啟動的方法
今天小編就為大家分享一篇nodejs項(xiàng)目windows下開機(jī)自啟動的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-11-11
在Nodejs中實(shí)現(xiàn)一個緩存系統(tǒng)的方法詳解
在數(shù)據(jù)庫查詢遇到瓶頸時(shí),我們通??梢圆捎镁彺鎭硖嵘樵兯俣?同時(shí)緩解數(shù)據(jù)庫壓力,在一些簡單場景中,我們也可以自己實(shí)現(xiàn)一個緩存系統(tǒng),避免使用額外的緩存中間件,這篇文章將帶你一步步實(shí)現(xiàn)一個完善的緩存系統(tǒng),需要的朋友可以參考下2024-03-03
解決nodejs報(bào)錯Error:EPERM:operation not permitted,mkdi
這篇文章主要介紹了解決nodejs報(bào)錯Error:EPERM:operation not permitted,mkdir‘xxxxxxxxxxxxxxxx‘問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02

