Del via


Forespørgsel efter data ved hjælp af portaler Web API

Du kan bruge tilgængelige web-API-handlinger i Power Pages. Web-API-handlinger består af HTTP-anmodninger og -svar. Denne artikel indeholder eksempler på læsehandlinger, metoder, URI'er og det JSON-eksempel, du kan bruge i HTTP-anmodningen.

Forudsætninger

  • Din portalversion skal være 9.4.1.x eller nyere.

  • Aktiver tabel og felt for web-API-handlinger. Flere oplysninger: Indstillinger for websted for web-API'en

  • Portalerne Web API giver adgang til tabelposter og følger de tabeltilladelser, der gives til brugere via de tilknyttede webroller. Sørg for at konfigurere de rette tabeltilladelser. Flere oplysninger: Oprette webroller

Bemærk

Når du refererer til Dataverse-tabeller ved hjælp af portal-Wweb-API'en, skal du f.eks. bruge EntitySetName til at få adgang til account-tabellen. Kodesyntaksen bruger EntitySetName accounts.

Forespørge på poster

Følgende eksempel forespørger om firmaposter:

Handling Method URI
Hente tabelposter GET [Portal URI]/_api/accounts

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

Prøvesvar

{
"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"
    }
]
}

Brug $select og $top til at returnere navneegenskaben for de første tre firmaer:

Handling Method URI
Hente de første tre objektposter GET [Portal URI]/_api/accounts?$select=name,revenue&$top=3

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

Hent firma ved hjælp af firma-id:

Handling Method URI
Hente en bestemt egenskab for en post GET [Portal URI]/_api/accounts(e0e11ba8-92f6-eb11-94ef-000d3a5aa607)?$select=name

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

Prøvesvar

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

Anvende indstillinger for systemforespørgsel

De systemforespørgselsindstillinger, du føjer til URL-adressen for det objektsæt, tilføjes ved hjælp af syntaksen for forespørgselsstrenge. Den første tilføjes efter [?], og følgende forespørgselsindstillinger adskilles ved hjælp af [&]. I alle forespørgselsindstillinger kan der bruges store og små bogstaver som vist i følgende eksempel:

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

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

Anmod om specifikke egenskaber

Brug indstillingen $select-systemforespørgsel til at begrænse de egenskaber, der returneres som vist i følgende eksempel:

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

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

Vigtigt

Dette er bedste praksis for ydeevne Hvis der ikke er angivet egenskaber, og du har konfigureret Webapi/<table name>/fields-værdien for indstillingen for websted til *, returneres alle egenskaber ved hjælp af $select. Hvis der ikke angives nogen egenskaber, returneres der en fejl.

Filtrer resultater

Brug indstillingen $filter-systemforespørgsel til at angive kriterier for, hvilke rækker der returneres.

Standardfilteroperatører

Web-API'en understøtter de OData-standardfilteroperatører, der er angivet i følgende tabel:

Operatør Beskrivelse Eksempel
Sammenligningsoperatorer
eq Lig med $filter=indtægtskilde eq 100000
ne Ikke lig med $filter=indtægtskilde ne 100000
gt Større end $filter=indtægtskilde gt 100000
ge Større end eller lig med $filter=indtægtskilde ge 100000
lt Mindre end $filter=indtægtskilde lt 100000
le Mindre end eller lig med $filter=indtægtskilde le 100000
Logiske operatorer
and Logisk AND $filter=omsætning lt100000 og omsætning gt 2000
or Logisk OR $filter=indeholder(navn,'(sample)') eller indeholder(navn,'test')
not Logisk negation $filter=ikke indeholder(navn,'sample')
Gruppering af operatorer
( ) Gruppering af prioritet (indeholder(navn,'sample') eller indeholder(navn,'test')) og omsætning gt 5000

Standardforespørgselsfunktioner

Web-API'en understøtter disse standardfunktioner til OData-strengforespørgsel:

Funktion Eksempel
indeholder $filter=ikke indeholder(navn,'(sample)')
endswith $filter=endswith(name,'Inc.')
startswith $filter=startswith(name,'a')

Dataverse-forespørgselsfunktioner

Web-API'en understøtter Dataverse-forespørgselsfunktioner til filtrering af resultater. Du kan finde flere oplysninger i Web API Query Function Reference.

Ordreresultater

Angiv den rækkefølge, elementer returneres i, ved hjælp af indstillingen $orderby systemforespørgsel. Brug asc- eller desc-suffiks til at angive henholdsvis stigende eller faldende rækkefølge. Standardværdien er stigende, hvis suffikset ikke anvendes. I følgende eksempel kan du se, hvordan du henter navn og indtægtsegenskaber for firmaer, der er sorteret efter stigende omsætning og faldende navn.

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

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

Aggregere og gruppere resultater

Ved hjælp $apply kan du aggregere og gruppere dataene dynamisk, som det kan ses i følgende eksempler:

Scenarier Eksempel
Liste over entydige statusser i forespørgslen firmaer?$apply=groupby((statuscode))
Samlet sum af den anslåede værdi salgsmuligheder?$apply=aggregate(anslået værdi med sum som total)
Den gennemsnitlige størrelse på handlen baseret på anslået værdi og status salgsmuligheder?$apply=groupby((statuscode),aggregate(estimatedvalue with average as averagevalue)
Sum af anslået værdi baseret på status salgsmuligheder?$apply=groupby((statuscode),aggregate(estimatedvalue with sum som total))
Samlet omsætning for salgsmulighed efter firmanavn salgsmuligheder?$apply=groupby((parentaccountid/name),aggregate(estimatedvalue with sum som total))
Navne på primære kontaktpersoner for firmaer i 'WA' accounts?$apply=filter(address1_stateorprovince eq 'WA')/groupby((primarycontactid/fullname))
Sidst oprettet dato og klokkeslæt for post firmaer?$apply=aggregate(createdon med maks. som lastCreate)
Først oprettet dato og klokkeslæt for post firmaer?$apply=aggregate(createdon med min. som firstCreate)

Hente en optælling af rækker

Brug indstillingen $count systemforespørgsel med værdien true til at medtage en optælling af objekter, der opfylder filterkriterierne op til 5.000.

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

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

Prøvesvar

{
"@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"
    }
]
}

Hvis du ikke vil returnere data med undtagelse af antallet, kan du anvende $count på en hvilken som helst samling for kun at få værdien.

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

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

Prøvesvar

3

Sammenligning af kolonner

I følgende eksempel kan du se, hvordan du kan sammenligne kolonner ved hjælp af web-API'en:

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

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

Brug indstillingen $expand-systemforespørgsel i navigationsegenskaberne for at styre, hvilke data fra relaterede objekter der returneres.

Opslagstilknyttet navigationsegenskab

Du skal bruge Microsoft.Dynamics.CRM.associatednavigationproperty som opslagsattribut, når du bruger forespørgselsindstillingen $expand.

Hvis du vil fastslå Microsoft.Dynamics.CRM.associatednavigationproperty for en attribut, kan du oprette følgende http GET-forespørgsel for kolonnen ved hjælp af følgende navngivningskonvention: _navn_værdi.

I følgende eksempel kan du fastslå den tilknyttede navigationsegenskab for kolonnen Primær kontaktperson i tabellen Firma ved at angive kolonnenavnet primarycontactid ved at formatere navnet i anmodningen: _primarycontactid_value.

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

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

Prøvesvar

{
"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"
    }
]
}

Vi kan se ud fra svaret, at den tilknyttede navigationsegenskab er primarycontactid. Den tilknyttede navigationsegenskab kan enten være opslagskolonnens logiske navn eller skemanavn, afhængigt af hvordan tabellen blev oprettet.

Du kan finde flere oplysninger under Hente data om opslagsegenskaber.

I følgende eksempel vises, hvordan du kan hente kontakten for alle firmaposterne. I forbindelse med relaterede kontaktposter henter vi kun kontakt-id og fulde navn.

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

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

Prøvesvar

{
"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)"
        }
    }
]
}

Hvis du udvider navigationsparametrene for samlingsværdier for at hente relaterede tabeller for objektsæt, returneres der kun ét niveau med dybden, hvis der findes data. Ellers returnerer samlingen en tom matrix.

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

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

I følgende eksempel vises, hvordan du kan udvide relaterede objekter for objektsæt ved hjælp af både navigationsegenskaber og navigationsegenskaber med samlingsværdi. Du skal angive tabelrelationsnavnet i syntaksen for din kode.

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

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

Brug FetchXML til postforespørgsler

Overfør FetchXml-forespørgslen som en URL-kodet strengværdi til samlingen af objektsæt ved hjælp af forespørgselsparameteren FetchXml.

Hvis du f.eks. vil hente data fra kontoobjektsættet, skal du oprette en FetchXML-forespørgsel, der angiver parameteren for navnet på objektelement til kontoen.

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

Den URL-kodede streng for den forrige forespørgsel er:

%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
Metode URI
GET [Portal URI]/_api/accounts?fetchxml

Eksempel:
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

Prøvesvar

{
  "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)"
      }
    }
  ]
}

Næste trin

Portalhandlingerne skrive, opdatere og slette bruger Web-API

Se også