一、批量插入/创建

使用 record.create() 插入数据时,一次只能插入一条,有多条数据需要插入时只能通过循环的方式,这样效率非常慢,耗时会随着数据量的增大而呈线性增长,有一种巧妙的方式可以进行批量插入:利用父子关系来批量插入,该方式可以显著提升效率,还节约了用量(usage),并且还可以实现事务处理中 commit 跟 rollback 的功能

实现原理:

假设该自定义记录类型为 A,创建一个父记录类型 B( B 没有实际业务意义),建立 A 跟 B 的父子关系,当要多次循环使用 record.create 创建 A 记录时,可以用父子关系的插入方式改为:使用 record.create() 创建 B 记录,使用 record.setSublistValue() 循环设置 A 记录的值,这样只需要使用 record.save() 提交一次记录,大大节约了跟数据库交互的次数

常规插入代码:

var rec = record.create({
type : 'salesorder'
});
rec.setValue({
fieldId : 'entity',
value : header.entity
});
var id = rec.save();

批量插入代码:

var rec = record.create({
type : 'customrecord_test_batch_parent',
isDynamic : false
});
var sublist = 'recmachcustrecord_tb_parent';
for (var i = 0; i < 100; i++) {
  rec.setSublistValue({
      sublistId : sublist,
      fieldId : 'custrecord_tb_name',
      value : 'zs' + i,
      line : i
  });
  rec.setSublistValue({
      sublistId : sublist,
      fieldId : 'custrecord_tb_addr',
      value : 'beijing' + i,
      line : i
  });
  rec.setSublistValue({
      sublistId : sublist,
      fieldId : 'custrecord_tb_email',
      value : i + '@qq.com',
      line : i
  });
}
rec.save();

二、批量更新

var rec = record.create({

  type : 'customrecord_test_batch_parent', 

  isDynamic : false

});

var parentId = rec.save(); 

var parentRec = record.load({

  type : 'customrecord_test_batch_parent',

    id : parentId,

  isDynamic : false

});

var sublist = 'recmachcustrecord_tb_parent';

var idAry = [ 21, 121 ];

for (var i = 0; i < idAry.length; i++) { 

  parentRec.setSublistValue({

  sublistId : sublist, 

    fieldId : 'id',

    value : idAry[i],

    line : i

}); 

  parentRec.setSublistValue({

  sublistId : sublist,

  fieldId : 'custrecord_tb_name', 

    value : 'zs007',

  line : i

}); 

  parentRec.setSublistValue({

  sublistId : sublist,

  fieldId : 'custrecord_tb_addr',

    value : 'beijing007',

  line : i

}); 

  parentRec.setSublistValue({

  sublistId : sublist,

  fieldId : 'custrecord_tb_email', 

    value : '007@qq.com',

  line : i

  }); 

}

parentRec.save();

其中第一个 setSublistValue 的字段是固定为 id,也就是设置内部 id 的值「每一条行数据都是独立的自定义记录」。

特别注意如下几点:

  • 现象:如果不给必输字段赋值,会报“请输入XXX的值”这样的错误,即使要更新的数据这些字段都是有值的也会报

    解决办法:

    A. 每次都给必输字段设置值(用 search.lookupFields() 查出来在赋值上去即可);

    B. 取消必输设置,改为在表格上设置必输
  • 现象:用 setSublistValue 只设置了需要更新字段的值,但是发现有些其他没有赋值字段的值自动清空了

    分析:字段勾选了“在列表中显示”,则该记录作为子列表时,该字段会显示在行上,此时如果未赋值,就会自动清空

    解决办法:

    A. 每次都给这些字段设置值。

    B. 不要勾选“在列表中显示”,需要显示在列表的字段通过视图来配置
  • 现象:类型为“多项选择”的字段,如果没有给他赋值会自动清空

    解决办法:每次都给多项选择字段设置值
  • 现象:非活动字段不能通过父子关系来赋值

    解决办法:暂无

三、批量删除

var subListId = 'recmachcustrecord_tb_parent'; 

var rec = record.create({

  type : 'customrecord_test_batch_parent',

  isDynamic : true

});

var parentId = rec.save();

var parentRec = record.load({

  type : 'customrecord_test_batch_parent', 

    id : parentId,

  isDynamic : true

});

var ids = [ 1, 11 ];

for (var i = 0; i < ids.length; i++) {

  parentRec.selectNewLine({ 

      sublistId : subListId

}); 

  parentRec.setCurrentSublistValue({

  sublistId : subListId,

    fieldId : 'id',

  value : ids[i]

  });

  parentRec.commitLine({

  sublistId : subListId

  });

}

parentRec.save();

// 删除

var currentRec = record.load({

  type : 'customrecord_test_batch_parent',

  id : parentId

});

for (var x = 0; x < currentRec.getLineCount({ sublistId : subListId

});) { 

  currentRec.removeLine({

  sublistId : subListId,

  line : x

  });

} 

currentRec.save();

四、其它说明

  1. 对于日期时间、数值类型的字段,是否勾选“在列表中显示”,批量创建时赋值是会有区别的

    1. 日期类型字段不勾选”在列表中显示“,赋值时会报错"type":"error.SuiteScriptError","name":"DATE_EXPECTED","message":"You entered 'null' into a field where a calendar date was expected.\nPlease go back and change this value to the correct date.”
    2. 小数类型字段赋值需要使用数字字符串,否则赋不上值
  2. parent记录会越来越多,可以在操作完成后删除,操作方式:将头行关联字段设置为“运行相关字段并将其值设置为空”
  3. 子记录不勾选“允许子记录编辑”报错:"type":"error.SuiteScriptError","name":"UNEXPECTED_ERROR","message":null,"stack":["anonymous(N/serverRecordService)……
  4. 父子记录的权限不一致(访问类型不同)报错:"type":"error.SuiteScriptError","name":"UNEXPECTED_ERROR","message":null,"stack":["anonymous(N/serverRecordService)……

NetSuite 开发日记:批量增删改的更多相关文章

  1. OracleHelper(对增删改查分页查询操作进行了面向对象的封装,对批量增删改操作的事务封装)

    公司的一个新项目使用ASP.NET MVC开发,经理让我写个OracleHelper,我从网上找了一个比较全的OracleHelper类,缺点是查询的时候返回DataSet,数据增删改要写很多代码(当 ...

  2. entity framework 5 批量增删改效率优化

    对于数据的批量增删改最慢的就是操作一条就提交一次事务. 以下是对增删改操作的优化测试 同样的300条数据 批量新增只提交一次事务 用时:10673.5444ms 批量新增只提交一次事务并把contex ...

  3. 使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序

    使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序 不定时更新翻译系列,此系列更新毫无时间规律,文笔菜翻译菜求各位看官老爷们轻 ...

  4. Elasticsearch学习笔记(十)批量查询mget、批量增删改bulk

    一.批量查询  mget             GET /_mget {   "docs":[       {         "_index":" ...

  5. MYSQL冷知识——ON DUPLICATE KEY 批量增删改

    一 有个需求要批量增删改,并且是混合的,也就是仅不存在才增. 删简单,因为有个deleteStaute之类的字段,删除本质上就是就是一个修改 所以就是实现批量混合增改,然而组长说mysql不支持混合增 ...

  6. Elasticsearch由浅入深(六)批量操作:mget批量查询、bulk批量增删改、路由原理、增删改内部原理、document查询内部原理、bulk api的奇特json格式

    mget批量查询 批量查询的好处就是一条一条的查询,比如说要查询100条数据,那么就要发送100次网络请求,这个开销还是很大的如果进行批量查询的话,查询100条数据,就只要发送1次网络请求,网络请求的 ...

  7. 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_3-2.使用Mybatis注解开发视频列表增删改查

    笔记 2.使用Mybatis注解开发视频列表增删改查     讲解:使用Mybatis3.x注解方式 增删改查实操, 控制台打印sql语句              1.控制台打印sql语句      ...

  8. 基于gin的golang web开发:mysql增删改查

    Go语言访问mysql数据库需要用到标准库database/sql和mysql的驱动.标准库的Api使用比较繁琐这里再引入另一个库github.com/jmoiron/sqlx. go get git ...

  9. Mock.js简易教程,脱离后端独立开发,实现增删改查功能(转)

    在我们的生产实际中,后端的接口往往是较晚才会出来,并且还要写接口文档,于是我们的前端的许多开发都要等到接口给我们才能进行,这样对于我们前端来说显得十分的被动,于是有没有可以制造假数据来模拟后端接口呢, ...

  10. MyBatis批量增删改查操作

      前文我们介绍了MyBatis基本的增删该查操作,本文介绍批量的增删改查操作.前文地址:http://blog.csdn.net/mahoking/article/details/43673741 ...

随机推荐

  1. 微信小程序 setData accepts an Object rather than some undefined 解决办法

    问题 setData accepts an Object rather than some undefined setData接受一个对象而不是一些定义 让我猜猜, 你一定是在加载index页面(首页 ...

  2. 小知识:PPT的幻灯片放映设置

    最近给某客户讲课时,碰到了幻灯片自动翻页的情况,发现是因为之前做过粗略的计时演练,有些片子就快速过了. 问题现象: 结果导致放映时也出现了某些片子快速被自动翻页. 解决方案: 设置成手动推进幻灯片的方 ...

  3. JDK21来了!附重要更新说明

    JDK21 计划23年9月19日正式发布,虽然一直以来都是"版本随便出,换 8 算我输",但这么多年这么多版本的折腾,如果说之前的 LTS版本JDK17你还觉得不香,那 JDK21 ...

  4. 记一次 .NET 某电力系统 内存暴涨分析

    一:背景 1. 讲故事 前些天有位朋友找到我,说他生产上的程序有内存暴涨情况,让我帮忙看下怎么回事,最简单粗暴的方法就是让朋友在内存暴涨的时候抓一个dump下来,看一看大概就知道咋回事了. 二:Win ...

  5. 织梦DedeCMS文章内容页调用标签方法教程

    织梦DedeCMS是新手站长使用比较多的建站软件,其模板制作也比较方便,一些站长朋友对其模板调用标签不是太熟悉,小编为大家介绍下织梦文章内容页调用标签的方法. 1.调用文章标题: {dede:fiel ...

  6. Linux下jdk配置

    1.首先执行以下命令查看可安装的jdk版本: yum -y list java* ​ 执行成功后可看到如下界面: 2.选择自己需要的jdk版本进行安装,比如这里安装1.8,执行以下命令: yum in ...

  7. Xshell远程连接、MBR/BOOT和GRUB三者关系总结(系统启动过程)

    远程连接 远程连接Linux服务器的常见工具有Xshell.SecureCRT.Putty等,这些客户端连接工具在Linux服务器对应着相同SSH服务进程sshd,即远程连接都是使用SSH协议,当然它 ...

  8. The method dismissDialog(int) from the type Activity is deprecated

    The method showDialog(int) from the type Activity is deprecated in android?   up vote6down votefavor ...

  9. Linux 中如何安全地抹去磁盘数据?

    哈喽大家好,我是咸鱼 离过职的小伙伴都知道,离职的时候需要上交公司电脑,但是电脑里面有许多我们的个人信息(聊天记录.浏览记录等等) 所以我们就需要先把这些信息都删除,确保无法恢复之后才上交 即有些情况 ...

  10. [NISACTF 2022]level-up

    [NISACTF 2022]level-up 查看源码,根据这个提示就可以反应出是需要去访问robots.txt这个文件 访问level_2_1s_h3re.php进入第二关 需要post进去arra ...