Delen via


Query voor gegevens uitvoeren met de web-API voor portals

U kunt beschikbare web-API-bewerkingen in Power Pages gebruiken. Web-API-bewerkingen bestaan uit HTTP-aanvragen en -reacties. Dit artikel biedt voorbeelden van leesbewerkingen, methoden, URI en het voorbeeld van het JSON-bestand dat u in de HTTP-aanvraag kunt gebruiken.

Vereisten

  • Uw websiteversie moet 9.4.1.x of hoger zijn.

  • Schakel tabel en veld in voor web API-bewerkingen. Meer informatie: Site-instellingen voor de web-API

  • De web-API voor portals heeft toegang tot tabelrecords en volgt de tabelmachtigingen die aan gebruikers zijn gegeven via de toegewezen webrollen. Zorg ervoor dat u de juiste tabelmachtigingen configureert. Meer informatie: Webrollen maken.

Notitie

Als wordt verwezen naar Dataverse-tabellen met behulp van de web-API voor portals, moet u de EntitySetName gebruiken, bijvoorbeeld om toegang te krijgen tot de account-tabel, gebruikt de codesyntaxis de EntitySetName van accounts.

Records opvragen

In het volgende voorbeeld worden accountrecords opgehaald:

Bewerking Methode URI
Tabelrecords ophalen GET [Portal URI]/_api/accounts

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts

Voorbeeldrespons

{
"value": [
    {
    "@odata.etag": "W/\"1066412\"",
    "name": "Fourth Coffee (sample)",
    "accountid": "d2e11ba8-92f6-eb11-94ef-000d3a5aa607"
    },
    {
    "@odata.etag": "W/\"1066413\"",
    "name": "Litware, Inc. (sample)",
    "accountid": "d4e11ba8-92f6-eb11-94ef-000d3a5aa607"
    }
]
}

Gebruik de systeemquery-opties $select en $top om de eigenschap naam voor de eerste drie accounts te retourneren:

Bewerking Methode URI
De eerste drie entiteitsrecords ophalen GET [Portal URI]/_api/accounts?$select=name,revenue&$top=3

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$select=name,revenue&$top=3

Account ophalen met account-id:

Bewerking Methode URI
Specifieke eigenschap voor een record ophalen GET [Portal URI]/_api/accounts(e0e11ba8-92f6-eb11-94ef-000d3a5aa607)?$select=name

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts(e0e11ba8-92f6-eb11-94ef-000d3a5aa607)?$select=name

Voorbeeldrespons

{
    "@odata.etag": "W/\"1066414\"",
    "name": "Adventure Works (sample)",
    "accountid": "d6e11ba8-92f6-eb11-94ef-000d3a5aa607"
}

Systeemquery-opties toepassen

Elke systeemquery-optie die u aan de URL voor de entiteitsset toevoegt, wordt toegevoegd met behulp van de syntaxis voor querytekenreeksen. De eerste wordt toegevoegd na [?] en de volgende query-opties worden gescheiden door [&]. Alle query-opties zijn hoofdlettergevoelig, zoals in het volgende voorbeeld wordt getoond:

Methode URI
GET [Portal URI]/_api/accounts?$select=name,revenue&$filter=revenue gt 90000&$top=3

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$select=name,revenue&$filter=revenue gt 90000&$top=3

Specifieke eigenschappen aanvragen

Gebruik de systeemquery-optie $select om de geretourneerde eigenschappen te beperken, zoals weergegeven in het volgende voorbeeld:

Method URI
GET [Portal URI]/_api/accounts?$select=name,revenue&$top=3

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$select=name,revenue&$top=3

Belangrijk

Dit is een best practice voor betere prestaties. Als er geen eigenschappen zijn opgegeven en u de site-instellingen Webapi/<table name>/fields hebt ingesteld op *, worden alle eigenschappen geretourneerd met $select. Als er geen eigenschappen zijn opgegeven, wordt er een fout geretourneerd.

Resultaten filteren

Gebruik de systeemqueryoptie $filter om criteria in te stellen op basis waarvan rijen worden geretourneerd.

Operators voor standaardfilters

De web-API ondersteunt de standaard OData-filteroperators die in de volgende tabel worden vermeld:

Operator Beschrijving Voorbeeld
Vergelijkingsoperators
eq Gelijk aan $filter=omzet eq 100000
ne Niet gelijk aan $filter=omzet ne 100000
gt Groter dan $filter=omzet gt 100000
ge Groter dan of gelijk aan $filter=omzet ge 100000
lt Kleiner dan $filter=omzet lt 100000
le Kleiner dan of gelijk aan $filter=omzet le 100000
Logische operators
and Logisch en $filter=omzet lt 100000 en omzet gt 2000
or Logisch of $filter=bevat(naam,'(voorbeeld)') of bevat(naam,'test')
not Logische negatie $filter=bevat niet(naam,'voorbeeld')
Groeperingsoperators
( ) Prioriteitsgroepering (bevat(naam,'voorbeeld') of bevat(naam,'test')) en omzet gt 5000

Standaardqueryfuncties

De web-API ondersteunt deze standaardfuncties voor OData-tekenreeksquery's:

Functie Voorbeeld
bevat $filter=bevat(naam,'(voorbeeld)')
eindigt op $filter=endswith(naam,'Inc.')
startswith $filter=startswith(naam,'a')

Dataverse-queryfuncties

De web-API ondersteunt Dataverse-queryfuncties om resultaten te filteren. Zie Naslaginformatie voor queryfunctie voor web-API voor meer informatie.

Resultaten sorteren

Specificeer de volgorde waarin items worden geretourneerd met de systeemquery-optie $orderby. Gebruik het achtervoegsel asc of desc om respectievelijk een oplopende of aflopende volgorde te specificeren. De standaardwaarde is oplopend als het achtervoegsel niet wordt toegepast. In het volgende voorbeeld ziet u hoe u de naam en omzeteigenschappen van accounts kunt ophalen, gerangschikt op oplopende omzet en op aflopende naam.

Methode URI
GET [Portal URI]/_api/accounts?$select=name,revenue&$orderby=name asc,revenue desc&$filter=revenue gt 90000

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$select=name,revenue&$orderby=name asc,revenue desc&$filter=revenue gt 90000

Resultaten aggregeren en groeperen

Als u $apply gebruikt, kunt u uw gegevens dynamisch aggregeren en groeperen, zoals te zien is in de volgende voorbeelden:

Scenario's Voorbeeld
Lijst met unieke statussen in de query accounts?$apply=groupby((statuscode))
Som van de geschatte waarde aggregeren opportunities?$apply=aggregate(geschatte waarde met som als totaal)
Gemiddelde grootte van de deal op basis van geschatte waarde en status opportunities?$apply=groupby((statuscode),aggregate(estimatedvalue met gemiddelde als averagevalue)
Som van geschatte waarde op basis van status opportunities?$apply=groupby((statuscode),aggregate(estimatedvalue met som als totaal))
Totale omzet van verkoopkansen per accountnaam opportunities?$apply=groupby((parentaccountid/name),aggregate(estimatedvalue met som als totaal))
Primaire contactnamen voor accounts in 'WA' accounts?$apply=filter(address1_stateorprovince eq 'WA')/groupby((primarycontactid/fullname))
Laatste gemaakte record voor datum en tijd accounts?$apply=aggregate(createdon met max als lastCreate)
Eerste gemaakte record voor datum en tijd accounts?$apply=aggregate(createdon met min als firstCreate)

Een aantal rijen ophalen

Gebruik de systeemquery-optie $count met de waarde true om een telling van entiteiten op te nemen die voldoen aan de filtercriteria tot maximaal 5.000.

Methode URI
GET [Portal URI/_api/accounts?$select=name&$filter=contains(name,'sample')&$count=true

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$select=name&$filter=contains(name,'sample')&$count=true

Voorbeeldrespons

{
"@odata.count": 10,
"value": [
    {
    "@odata.etag": "W/\"1066412\"",
    "name": "Fourth Coffee (sample)",
    "accountid": "d2e11ba8-92f6-eb11-94ef-000d3a5aa607"
    },
    {
    "@odata.etag": "W/\"1066413\"",
    "name": "Litware, Inc. (sample)",
    "accountid": "d4e11ba8-92f6-eb11-94ef-000d3a5aa607"
    },
    {
    "@odata.etag": "W/\"1066414\"",
    "name": "Adventure Works (sample)",
    "accountid": "d6e11ba8-92f6-eb11-94ef-000d3a5aa607"
    }
]
}

Als u geen gegevens wilt retourneren, behalve de telling, kunt u een $count toepassen op elke verzameling om alleen de waarde op te halen.

Methode URI
GET [Portal URI/_api/accounts/$count

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts/$count

Voorbeeldrespons

3

Kolomvergelijking

In het volgende voorbeeld ziet u hoe u kolommen kunt vergelijken met de web-API:

Methode URI
GET [Portal URI]/_api/contacts?$select=firstname&$filter=firstname eq lastname

Voorbeeld:
https://contoso.powerappsportals.com/_api/contacts?$select=firstname&$filter=firstname eq lastname

Gebruik de systeemquery-optie $expand in de navigatie-eigenschappen om te bepalen welke gegevens van gerelateerde entiteiten worden geretourneerd.

Aan zoekopdracht gekoppelde navigatie-eigenschap

U moet de Microsoft.Dynamics.CRM.associatednavigationproperty gebruiken als opzoekkenmerk bij gebruik van de queryoptie $expand.

Om de Microsoft.Dynamics.CRM.associatednavigationproperty van een kenmerk te bepalen, kunt u de volgende http-aanvraag GET voor de kolom doen met behulp van de volgende naamgevingsconventie: _name_value.

In het volgende voorbeeld kunnen we de bijbehorende navigatie-eigenschap bepalen van de kolom Primaire contactpersoon van de Account-tabel door de kolomnaam primarycontactid op te geven door de naam in de aanvraag in te delen als: _primarycontactid_value.

Method URI
GET [Portal URI]/_api/accounts?$select=_primarycontactid_value

Voorbeeld
https://contoso.powerappsportals.com/_api/accounts?$select=_primarycontactid_value

Voorbeeldrespons

{
"value": [
    {
        "@odata.etag": "W/\"2465216\"",
        "_primarycontactid_value@OData.Community.Display.V1.FormattedValue": "Yvonne McKay (sample)",
        "_primarycontactid_value@Microsoft.Dynamics.CRM.associatednavigationproperty": "primarycontactid",
        "_primarycontactid_value@Microsoft.Dynamics.CRM.lookuplogicalname": "contact",
        "_primarycontactid_value": "417319b5-cd18-ed11-b83c-000d3af4d812",
        "accountid": "2d7319b5-cd18-ed11-b83c-000d3af4d812"
    }
]
}

We zien uit de respons dat de bijbehorende navigatie-eigenschap is primarycontactid. De bijbehorende navigatie-eigenschap kan of de logische naam of de schemanaam van de opzoekkolom zijn, afhankelijk van hoe de tabel is gemaakt.

Zie Gegevens ophalen over opzoekeigenschappen voor meer informatie.

In het volgende voorbeeld ziet u hoe u de contactpersoon voor alle accountrecords kunt ophalen. Voor de gerelateerde contactrecords halen we alleen de contactid en fullname op.

Method URI
GET [Portal URI]/_api/accounts?$select=name&$expand=primarycontactid($select=contactid,fullname)

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$select=name&$expand=primarycontactid($select=contactid,fullname)

Voorbeeldrespons

{
"value": [
    {
    "@odata.etag": "W/\"1066412\"",
    "name": "Fourth Coffee (sample)",
    "accountid": "d2e11ba8-92f6-eb11-94ef-000d3a5aa607",
        "primarycontactid": {
        "contactid": "e6e11ba8-92f6-eb11-94ef-000d3a5aa607",
        "fullname": "Yvonne McKay (sample)"
        }
    },
    {
    "@odata.etag": "W/\"1066413\"",
    "name": "Litware, Inc. (sample)",
    "accountid": "d4e11ba8-92f6-eb11-94ef-000d3a5aa607",
        "primarycontactid": {
        "contactid": "e8e11ba8-92f6-eb11-94ef-000d3a5aa607",
        "fullname": "Susanna Stubberod (sample)"
        }
    }
]
}

Als u navigatieparameters met een verzameling waarden uitbreidt om gerelateerde tabellen voor entiteitssets op te halen, wordt er slechts één diepteniveau geretourneerd als er gegevens zijn. Anders retourneert de verzameling een lege matrix.

Method URI
GET [Portal URI]/_api/accounts?$top=5&$select=name&$expand=Account_Tasks($select=subject,scheduledstart)

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$top=5&$select=name&$expand=Account_Tasks($select=subject,scheduledstart)

Het volgende voorbeeld laat zien hoe u gerelateerde entiteiten voor entiteitssets kunt uitbreiden met behulp van navigatie-eigenschappen met zowel één waarde als met een verzameling waarden. U moet de naam van de tabelrelatie opgeven in de syntaxis van uw code.

Method URI
GET [Portal URI]/_api/accounts?$top=5&$select=name&$expand=primarycontactid($select=contactid,fullname),Account_Tasks($select=subject,scheduledstart)

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?$top=5&$select=name&$expand=primarycontactid($select=contactid,fullname),Account_Tasks($select=subject,scheduledstart)

Query's op records uitvoeren met FetchXml

Geef de FetchXml-query door als een URL-gecodeerde tekenreekswaarde aan de entiteitensetverzameling met behulp van de FetchXml-queryparameter.

Om bijvoorbeeld gegevens op te halen uit de accountentiteitenset, stelt u een FetchXml-query samen waarin u de parameter entity element name instelt op het account.

<fetch top='2'>
  <entity name='account'>
      <attribute name='name' />
  </entity>
</fetch>

De URL-gecodeerde tekenreeks voor de vorige query is:

%3Cfetch%20top%3D%275%27%3E%0D%0A%3Centity%20name%3D%27account%27%3E%0D%0A%3Cattribute%20name%3D%27name%27%2F%3E%0D%0A%3C%2Fentity%3E%0D%0A%3C%2Ffetch%3E
Method URI
GET [Portal URI]/_api/accounts?fetchxml

Voorbeeld:
https://contoso.powerappsportals.com/_api/accounts?fetchXml=%3Cfetch%20top%3D%275%27%3E%0D%0A%3Centity%20name%3D%27account%27%3E%0D%0A%3Cattribute%20name%3D%27name%27%2F%3E%0D%0A%3C%2Fentity%3E%0D%0A%3C%2Ffetch%3E

Voorbeeldrespons

{
  "value": [
    {
      "@odata.etag": "W/\"1066412\"",
      "name": "Fourth Coffee (sample)",
      "accountid": "d2e11ba8-92f6-eb11-94ef-000d3a5aa607",
      "primarycontactid": {
        "contactid": "e6e11ba8-92f6-eb11-94ef-000d3a5aa607",
        "fullname": "Yvonne McKay (sample)"
      }
    },
    {
      "@odata.etag": "W/\"1066413\"",
      "name": "Litware, Inc. (sample)",
      "accountid": "d4e11ba8-92f6-eb11-94ef-000d3a5aa607",
      "primarycontactid": {
        "contactid": "e8e11ba8-92f6-eb11-94ef-000d3a5aa607",
        "fullname": "Susanna Stubberod (sample)"
      }
    }
  ]
}

Volgende stap

Bewerkingen voor schrijven, bewerken en verwijderen van portals met de web-API

Zie ook