yusdddd_ 2022-03-25 21:05 采纳率: 88.2%
浏览 96
已结题

后端向数据库更改update数据,用postman调试返回Okpacket,但是数据没存进去

问题遇到的现象和发生背景

后端向数据库更改update数据,用postman调试返回Okpacket,但是数据没存进去,为什么回返回Okpacket?

问题相关代码,请勿粘贴截图

/* 修改个人信息 */ 封装的changeMsgInfo方法,方便下面函数调用

static changeMsgInfo(myName,sex,className,stuNum,username){
  return new Promise((resolve,reject)=>{
    let sql="update myusers_db set my_name='"+myName+"',sex='"+sex+"',class_name='"+className+"',stu_num='"+stuNum+"' where username='"+username+"'"
    this.query(sql).then(result=>{
      console.log("走到result")
      resolve(result)
    }).catch(err=>{
      console.log("写入失败了!!@")
      reject("写入失败了!")
    })
  })
}
/* 修改个人信息   封装的changeMsg方法,方便接口调用 */ 
static async changeMsg(req,resp){
  let body = req.body
  let changeMsgData = await this.changeMsgInfo(body.myName,body.sex,body.className,body.stuNum,body.username)
  if(changeMsgData.length!=0){
    console.log("成功")
    resp.send(changeMsgData)
  } else{
    console.log("失败")
    console.log(changeMsgData)
    resp.status(500).send("写入数据失败")
  }
}
router.get('/changeMsg',function(req,res){
  user.changeMsg(req,res)
})
运行结果及报错内容

这是终端打印的内容

img

运行结果显示成功,返回的changeMsgData是个Okpacket,但是数据库的数据没变动,sql语句检查了十几遍了,应该是没问题的!

我的解答思路和尝试过的方法

img


这是postman的结果

我想要达到的结果

想要将数据更新到数据库!要怎么改才能实现

  • 写回答

1条回答 默认 最新

  • yusdddd_ 2022-03-26 02:19
    关注

    本人已解决!参考了其他开源项目之后,在接口的地方function加上async就解决了,具体什么原因再查查。解决方法:

    /*  修改个人信息*/
    router.post('/changeMsg',async function(req,res){
      user.changeMsg(req,res)
    })
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

    报告相同问题?

    问题事件

    • 系统已结题 4月7日
    • 已采纳回答 3月30日
    • 修改了问题 3月25日
    • 修改了问题 3月25日
    • 展开全部

    悬赏问题

    • ¥15 Unity微信小游戏上调用ReadPixels()方法报错
    • ¥15 如何通过求后验分布求得样本中属于两种物种其中一种的概率?
    • ¥15 q从常量变成sin函数,怎么改写python代码?
    • ¥15 图论编程问题,有可以指导的吗
    • ¥15 DEA的CCR模型画图
    • ¥15 请假各位一个关于安卓车机的问题
    • ¥15 光谱仪怎么看这样的透射谱
    • ¥15 pyqt5 如何实现输入框输入关键词,下拉框显示模糊查询返回的结果?
    • ¥20 fluent模拟,可以燃烧和相变同时模拟吗?
    • ¥50 海康摄像头,C#如何识别车牌号码和抓取JPG