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

后端向数据库更改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 为什么eprime输出的数据会有缺失?
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题