CRM2016启用了webapi 而弃用了odata,作为码农的我们又开始学习新东西了。
下面是一段简单的查询代码,通过systemuser的primary key来查询一条记录
Web API查询方式
var userId = Xrm.Page.getAttribute("ownerid").getValue()[0].id; var appellation; $.ajax({ async: false, type: "GET", contentType: "application/json; charset=utf-8", datatype: "json", url: Xrm.Page.context.getClientUrl() + "/api/data/v8.0/systemusers(" + userId.replace('{', '').replace('}', '') + ")", success: function (data, textStatus, XmlHttpRequest) { appellation = data.lastname + data.firstname + '-' + data.salutation; }, error: function (XmlHttpRequest, textStatus, errorThrown) { } });
这里我查询的是全部字段,如果是要查询指定字段写法参考sdk
odata的查询方式
var userId = Xrm.Page.getAttribute("ownerid").getValue()[0].id; var appellation; $.ajax({ async: false, type: "GET", contentType: "application/json; charset=utf-8", datatype: "json", url: Xrm.Page.context.getClientUrl() + "/XRMServices/2011/OrganizationData.svc/SystemUserSet(guid'" + userId + "')", success: function (data, textStatus, XmlHttpRequest) { appellation = data.d.lastname + data.d.firstname + '-' + data.d.salutation; }, error: function (XmlHttpRequest, textStatus, errorThrown) { } }); }
通过上述两种方式的代码中可以看到些许的差别,主要是在url和返回json数据的处理上,当然这只是最简单的R,还有复杂的R还有CUD需要慢慢去探索。