不重复的Suitescript保存搜索。
创始人
2025-01-12 13:00:07
0

在Suitescript中,可以使用N/search模块来创建和保存搜索。为了确保保存的搜索不重复,可以通过搜索名称来检查是否已存在同名的搜索,如果存在则删除它,然后再创建并保存新的搜索。

以下是一个示例代码:

/**
 * 创建并保存不重复的搜索
 * @param {string} searchName - 搜索名称
 * @param {string} searchScriptId - 搜索脚本ID
 * @param {string} searchRecordType - 搜索记录类型
 * @param {Array} searchFilters - 搜索过滤器
 * @param {Array} searchColumns - 搜索列
 * @returns {number} - 新创建搜索的ID
 */
function createAndSaveUniqueSearch(searchName, searchScriptId, searchRecordType, searchFilters, searchColumns) {
  var existingSearch = search.load({
    id: searchScriptId
  });

  // 检查是否存在同名的搜索
  var existingSearchId = search.lookupFields({
    type: search.Type.SAVED_SEARCH,
    columns: ['internalid'],
    filters: [
      ['title', 'is', searchName]
    ]
  });

  if (existingSearchId && existingSearchId.internalid) {
    // 删除同名的搜索
    search.delete({
      id: existingSearchId.internalid
    });
  }

  // 创建新的搜索
  var newSearch = search.create({
    type: search.Type.SAVED_SEARCH,
    title: searchName,
    id: searchScriptId,
    filters: searchFilters,
    columns: searchColumns
  });

  // 保存搜索
  var newSearchId = newSearch.save();

  return newSearchId;
}

// 示例用法
var searchName = "My Unique Search";
var searchScriptId = "customsearch_my_unique_search";
var searchRecordType = search.Type.CUSTOMER;
var searchFilters = [
  ['entityid', 'contains', 'ABC'],
  'AND',
  ['email', 'isnotempty', '']
];
var searchColumns = [
  search.createColumn({
    name: 'entityid',
    sort: search.Sort.ASC
  }),
  search.createColumn({
    name: 'email'
  })
];

var newSearchId = createAndSaveUniqueSearch(searchName, searchScriptId, searchRecordType, searchFilters, searchColumns);

在上面的示例中,我们首先加载已存在的搜索(如果有的话),然后使用search.lookupFields检查是否存在同名的搜索。如果存在,则使用search.delete删除它。接下来,我们使用search.create创建新的搜索,并使用save方法保存它。最后,函数返回新创建搜索的ID。

请注意,search.ScriptId参数是必需的,并且在保存搜索时将其指定为与脚本ID相同的值,以确保搜索与脚本绑定在一起。此外,创建搜索时,需要提供搜索的记录类型、过滤器和列。在示例中,我们创建了一个搜索,以查找实体ID包含"ABC"且电子邮件字段不为空的客户。

相关内容

热门资讯

不少玩家反映!衢州都莱辅助器免... 不少玩家反映!衢州都莱辅助器免费下载!好像确实有开挂辅助挂(有挂教学)-哔哩哔哩1、用户打开应用后不...
教学辅助挂!透视辅助工具!原来... 教学辅助挂!透视辅助工具!原来真的有开挂辅助app(有挂分析)-哔哩哔哩1、透视辅助工具免费辅助多个...
做出回应!仙桃晃晃辅助器!其实... 做出回应!仙桃晃晃辅助器!其实是真的有开挂辅助教程(新版有挂)-哔哩哔哩1、许多玩家不知道仙桃晃晃辅...
值得注意的是!决战卡五星最新辅... 值得注意的是!决战卡五星最新辅助!真是确实有开挂辅助方法(证实有挂)-哔哩哔哩1、值得注意的是!决战...
黑科技攻略!浙江宝宝游戏辅助器... 黑科技攻略!浙江宝宝游戏辅助器是真的嘛!真是真的是有开挂辅助脚本(有挂秘诀)-哔哩哔哩1、打开软件启...
刚刚!余干五十k攻略!切实确实... 刚刚!余干五十k攻略!切实确实有开挂辅助教程(竟然有挂)-哔哩哔哩1、超多福利:超高返利,海量正版游...
2026版攻略!川南九九辅助!... 2026版攻略!川南九九辅助!一直确实有开挂辅助攻略(有挂解密)-哔哩哔哩1)川南九九辅助免费钻石:...
此事迅速冲上热搜!哥哥打大a有... 此事迅速冲上热搜!哥哥打大a有没有辅助!一贯是真的有开挂辅助脚本(有挂秘籍)-哔哩哔哩1、该软件可以...
2026版规律!约局吧透视辅助... 2026版规律!约局吧透视辅助ios下载!一直真的有开挂辅助技巧(今日头条)-哔哩哔哩约局吧透视辅助...
2026版辅助挂!胡乐辅助脚本... 2026版辅助挂!胡乐辅助脚本是真的假的!切实真的是有开挂辅助app(有挂透视)-哔哩哔哩进入游戏-...