MALOUDA-PSA 2024-08-27 10:13 采纳率: 96.7%
浏览 4
已结题

云函数往云数据库添加数据的问题

用 get 可以拿到数据,可是ADD添加数据缺添加不成功:

const db = uniCloud.database();

exports.main = async (event, context) => {
 
  const collection = db.collection('fxj_list')
  let res = collection.add({
      stockCode: 'sh600389'
  })
  
  console.log(JSON.stringify(res));

 

    // 返回错误信息
    return {
      code: 200,
      msg: "内部错误",
      data: JSON.stringify(res)
    };
    
    //返回数据给客户端
    return event


数据库并没有成功添加数据

  • 写回答

1条回答 默认 最新

  • 帅次 移动开发领域优质创作者 2024-08-27 12:07
    关注

    1、collection.add() 方法是异步的,这意味着它不会立即返回结果。你需要等待这个异步操作完成,并处理其返回的结果。

    2、collection.add() 方法本身返回的是一个 Promise 对象,而不是实际的添加结果。你需要使用 await 关键字来等待这个 Promise 解析,并获取实际的结果。

    以下是修改后的代码示例,它应该能正确地向云数据库添加数据,并返回适当的结果给客户端:

    const db = uniCloud.database();  
      
    exports.main = async (event, context) => {  
      try {  
        const collection = db.collection('fxj_list');  
        let res = await collection.add({  
          stockCode: 'sh600389'  
        });  
      
        // 注意:res 是一个包含 _id 和其他可能的字段的对象  
        // 如果您只需要 _id,可以使用 res._id  
        console.log(JSON.stringify(res));  
      
        // 返回成功信息给客户端  
        return {  
          code: 200,  
          msg: "添加成功",  
          data: res // 或者只返回 res._id,取决于您的需求  
        };  
      } catch (error) {  
        // 处理添加过程中可能发生的错误  
        console.error('添加数据失败:', error);  
        return {  
          code: 500,  
          msg: "添加数据失败",  
          data: error.message || '未知错误'  
        };  
      }  
    };
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 9月11日
  • 已采纳回答 9月3日
  • 创建了问题 8月27日

悬赏问题

  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图
  • ¥15 UE5.1局部变量对蓝图不可见
  • ¥15 一共有五道问题关于整数幂的运算还有房间号码 还有网络密码的解答?(语言-python)
  • ¥20 sentry如何捕获上传Android ndk 崩溃
  • ¥15 在做logistic回归模型限制性立方条图时候,不能出完整图的困难
  • ¥15 G0系列单片机HAL库中景园gc9307液晶驱动芯片无法使用硬件SPI+DMA驱动,如何解决?