node.js项目如何连接MySQL,方法操作是什么
Admin 2022-06-11 群英技术资讯 837 次浏览
这篇文章给大家介绍了“node.js项目如何连接MySQL,方法操作是什么”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。1.1 安装koa-generator
在终端输入:
$ npm install -g koa-generator
1.2 使用koa-generator生成koa2项目
$ koa2 HelloKoa2
成功创建项目后,进入项目目录,并执行npm install命令
$ cd HelloKoa2 $ npm install
1.3 启动项目
在终端输入:
$ npm start
项目启动后,默认端口号是3000,在浏览器中运行可以得到下图的效果说明运行成功。
2.1刚刚创建的文件使用webstorm打开
新建一个db目录

2.2查看Sequelize文档
使用npm安装Sequelize
npm install --save sequelize
你还必须手动为所选数据库安装驱动程序选择一个方法之一:
# 选择以下之一: $ 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连接数据库
再刚刚创建得db文件加里面添加**config.js**
添加连接代码:
module.exports = {
dbsMysql: 'mysql://root:123456@localhost:3306/new'
//root是数据库管理员账号,‘123546'是密码 3306是端口号(MySQL默认是3306) school_admin是数据库名称
}
继续在db文件夹里面添加mysql.js
添加连接以及添加日记:
const Sequelize = require('sequelize');
const mysqlurl = require('./config').dbsMysql
const sequelize = new Sequelize(mysqlurl, {
// 选择一种日志记录参数
logging: console.log // 默认值,显示日志函数调用的第一个参数
});
// //每次启动server刷新数据库
// (async ()=>{
// await sequelize.sync({ force: true });
// })()
module.exports = sequelize
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
},
},
{
// 这是其他模型参数
freezeTableName: true
});
// 定义的模型是类本身
module.exports= new2
4.1创建new2路由
在routes文件夹中添加new2.js
//引入kob得routes模块
const router = require('koa-router')()
//定义模型为刚刚创建得new2.js
let Model = require("../db/models/new2");
//正常来说启动端口为http://localhost:3000 添加/new2就可以进入new2路由
router.prefix('/new1')
// 进入new2路由以后可以打印this is a users response!
router.get('/', function (ctx, next) {
ctx.body = 'this is a users response!'
})
//设置增加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
}
})
//设置查询find接口
router.post('/find', async function (ctx, next) {
const new2 =await Model.findAll({include: []})
console.log(1111)
ctx.body = {
code: 200,
data: new2
}
})
//设置通过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
}
})
//设置修改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
})
//设置删除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刷新数据库
// (async ()=>{
// await sequelize.sync({ force: true });
// })()
module.exports = router
4.2在app.js里面添加路由


//引入刚刚创建的new2路由
const new2 =require('./routes/new2')
//使用我们的路由 app.use(new2.routes(),new2.allowedMethods())
4.3启动项目

在数据库中查看

5.测试
5.1使用浏览器查看
输入url:http://localhost:3000/new2

5.2.使用postman测试接口
测试find接口(因为我们写的find方法使用的post方法所以记得将get换成post):
http://localhost:3000/new2/find

测试get接口

展示一下最后的目录

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家详细介绍了JavaScript实现简易折叠面板,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
JavaScript中的变量是松散类型的,可以保存任何类型数据,变量只不过是一个名称,下面这篇文章主要给大家介绍了关于JavaScript变量声明的var、let、const的相关资料,需要的朋友可以参考下
这篇文章主要介绍了uni-app 的基础组件,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
这篇文章给大家分享的是判断字符串的长度的方法,也就是判断字符串有几个字符,这里是使用jQuery来实现的,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
这篇文章给大家分享的是有关layui怎么使用的内容,本文有使用layui实现三级联动的实例供大家参考,小编觉得挺实用的,对大家学习layui的使用有一定的帮助,感兴趣的朋友接下来一起跟随小编看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008