HarmonyOS:如何讲 Map 类型数据转化为valuesBucket(数据集)类型

前言:今天在开发数据库插入数据的过程中,发现之前的数据插入都是先将 json 数据转为 model,再将model 转为数据集,这样再往数据库里面存储的方式。今天开发过程中,发现需要被存储的数据是 Map 格式的,如果还按照原来的思路来处理,Map 数据------>Json 数据------>Model 对象------>ValuesBucket数据,再执行存储,相当于多了步骤,虽然也可以这么操作,但是对于我们来说,如果数据量比较大,就加大了处理器的负担,所以我直接将 Map 数据转为ValuesBucket数据,这样中间就节省了处理器的开支,并且成功存储数据。 下面是 Map 转ValuesBucket的方法:

typescript 复制代码
function mapToValuesBucket(map: Map<string, string | number | boolean>): ValuesBucket {
  let valuesBucket: ValuesBucket = {}
  map.forEach((value, key) => {
    valuesBucket[key] = value
  });
  return valuesBucket;
}

 const prodDisMap = new Map<string, string>();
 prodDisMap.set('name', '产品 1');
 prodDisMap.set('code', '00001');
 const valuesBucket = mapToValuesBucket(prodDisMap);
 console.info(`valuesBucket:${JSON.stringify(valuesBucket)}`)

我们项目中的存储数据库方法如下:

typescript 复制代码
function parseBaseStoreProductDisData(context: Context, jsonData: string, serverNode:string) {
  DatabaseManager.deleteTableDataByTabName(context,"base_store_prod_dis",serverNode);
  try {
    //整理数据
    //分销规则数组,暂时写死处理,后续再从登录数据获取
    let sepcList:string[] = ["drid", "pid", "dist", "pri", "inv", "aging", "disp", "sdisp", "cmpt", "oos", "mtd", "ord", "gofa", "item1", "item2", "item3", "item4", "item5", "item6", "item7", "item8", "item9", "item10", "genid"]
    //原始数据模型
    let originalStoreProDisList:BaseProductDisModel[] = JSON.parse(jsonData)[serverNode];
    let allProdDisList: Map<string,string>[] = []
    let parseProductDisList: ValuesBucket[] = [];
    //转为需要存储回显表的数据模型
    for (let i = 0; i < originalStoreProDisList.length; i++) {
      const valueBucket1: ValuesBucket = {}
      let element = originalStoreProDisList[i];
      let prodDisMap = new Map<string, string>();
      let pStr:string  = element.p as string;
      if (pStr!=undefined&&pStr.length>0) {
        let propertyList:string[] = pStr.split(',');
        for (let index = 0; index < propertyList.length; index++) {
          const columnValue:string = propertyList[index] as string;
          let columnName:string = '';
          if (sepcList.length > index) {
            columnName = sepcList[index] as string;
            if (columnName.length>0&&(columnName == 'sid' || columnName == 'drid' || columnName == 'drId')) {
              columnName = 'store_id'
            }else  if (columnName.length>0 && columnName =='pid'){
              columnName = 'prod_id'
            }
          }
          prodDisMap.set(columnName,columnValue);
        }
        if (element.gen_id&&element.gen_id.length>0) {
          prodDisMap.set('genid',element.gen_id);
        }
        if (serverNode&&serverNode.length>0){
          prodDisMap.set('server_node',serverNode);
        }
        if (prodDisMap) {
        //Map 转valuesBucket
          const valuesBucket = mapToValuesBucket(prodDisMap);
          parseProductDisList.push(valuesBucket);
        }
      }
    }
    DatabaseManager.batchInsertTableData(context, "base_store_prod_dis", parseProductDisList);
  } catch (error) {
    WinLog.info("base_product insert error" + error)
  }
}

完美实现我想要的方法。 数据库插入报错:10-11 17:17:23.730 17950-17950 A03d00/JSAPP net.winch...l.winsfa I [INFO ] 2024-10-11 17:17:23,729 [Index:54] Winchannel--->base_product insert errorTypeError: Cannot read property length of undefined 各位有遇到?

相关推荐
2501_920931706 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
0思必得08 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5168 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino8 小时前
图片、文件的预览
前端·javascript
2501_9209317010 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman052810 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔10 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李10 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN10 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒10 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局