按Netsuite中的自定义字段搜索客户


Search Customer by custom field in Netsuite

我能够使api在php中工作,并通过内部id搜索客户。然而,我有一个场景,我将通过自定义字段搜索客户。在"客户"下,它有一个自定义选项卡,其中包含多个域名和域详细信息。

例如:

主要搜索条件:域名

这在netsuitephpapi中是怎么可能的?非常感谢您的帮助。我只是NetSuite的新手。我将如何修改此示例代码以按自定义字段进行搜索?

$service = new NetSuiteService();
$request = new GetRequest();
$request->baseRef = new RecordRef();
$request->baseRef->internalId = "1780";
$request->baseRef->type = "customer";
$getResponse = $service->get($request);
if (!$getResponse->readResponse->status->isSuccess) {
    echo "GET ERROR";
} else {
    $customer = $getResponse->readResponse->record;
    //var_dump($customer);
    echo "GET SUCCESS, customer:";
    echo "'nCompany name: ". $customer->companyName;
    echo "'nInternal Id: ". $customer->internalId;
    echo "'nEmail: ". $customer->email;
    echo "'nCustomerID: ". $customer->firstName;
}

好的,我正在尝试从egrubaugh360获取所有域名库的自定义记录。

$service = new NetSuiteService();
$request = new GetRequest();
$request->baseRef = new CustomRecordRef();
$request->baseRef->internalId = "47";
//$request->baseRef->externalId = "xxxx";
$request->baseRef->typeId = "custom_list_domains";
$getResponse = $service->get($request);
var_dump($getResponse);
if (!$getResponse->readResponse->status->isSuccess) {
    echo "GET ERROR";
} else {
    var_dump($getResponse->readResponse->record);
    echo "GET SUCCESS";
}

我不知道该在"typeId"中放什么,该放什么类型?它给我错误"无效的自定义记录类型密钥"

object(GetResponse)#8 (1) { ["readResponse"]=> object(ReadResponse)#9 (2) { ["status"]=> object(Status)#10 (2) { ["statusDetail"]=> array(1) { [0]=> object(StatusDetail)#11 (3) { ["code"]=> string(26) "INVALID_CSTM_RCRD_TYPE_KEY" ["message"]=> string(31) "Invalid custom record type key." ["type"]=> string(5) "ERROR" } } ["isSuccess"]=> bool(false) } ["record"]=> NULL } }

下面是一个通过自定义字段搜索客户的一般示例。

您可以根据需要进行修改。

$NSservice = new NetSuiteService();
$NSservice->setSearchPreferences(false, 10);
$cs = new CustomerSearch();
$csb = new CustomerSearchBasic();
$domain = new SearchCustomStringField();
$domain->internalId = 'yourcustomfieldinternalid';
$domain->searchValue = 'text you are searching for';
$domain->operator = 'is';
$scfl = new SearchCustomFieldList();
$scfl->customField = array($domain);
$csb->customFieldList = $scfl;
$cs->basic = $csb;
$request = new SearchRequest();
$request->searchRecord = $cs;
$searchResponse = $NSservice->search($request);

您将希望执行SearchRequest,而不是执行GetRequest。您的$request应成为CustomerSearchBasic对象。然后可以使用$request->customFieldList添加SearchCustom*Field过滤器的列表。例如,如果要筛选的自定义字段是文本字段,则构建一个新的SearchCustomStringField。然后您将使用$service->search($request);来执行搜索。有关完整的PHP工具包文档,请参阅此处。

听起来你的域名实际上可能是一个自定义的子列表,而不仅仅是一个定制的字段。如果是这种情况,您将希望搜索自定义域记录,而不是客户记录。然后,您可以查找客户为1780的所有域,以及您可能需要的任何其他筛选器。

根据预览,代码客户按自定义字段搜索,在行下仅1个问题。

$domain=new SearchCustomStringField();

替换:

$domain=new SearchStringCustomField();