node.js Promise封装

本文介绍了一种使用Promise封装数据库更新逻辑的方法,通过将复杂的异步操作转化为Promise,实现了更简洁、易读的代码结构。文章详细展示了如何利用Node.js的pool模块连接数据库,并执行SQL更新语句,同时处理了可能的错误情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前在一个页面写了好多代码,有点冗杂,把具体的逻辑代码封装一下;

有些方法需要Promise

示例:

function serverYDYN() {
	//修改
	this.updateContent = function (id, newContent) {
        var promise = new Promise(function (resolve, reject) {
            pool.getConnection((err, connection) => {
                if (err) {
                    console.log("连接失败");
                } else {
                    let sql = "UPDATE ydyn1 SET content='" + newContent + "'WHERE id='" + id + "'";
                    connection.query(sql, function (err, result) {
                        if (err) {
                            console.log('[修改content错误] - ', err.message);
                            return reject(err);
                        }
                        console.log('修改content result:\n', result);
                        return resolve(result);
                    });
                    connection.release();
                }
            });
        });
        return promise;
    };
}

module.exports = serverYDYN;

使用:

const serverYDYN = require('./sqlServerYDYN'); 

app.put('/updateContent', function (request, res) {
  let newContent = request.body.content;
  let id = request._parsedUrl.query;
  sqlServer.updateContent(id,newContent).then(
    result => {
      console.log('修改成功 res',result);
      res.send('sucess');
    }
  ).catch(
    err => {
      console.log('修改错误',err)
    }
  );
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值