Dynamics CRM2016 Web API之通过实体的primary key查询记录(二)

时间:2021-06-05 10:42:26

       继续接上篇,还是通过primary key来查询数据,本篇介绍两个我个人比较喜欢的查询方式,一个是查询单个字段,一个是查询lookup关联实体中的属性字段。

    先来看如何查询单个字段,只需要在url的最后加上“/字段名",作用同表达式"?$select=字段名",前者的返回值直接取value值即可,很简洁。

$.ajax({
async: false,
type: "GET",
contentType: "application/json; charset=utf-8",
datatype: "json",
url: Xrm.Page.context.getClientUrl() + "/api/data/v8.0/accounts(" + id.replace('{', '').replace('}', '') + ")/name",
success: function (data, textStatus, XmlHttpRequest) {

var name = data.value;
},
error: function (XmlHttpRequest, textStatus, errorThrown) {
}
});

      再来看查询lookup关联实体中的属性字段

$.ajax({
async: false,
type: "GET",
contentType: "application/json; charset=utf-8",
datatype: "json",
url: Xrm.Page.context.getClientUrl() + "/api/data/v8.0/accounts(" + id.replace('{', '').replace('}', '') + ")/territoryid?$select=description",
success: function (data, textStatus, XmlHttpRequest) {

var description = data.description;
},
error: function (XmlHttpRequest, textStatus, errorThrown) {
}
});

      上述代码是取客户实体记录中相关联的区域中的说明字段,按以前odata的方式就需要通过两个retrieve,通过客户id查询到区域的lookup字段的id值,再通过这个id去查询区域实体,最后得到说明字段中的值,但有了新的API后一个表达式"/territoryid?$select=description"搞定,如果你想取区域记录的所有字段把"?$select"去掉即可,so easy。

Dynamics CRM2016 Web API之通过实体的primary key查询记录(二)

Dynamics CRM2016 Web API之通过实体的primary key查询记录(二)