过滤器 SuiteScript 2.0 (NetSuite) 上的运算符 'and' & 'or'
Operators 'and' & 'or' on filters SuiteScript 2.0 (NetSuite)
我需要在我的搜索过滤器上设置条件。我浏览了很多论坛都没有找到功能解决方案。经过多次不确定的测试后,我向您寻求帮助。
我的代码:
function retrieveVendor(vendorValues){
var subsidiaryIdFilter = SEARCHMODULE.createFilter({
name: 'internalid',
join: 'subsidiary',
operator: SEARCHMODULE.Operator.ANYOF,
values: vendorValues.companyCode
});
var addressFilter = SEARCHMODULE.createFilter({
name: 'address',
join: 'vendor',
operator: SEARCHMODULE.Operator.CONTAINS,
values: vendorValues.street
});
var cityFilter = SEARCHMODULE.createFilter({
name: 'city',
join: 'vendor',
operator: SEARCHMODULE.Operator.CONTAINS,
values: vendorValues.city
});
var zipFilter = SEARCHMODULE.createFilter({
name: 'zipcode',
join: 'vendor',
operator: SEARCHMODULE.Operator.CONTAINS,
values: vendorValues.postalCode
});
var vendorIdTest = SEARCHMODULE.create({
type: SEARCHMODULE.Type.VENDOR_SUBSIDIARY_RELATIONSHIP,
columns: [
SEARCHMODULE.createColumn({name:'entityid', join: 'vendor'}),
SEARCHMODULE.createColumn({name:'internalid', join: 'subsidiary'}),
SEARCHMODULE.createColumn({name:'address', join: 'vendor'})
],
filters: [
subsidiaryIdFilter, 'and', [addressFilter, 'or', zipFilter]
]
});
var nbOfResults = vendorIdTest.runPaged().count;
var resultArray = [];
var aa = vendorIdTest.run().each(function(result){
var obj ={};
obj['vendorName'] = result.getValue({
name: 'entityid',
join: 'vendor'
});
obj['idOfSubsidiary'] = result.getValue({
name: 'internalid',
join: 'subsidiary'
});
obj['vendorAddress'] = result.getValue({
name: 'address',
join: 'vendor'
});
resultArray.push(obj);
return true;
});
var result = nbOfResults + ' : ' + JSON.stringify(resultArray);
return result;
}
下面是我搜索的 'filters' 参数上尝试的所有语法:
subsidiaryIdFilter, 'and', [addressFilter, 'or', zipFilter]
[subsidiaryIdFilter, 'and', [addressFilter, 'or', zipFilter]]
subsidiaryIdFilter, 'and', (addressFilter, 'or', zipFilter)
subsidiaryIdFilter && (addressFilter, 'or', zipFilter)
subsidiaryIdFilter && (addressFilter || zipFilter)
我当然在 SuiteScript 文档中进行了搜索,但没有提及此主题。感谢您的帮助。
实际上并不是这样。使用 search.createFilter 创建的过滤器都隐含地与在一起。
您需要的是具有不同语法的过滤器表达式。您不能混合过滤器和过滤器表达式,因此:
var vendorIdTest = SEARCHMODULE.create({
type: SEARCHMODULE.Type.VENDOR_SUBSIDIARY_RELATIONSHIP,
columns: [
SEARCHMODULE.createColumn({name:'entityid', join: 'vendor'}),
SEARCHMODULE.createColumn({name:'internalid', join: 'subsidiary'}),
SEARCHMODULE.createColumn({name:'address', join: 'vendor'})
],
filters: [
['subsidiary', 'anyof', vendorValues.companyCode], 'AND',
[
[
['vendor.address', 'contains', vendorValues.street ], 'AND',
['vendor.city', 'is', vendorValues.city] // i'm guessing you meant to include this
], 'OR',
['vendor.zipcode', 'contains', vendorValues.postalCode]
]
]
});
感谢插件 (https://chrome.google.com/webstore/detail/netsuite-search-export/gglbgdfbkaelbjpjkiepdmfaihdokglp),我找到了在带有连接的过滤器之间放置 AND 和 OR 的语法:
var subsidiaryIdFilter = ["subsidiary.internalid", "anyof", vendorValues.companyCode];
var addressFilter = ["vendor.addresslabel", "contains", vendorValues.street];
var cityFilter = ["vendor.city", "contains", vendorValues.city];
var vendorNameFilter = ["vendor.entityid", "contains", vendorValues.name];
var zipFilter = ["vendor.zipcode", "contains", vendorValues.postalCode];
var addressSearch = SEARCHMODULE.create({
type: SEARCHMODULE.Type.VENDOR_SUBSIDIARY_RELATIONSHIP,
columns: [
SEARCHMODULE.createColumn({name:'entityid', join: 'vendor', sort : SEARCHMODULE.Sort.ASC})
],
filters: [
subsidiaryIdFilter, "AND", [zipFilter, "OR", cityFilter, "OR", addressFilter]
]
});
我需要在我的搜索过滤器上设置条件。我浏览了很多论坛都没有找到功能解决方案。经过多次不确定的测试后,我向您寻求帮助。 我的代码:
function retrieveVendor(vendorValues){
var subsidiaryIdFilter = SEARCHMODULE.createFilter({
name: 'internalid',
join: 'subsidiary',
operator: SEARCHMODULE.Operator.ANYOF,
values: vendorValues.companyCode
});
var addressFilter = SEARCHMODULE.createFilter({
name: 'address',
join: 'vendor',
operator: SEARCHMODULE.Operator.CONTAINS,
values: vendorValues.street
});
var cityFilter = SEARCHMODULE.createFilter({
name: 'city',
join: 'vendor',
operator: SEARCHMODULE.Operator.CONTAINS,
values: vendorValues.city
});
var zipFilter = SEARCHMODULE.createFilter({
name: 'zipcode',
join: 'vendor',
operator: SEARCHMODULE.Operator.CONTAINS,
values: vendorValues.postalCode
});
var vendorIdTest = SEARCHMODULE.create({
type: SEARCHMODULE.Type.VENDOR_SUBSIDIARY_RELATIONSHIP,
columns: [
SEARCHMODULE.createColumn({name:'entityid', join: 'vendor'}),
SEARCHMODULE.createColumn({name:'internalid', join: 'subsidiary'}),
SEARCHMODULE.createColumn({name:'address', join: 'vendor'})
],
filters: [
subsidiaryIdFilter, 'and', [addressFilter, 'or', zipFilter]
]
});
var nbOfResults = vendorIdTest.runPaged().count;
var resultArray = [];
var aa = vendorIdTest.run().each(function(result){
var obj ={};
obj['vendorName'] = result.getValue({
name: 'entityid',
join: 'vendor'
});
obj['idOfSubsidiary'] = result.getValue({
name: 'internalid',
join: 'subsidiary'
});
obj['vendorAddress'] = result.getValue({
name: 'address',
join: 'vendor'
});
resultArray.push(obj);
return true;
});
var result = nbOfResults + ' : ' + JSON.stringify(resultArray);
return result;
}
下面是我搜索的 'filters' 参数上尝试的所有语法:
subsidiaryIdFilter, 'and', [addressFilter, 'or', zipFilter]
[subsidiaryIdFilter, 'and', [addressFilter, 'or', zipFilter]]
subsidiaryIdFilter, 'and', (addressFilter, 'or', zipFilter)
subsidiaryIdFilter && (addressFilter, 'or', zipFilter)
subsidiaryIdFilter && (addressFilter || zipFilter)
我当然在 SuiteScript 文档中进行了搜索,但没有提及此主题。感谢您的帮助。
实际上并不是这样。使用 search.createFilter 创建的过滤器都隐含地与在一起。
您需要的是具有不同语法的过滤器表达式。您不能混合过滤器和过滤器表达式,因此:
var vendorIdTest = SEARCHMODULE.create({
type: SEARCHMODULE.Type.VENDOR_SUBSIDIARY_RELATIONSHIP,
columns: [
SEARCHMODULE.createColumn({name:'entityid', join: 'vendor'}),
SEARCHMODULE.createColumn({name:'internalid', join: 'subsidiary'}),
SEARCHMODULE.createColumn({name:'address', join: 'vendor'})
],
filters: [
['subsidiary', 'anyof', vendorValues.companyCode], 'AND',
[
[
['vendor.address', 'contains', vendorValues.street ], 'AND',
['vendor.city', 'is', vendorValues.city] // i'm guessing you meant to include this
], 'OR',
['vendor.zipcode', 'contains', vendorValues.postalCode]
]
]
});
感谢插件 (https://chrome.google.com/webstore/detail/netsuite-search-export/gglbgdfbkaelbjpjkiepdmfaihdokglp),我找到了在带有连接的过滤器之间放置 AND 和 OR 的语法:
var subsidiaryIdFilter = ["subsidiary.internalid", "anyof", vendorValues.companyCode];
var addressFilter = ["vendor.addresslabel", "contains", vendorValues.street];
var cityFilter = ["vendor.city", "contains", vendorValues.city];
var vendorNameFilter = ["vendor.entityid", "contains", vendorValues.name];
var zipFilter = ["vendor.zipcode", "contains", vendorValues.postalCode];
var addressSearch = SEARCHMODULE.create({
type: SEARCHMODULE.Type.VENDOR_SUBSIDIARY_RELATIONSHIP,
columns: [
SEARCHMODULE.createColumn({name:'entityid', join: 'vendor', sort : SEARCHMODULE.Sort.ASC})
],
filters: [
subsidiaryIdFilter, "AND", [zipFilter, "OR", cityFilter, "OR", addressFilter]
]
});