1

如何使用 Javascript 和 JSON 表示法更改 CRM 中的状态/禁用记录?所有来源都使用 XML链接到http://mileyja.blogspot.cz/2011/07/set-status-or-state-of-record-using.html 。我试图让它与 JSON 一起工作,但是没有成功。以下是我的代码和返回的错误。该代码在更改其他字段时有效。

function update(oldObject,id){

   var newObject = new Object();
   newObject.statecode=oldObject.statecode; //take the state object from record of the same entity
   newObject.statuscode=oldObject.statuscode; // -||-

   newObject.statecode.Value=1;   
   newObject.statuscode.Value=2;  

   var jsonEntity = window.JSON.stringify(newObject);
   var ODataPath = serverUrl + 
      "/XRMServices/2011/OrganizationData.svc/ort_hodinyzesmluvSet(guid'" + id + "')";

   var r = new XMLHttpRequest();
   r.open("POST", ODataPath, false);
   r.setRequestHeader("Accept", "application/json");
   r.setRequestHeader("Content-Type", "application/json; charset=utf-8");
   r.setRequestHeader("X-HTTP-Method", "MERGE");
   r.onreadystatechange = function () {

     r=this;
     if (r.readyState == 4 ) {
       if (r.status == 200 || r.status == 201 || r.status == 202 || r.status==1223){
         alert('suc');
       } 
       else
         prompt('error',JSON.stringify(r));
     }

   };
   r.send(jsonEntity);

}

错误:

{
"timeout":0,
"responseXML":{},
"ontimeout":null,
"status":500,
"readyState":4,
"statusText":"Internal Server Error",
"responseText":"{\r\n\"error\": {\r\n\"code\": \"-2147187704\", \"message\": {\r\n\"lang\": \"en-US\", \"value\": \"**2 is not a valid status code for state code ort_hodinyzesmluvState.Active on ort_hodinyzesmluv**.\"\r\n}\r\n}\r\n}"
}
4

1 回答 1

1

从错误消息的外观来看,问题是您尝试分配给实体的状态码的值ort_hodinyzesmluv

一个实体的状态由两个字段描述:对于每个实体statecodestatuscode只有这两个字段的某些组合是有效的。

从您在上面发布的代码中,您正在分配:

newObject.statecode.Value=1;
newObject.statuscode.Value=2;

我建议你检查一下表格StatusMap。这包含每个实体的所有有效组合(您还需要实体 ObjectTypeCode)。

于 2012-07-04T19:58:03.897 回答