事务高级搜索NetSuite中的销售订单,当使用otherRefNum Operator时返回错误

时间:2013-08-20 20:13:26

标签: web-services wsdl netsuite

知道为什么下面的代码会为其状态返回错误(失败)吗?

    private SearchResult getTxns()
    {
        TransactionSearchAdvanced tsa = new TransactionSearchAdvanced();

        tsa.columns = new TransactionSearchRow();

        tsa.columns.basic = new TransactionSearchRowBasic();
        tsa.columns.basic.tranId = new SearchColumnStringField[] { new SearchColumnStringField() };

        tsa.criteria = new TransactionSearch();
        tsa.criteria.basic = new TransactionSearchBasic();

        tsa.criteria.basic.mainLine = new SearchBooleanField();
        tsa.criteria.basic.mainLine.searchValue = true;
        tsa.criteria.basic.mainLine.searchValueSpecified = true;

        tsa.criteria.basic.type = new SearchEnumMultiSelectField();
        tsa.criteria.basic.type.@operator = SearchEnumMultiSelectFieldOperator.anyOf;
        tsa.criteria.basic.type.operatorSpecified = true;
        tsa.criteria.basic.type.searchValue = new string[] { "_salesOrder" };

        tsa.criteria.basic.otherRefNum = new SearchTextNumberField();
        tsa.criteria.basic.otherRefNum.@operator = SearchTextNumberFieldOperator.equalTo;
        tsa.criteria.basic.type.operatorSpecified = true;
        tsa.criteria.basic.type.searchValue = new string[] { "BBnB 1001" };

        SearchResult sr = _service.search(tsa);

        return sr;
    }

以下是结果中返回的错误。

状态代码: INVALID_SEARCH_OPERATOR
状态消息:您需要提供有效的搜索字段操作符。

但是,当我进行搜索时,此运算符会出现在NetSuite UI中。另外,我在NetSuite文档here中找到它。

我正在使用v2013_1_0作为wsdl的webservices版本。

发现解决方案位于最后一段代码中。试图设置otherRefNum并引用Type。这是更正后的代码。

    private SearchResult getTxns()
    {
        TransactionSearchAdvanced tsa = new TransactionSearchAdvanced();

        tsa.columns = new TransactionSearchRow();

        tsa.columns.basic = new TransactionSearchRowBasic();
        tsa.columns.basic.tranId = new SearchColumnStringField[] { new SearchColumnStringField() };

        tsa.criteria = new TransactionSearch();
        tsa.criteria.basic = new TransactionSearchBasic();

        tsa.criteria.basic.mainLine = new SearchBooleanField();
        tsa.criteria.basic.mainLine.searchValue = true;
        tsa.criteria.basic.mainLine.searchValueSpecified = true;

        tsa.criteria.basic.type = new SearchEnumMultiSelectField();
        tsa.criteria.basic.type.@operator = SearchEnumMultiSelectFieldOperator.anyOf;
        tsa.criteria.basic.type.operatorSpecified = true;
        tsa.criteria.basic.type.searchValue = new string[] { "_salesOrder" };

        tsa.criteria.basic.otherRefNum = new SearchTextNumberField();
        tsa.criteria.basic.otherRefNum.@operator = SearchTextNumberFieldOperator.equalTo;
        tsa.criteria.basic.otherRefNum.operatorSpecified = true;
        tsa.criteria.basic.otherRefNum.searchValue = "BBnB 1001";

        SearchResult sr = _service.search(tsa);

        return sr;
    }

1 个答案:

答案 0 :(得分:1)

问题在于您的SearchEnumMultiSelectField运营商。 equalto不是此过滤器的有效运算符;您需要使用anyOf代替。

- 编辑 - 改编自原始评论 -

SearchTextNumberField不接受字符串数组。而是尝试tsa.criteria.basic.otherRefNum.searchValue = "BBnB 1001";