node.js通过Sequelize 连接MySQL的方法
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要介绍了node.js通过Sequelize 连接MySQL的方法,本文给大家介绍的非常详细,对大家的学习或工作,具有一定的参考借鉴价值,需要的朋友可以参考下
一.通过koa2脚手架构建项目
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
5.2.使用postman测试接口
测试find接口(因为我们写的find方法使用的post方法所以记得将get换成post)
测试get接口
展示一下的目录
到此这篇关于node.js通过Sequelize 连接MySQL的文章就介绍到这了,更多相关node.js连接MySQL内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
上一篇:Vue仿百度搜索功能
下一篇:解决elementui表格操作列自适应列宽
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程