文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么使用Nodejs连接Mysql实现基本的增删改查操作

2023-06-15 03:53

关注

这篇文章将为大家详细讲解有关怎么使用Nodejs连接Mysql实现基本的增删改查操作,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

接下来示例代码的主要技术点包括

0、前置需求

1、node连接数据库

2、 连接mysql数据库,实现表格显示功能

怎么使用Nodejs连接Mysql实现基本的增删改查操作

怎么使用Nodejs连接Mysql实现基本的增删改查操作

  const koaNunjucks = require('koa-nunjucks-2');  const path = require('path');   // 注入 nunjucks 模板引擎   app.use(koaNunjucks({      ext: 'html', // html文件的后缀名      path: path.join(__dirname, 'views'), // 视图文件放在哪个文件夹下      nunjucksConfig: {        trimBlocks: true // 自动去除 block/tag 后面的换行符      }    }));    //在 /userAll这个路由中我们不直接返回数据了,我们返回table.html页面  router.get("/userAll", async ctx => {  const userAll = await resDb("SELECT * FROM user")  await ctx.render("table",{userAll})  })

3、 添加数据到mysql数据库中

怎么使用Nodejs连接Mysql实现基本的增删改查操作

怎么使用Nodejs连接Mysql实现基本的增删改查操作

怎么使用Nodejs连接Mysql实现基本的增删改查操作

4、 通过id更新数据

5、通过id删除单条数据

6、 完整代码

        const Koa = require("koa")        const Router = require("koa-router")        const mysql = require("mysql")        const koaNunjucks = require('koa-nunjucks-2');        const path = require('path');        const app = new Koa();        const router = new Router();        // mysqljs 连接 mysql数据库        let connection = mysql.createConnection({            host: '127.0.0.1', // mysql所在的主机,本地的话就是 127.0.0.1 或者 localhost, 如果数据库在服务器上,就写服务器的ip            user: 'root', // mysql的用户名 默认root            password: 'mysql密码', // mysql的密码            database: 'db1' // 你要连接那个数据库        })        // 连接 mysql        connection.connect(err=>{            // err代表失败            if(err) {                console.log("数据库初始化失败");            }else {                console.log("数据库初始化成功");            }        })        // 因为 mysqljs不支持 Promise方式CRUD数据        // 所以我们做一个简单的封装        function resDb(sql, params) {            return new Promise((resolve,reject) => {                let sqlParamsList = [sql]                if(params) {                    sqlParamsList.push(params)                }                connection.query(...sqlParamsList, (err,res) => {                    if(err) {                        reject(err)                    }else {                        resolve(res)                    }                })            })        }         // 注入 nunjucks 模板引擎         app.use(koaNunjucks({            ext: 'html', // html文件的后缀名            path: path.join(__dirname, 'views'), // 视图文件放在哪个文件夹下            nunjucksConfig: {              trimBlocks: true // 自动去除 block/tag 后面的换行符            }          }));        //请求 /userAll 的时候返回数据        router.get("/userAll", async ctx => {            const userAll = await resDb("SELECT * FROM user")            await ctx.render("table",{userAll})        })        //请求 /addUser 接受前端传过来的数据,并且把数据持久化到数据库中        router.get("/addUser", async ctx => {            const { name, age } = ctx.query            // 判断 name 和 age是否有值,都有值时,数据存入数据库,刷新表格页面            // 否则直接返回到表格页面            if(name && age) {            await resDb("INSERT INTO user values(null,?,?)",[name, age])            }            //重定向路由,到 userAll            ctx.redirect("/userAll")        })        //请求 /updateUser 接受前端传过来的数据,并且把数据持久化到数据库中        router.get("/updateUser", async ctx => {            const { id, name, age } = ctx.query            // 判断 id, name 和 age是否有值,都有值时,更新数据库中的数据,刷新表格页面            // 否则直接返回到表格页面            if(id, name && age) {            await resDb("UPDATE user SET name=?, age=? WHERE id=?",[name, age, id])            }            //重定向路由,到 userAll            ctx.redirect("/userAll")        })        //请求/delete/:id  接受前端传过来的数据,并且把对应的id的数据删掉        router.get("/delete/:id", async ctx => {            const { id } = ctx.params            // 判断 id否有值,有值时,根据id删除数据库中的数据,刷新表格页面            // 否则直接返回到表格页面            if(id) {            await resDb("DELETE FROM user WHERE id=?",[id])            }            //重定向路由,到 userAll            ctx.redirect("/userAll")        })        //测试代码        router.get("/hello", ctx => {            ctx.body = "hello"        })        app        .use(router.routes())        .use(router.allowedMethods())        .listen(3333,()=>{            console.log("server running port:" + 3333);        })

7、写在最后

关于“怎么使用Nodejs连接Mysql实现基本的增删改查操作”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯