前端发起更改数据请求后再获取后端数据发现数据并未更改的一个解决办法

前端发起更改数据请求后再获取后端数据发现数据并未更改的一个解决办法

问题再现

复制代码
async function refuseRefund(id,type){
    if(confirm('确定拒绝?')){
        await fetch('http://127.0.0.1:3000/api/refuseRefund', {
            method: 'POST',
            headers: {
                'Content-type': 'application/json'
            },
            body: JSON.stringify({
                id: id,
                type: type
            })
        })
        .then(response => {
            if (!response.ok) {
                throw new Error('Network response was not ok');
            }
            return response.json();
        })
        .then(data => {
            //重载
            addOrdersList();
        })
        .catch(error => {
            console.error('Error:', error);
        });  
    }
}

async function addOrdersList() {
    buyShipOrders = await getAll('buy');
    console.log(buyShipOrders); 
}

我们向后端发起一个http请求来修改数据库的某个值,然后再重新获取数据,发现数据并未更改,奇怪,明明函数里用了await()

原因

原来后端node.js函数出了问题

复制代码
app.post('/api/refuseRefund', (req, res) => {
    const orderId = req.body.id;
    const type = req.body.type;
    pool.query(`UPDATE ${type} set status = ? WHERE id = ? `, ['已拒绝',orderId], (error, results) => {
        if (error) {
            console.error('Error querying database:', error);
            res.status(500).send('Internal Server Error');
            return;
        }
    });
    res.json({status: true});
});

nodejs也是js,那么既然是js,那么它就是异步的,也就是说,res.json()会先于pool.query()执行,数据库修改也是需要时间的,这就回造成数据库还没处理完就返回了res,前端这边拿到res也是立马再发起了一个获取数据的请求,由于数据库还没修改完,所以返回的是修改前的值

解决

将res.json()放在pool.query()里面

复制代码
app.post('/api/refuseRefund', (req, res) => {
    const orderId = req.body.id;
    const type = req.body.type;
    pool.query(`UPDATE ${type} set status = ? WHERE id = ? `, ['已拒绝',orderId], (error, results) => {
        if (error) {
            console.error('Error querying database:', error);
            res.status(500).send('Internal Server Error');
            return;
        }
        res.json({status: true});
    });
});

总结

node.js是异步的,需要考虑执行顺序

相关推荐
徐小夕@趣谈前端5 分钟前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
Data_Journal17 分钟前
如何使用 Python 解析 JSON 数据
大数据·开发语言·前端·数据库·人工智能·php
德育处主任Pro17 分钟前
纯前端网格路径规划:PathFinding.js的使用方法
开发语言·前端·javascript
墨笔.丹青24 分钟前
基于QtQuick开发界面设计出简易的HarmonyUI界面----下
开发语言·前端·javascript
董世昌4141 分钟前
深度解析浅拷贝与深拷贝:底层逻辑、实现方式及实战避坑
前端·javascript·vue.js
扶苏10021 小时前
vue使用event.dataTransfer实现A容器数据拖拽复制到到B容器
前端·vue.js·chrome
David凉宸1 小时前
Vue 3 项目的性能优化策略:从原理到实践
前端·vue.js·性能优化
小马_xiaoen1 小时前
Proxy 与 Reflect 从入门到实战:ES6 元编程核心特性详解
前端·javascript·ecmascript·es6
hoiii1871 小时前
MATLAB SGM(半全局匹配)算法实现
前端·算法·matlab
摘星编程2 小时前
React Native + OpenHarmony:ImageSVG图片渲染
javascript·react native·react.js