2012-06-19 5 views
0

예상되는 동작 : 사용자가 등록 버튼을 클릭하고 관련 엔터티에 레코드가 생성됩니다. 이것은 지금까지 효과가 있었지만 현재는 현재 양식에 대한 조회를 기반으로 외래 키를 업데이트해야합니다. 어떻게해야합니까? 아래의 붙여 넣은 코드는 브라우저에서 오류를 발생시킵니다. "오류 - 잘못된 요청입니다."odata json으로 외래 키를 업데이트하는 방법

// JScript source code 
CreateButton = function() { 
    var fieldTable = crmForm.all.new_registerbutton_d; 
    var html = "<TABLE border=0 cellSpacing=0 cellPadding=0><TBODY><TR><TD width=0px>" + fieldTable.innerHTML + "</TD><TD width=200><INPUT style='BACKGROUND-COLOR: #d8e8ff' onclick=Button_OnClick() value='Register' type=button></TD></TR></TBODY></TABLE>"; 

    fieldTable.innerHTML = html; 
    document.all.new_registerbutton.style.display = 'none'; 
    crmForm.all.new_registerbutton_c.innerText = ""; 
} 

Button_OnClick = function() { 

    //var new_se_registration = new Object(); 
    var invitationName = Xrm.Page.getAttribute("new_name").getValue(); 
    //new_se_registration.new_name = invitationName; 

    var invitationGUID = Xrm.Page.data.entity.getId().replace('{', '').replace('}', ''); 
    alert(invitationGUID); 
    var value = new Array(); 
    value[0] = new Object(); 
    value[0].id = invitationGUID; 
    value[0].name = invitationName; 
    //var invitation = { 
    //id: invitationGUID, name: invitationName, entityType: "new_se_registration" 
    //}; 
    //var invitation= { Id: invitationGUID, LogicalName: "new_se_registration", Name: invitationName }; 
    //value[0].entityType = Xrm.Page.data.entity.getEntityType(); 
    //new_se_registration.new_new_se_invitation_new_se_registid.setValue([{ id: invitationGUID, name: invitationName, entityType: "new_se_registration"}]); 
    //new_se_registration.new_new_se_invitation_new_se_registid = invitation; 

    //new_se_registration.new_eventname= Xrm.Page.getAttribute("new_eventname").getValue(); 
    //new_invitationid is the Event id 
    var lookupItem = new Array; 
    lookupItem = crmForm.all.new_invitationid.DataValue; 
    var eventname = lookupItem[0].name; 
    //new_se_registration.new_eventname = eventname; 

    lookupItem = crmForm.all.new_invitationid.DataValue; 

    var new_se_registration = { 

     new_new_se_invitation_new_se_registid: { 
     __metadata: { type: "Microsoft.Crm.Sdk.Data.Services.EntityReference" }, 
     Id: invitationGUID, 
     LogicalName: invitationName 
     }, 

     new_name: invitationName, 
     new_eventname: eventname 
    }; 

    //alert ( eventname); 

    // end Ek - adding event name 

    //deleteRecord(new_se_registration.new_name, "new_se_registrationSet"); 

    var reg = Xrm.Page.getAttribute("new_registered").getValue(); 



    if (reg == null) { 
     reg = "N"; 
    } 


    if (reg != "Y") { 

     //Xrm.Page.getAttribute("new_registered").setValue("Y"); 
     //alert(reg); 
     //return; 

     createRecord(new_se_registration, "new_se_registrationSet", RegisterCompleted, null); 
     Xrm.Page.getAttribute("new_registered").setValue("Y"); 
     //Xrm.Page.data.entity.attributes.get("new_registered").setSubmitMode("always"); 
     //Xrm.Page.data.entity.save(); 
    } 
    else { 
     alert("\"" + Xrm.Page.getAttribute("new_name").getValue() + "\" has been registered already."); 
    } 
} 


function RegisterCompleted(data, textStatus, XmlHttpRequest) { 
    var new_se_registration = data; 
    Xrm.Page.data.entity.save(); 
    alert("\"" + Xrm.Page.getAttribute("new_name").getValue() + "\" has been registered successfully."); 
} 

function checkDuplicate() { 
    alert("test"); 
} 

function deleteRecord(id, odataSetName) { 

    var serverUrl = Xrm.Page.context.getServerUrl(); 
    var ODATA_ENDPOINT = "/XRMServices/2011/OrganizationData.svc"; 

    $.ajax({ 

     type: "POST", 
     contentType: "application/json; charset=utf-8", 
     datatype: "json", 
     url: serverUrl + ODATA_ENDPOINT + "/" + odataSetName + "(guid'" + id + "')", 
     beforeSend: function (XMLHttpRequest) { 

      //XMLHttpRequest.setRequestHeader("Accept", "application/json"); 
      XMLHttpRequest.setRequestHeader("X-HTTP-Method", "DELETE"); 
     }, 

     success: function (data, textStatus, XmlHttpRequest) { 
      alert("Record deleted successfully!"); 
     }, 

     error: function (XmlHttpRequest, textStatus, errorThrown) { 
      alert("Error while deletion – " + errorThrown); 
     } 
    }); 
} 


function createRecord(entityObject, odataSetName, successCallback, errorCallback) { 

    var jsonEntity = window.JSON.stringify(entityObject); 
    var serverUrl = Xrm.Page.context.getServerUrl(); 
    var ODATA_ENDPOINT = "/XRMServices/2011/OrganizationData.svc"; 

    $.ajax({ 

     type: "POST", 
     contentType: "application/json; charset=utf-8", 
     datatype: "json", 
     url: serverUrl + ODATA_ENDPOINT + "/" + odataSetName, 
     data: jsonEntity, 
     beforeSend: function (XMLHttpRequest) { 
      XMLHttpRequest.setRequestHeader("Accept", "application/json"); 
     }, 

     success: function (data, textStatus, XmlHttpRequest) { 
      if (successCallback) { 
       successCallback(data.d, textStatus, XmlHttpRequest); 
      } 
     }, 

     error: function (XmlHttpRequest, textStatus, errorThrown) { 

      if (errorCallback) 
       errorCallback(XmlHttpRequest, textStatus, errorThrown); 
      else 
       alert("Error on the creation of record; Error – " + errorThrown); 
     } 

    }); 

} 

답변

1

해결되었습니다. 대소 문자 구분. new_new_se_invitation_new_se_registId에 대소 문자를 잘못 사용했습니다.

var new_se_registration = { 

    new_new_se_invitation_new_se_regist**I**d: { 
    __metadata: { type: "Microsoft.Crm.Sdk.Data.Services.EntityReference" }, 
    Id: invitationGUID, 
    LogicalName: invitationName 
    }, 

    new_name: invitationName, 
    new_eventname: eventname 
}; 
관련 문제