Condividi tramite


Query di dati utilizzando l'API Web dei portali

Puoi usare le operazioni API Web disponibili in Power Pages. Le operazioni API Web sono costituite da richieste e risposte HTTP. Questo articolo fornisce operazioni di lettura di esempio, metodi, URI e JSON di esempio che puoi usare nella richiesta HTTP.

Prerequisiti

  • La versione del tuo sito Web deve essere 9.4.1.x o successiva.

  • Abilita la tabella e il campo per le operazioni dell'API Web. Maggiori informazioni: Impostazioni del sito per l'API Web

  • L'API Web dei portali accede ai record della tabella e segue le autorizzazioni della tabella fornite agli utenti tramite i ruoli web associati. Assicurati di configurare le autorizzazioni della tabella corrette. Più informazioni: Creare ruoli web

Nota

Quando si fa riferimento alle tabelle Dataverse utilizzando l'API Web dei portali, è necessario utilizzare EntitySetName, ad esempio, per accedere alla tabella degli account, la sintassi del codice utilizzerà EntitySetName di account.

Query di record

L'esempio seguente esegue una query dei record dell'account:

Operazione Method URI
Recupera record di tabella GET [Portal URI]/_api/accounts

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

Risposta di esempio

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

Usa le opzioni di query di sistema $select e $top per restituire la proprietà nome per i primi tre account:

Operazione Method URI
Recupera i primi tre record di entità GET [Portal URI]/_api/accounts?$select=name,revenue&$top=3

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

Recupera l'account utilizzando l'ID account:

Operazione Method URI
Recupera una proprietà specifica per un record GET [Portal URI]/_api/accounts(e0e11ba8-92f6-eb11-94ef-000d3a5aa607)?$select=name

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

Risposta di esempio

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

Applicare le opzioni di query di sistema

Ciascuna delle opzioni di query di sistema che aggiungi all'URL per il set di entità viene aggiunta utilizzando la sintassi per le stringhe di query. La prima è aggiunta dopo [?] e le seguenti opzioni di query sono separate usando [&]. Tutte le opzioni di query fanno distinzione tra maiuscole e minuscole, come mostrato nell'esempio seguente:

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

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

Richiedere proprietà specifiche

Utilizza l'opzione di query di sistema $select per limitare le proprietà restituite come mostrato nell'esempio seguente:

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

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

Importante

Questa è una procedura consigliata per le prestazioni. Se le proprietà non sono specificate e hai configurato il valore di impostazione del sito Webapi/<table name>/fields su *, tutte le proprietà verranno restituite utilizzando $select. Se non vengono specificate proprietà, verrà restituito un errore.

Filtrare i risultati

Utilizza l'opzione di query di sistema $filter per impostare i criteri secondo cui verranno restituite le righe.

Operatori di filtro standard

L'API Web supporta gli operatori di filtro OData standard elencati nella tabella seguente:

Operator Descrizione Esempio
Operatori di confronto
eq Uguale $filter=revenue eq 100000
ne Non uguale $filter=revenue ne 100000
gt Maggiore di $filter=revenue gt 100000
ge Maggiore di o uguale a $filter=revenue ge 100000
lt Minore di $filter=revenue lt 100000
le Minore di o uguale a $filter=revenue le 100000
Operatori logici
and And logico $filter=revenue lt 100000 and revenue gt 2000
or Or logico $filter=contains(name,'(sample)') or contains(name,'test')
not Negazione logica $filter=not contains(name,'sample')
Operatori di raggruppamento
( ) Raggruppamento di precedenza (contains(name,'sample') or contains(name,'test')) and revenue gt 5000

Funzioni di query standard

L'API Web supporta queste funzioni di query stringa OData standard:

Funzione Esempio
contiene $filter=contains(name,'(sample)')
finisce con $filter=endswith(name,'Inc.')
startswith $filter=startswith(name,'a')

Funzioni di query Dataverse

L'API Web supporta le funzioni di query Dataverse per filtrare i risultati. Per altre informazioni, vedi Informazioni di riferimento sulle funzioni di query dell'API Web.

Ordina i risultati

Specifica l'ordine in cui gli elementi vengono restituiti utilizzando l'opzione di query di sistema $orderby. Utilizza il suffisso asc o desc per specificare rispettivamente l'ordine crescente o decrescente. L'impostazione predefinita è crescente se il suffisso non viene applicato. L'esempio seguente mostra il recupero del nome e delle proprietà dei ricavi degli account ordinati per ricavi crescenti e per nome decrescente.

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

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

Aggregare e raggruppare i risultati

Usando $apply, puoi aggregare e raggruppare i tuoi dati in modo dinamico come mostrato nei seguenti esempi:

Scenari Esempio
Elenco degli stati univoci nella query accounts?$apply=groupby((statuscode))
Somma aggregata del valore stimato opportunities?$apply=aggregate(estimatedvalue with sum as total)
Dimensione media della transazione in base al valore e allo stato stimati opportunities?$apply=groupby((statuscode),aggregate(estimatedvalue with average as averagevalue)
Somma del valore stimato in base allo stato opportunities?$apply=groupby((statuscode),aggregate(estimatedvalue with sum as total))
Ricavi opportunità totali per nome account opportunities?$apply=groupby((parentaccountid/name),aggregate(estimatedvalue with sum as total))
Nomi dei contatti primari per gli account in "WA" accounts?$apply=filter(address1_stateorprovince eq 'WA')/groupby((primarycontactid/fullname))
Data e ora creazione ultimo record accounts?$apply=aggregate(createdon with max as lastCreate)
Data e ora creazione primo record accounts?$apply=aggregate(createdon with min as firstCreate)

Recuperare un conteggio delle righe

Utilizza l'opzione di query di sistema $count con il valore Vero per includere un conteggio delle entità che corrispondono ai criteri di filtro fino a 5.000.

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

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

Risposta di esempio

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

Se non vuoi restituire nessun dato tranne il conteggio, puoi applicare $count a qualsiasi raccolta per ottenere solo il valore.

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

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

Risposta di esempio

3

Confronto colonne

L'esempio seguente mostra come confrontare le colonne utilizzando l'API Web:

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

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

Utilizza l'opzione di query di sistema $expand nelle proprietà di spostamento per controllare quali dati vengono restituiti dalle entità correlate.

Proprietà di navigazione associata alla ricerca

Devi utilizzare Microsoft.Dynamics.CRM.associatednavigationproperty come attributo di ricerca quando si utilizza l'opzione di query $expand.

Per determinare la proprietà Microsoft.Dynamics.CRM.associatednavigationproperty di un attributo, puoi effettuare la seguente richiesta http GET per la colonna utilizzando la seguente convenzione di denominazione: _name_value.

Nell'esempio seguente, possiamo determinare la proprietà di navigazione associata della colonna Contatto primario della tabella Account specificando il nome di colonna primarycontactid formattando il nome nella richiesta: _primarycontactid_value.

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

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

Risposta di esempio

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

Nella risposta è possibile osservare che la proprietà di navigazione associata è primarycontactid. La proprietà di navigazione associata può essere il nome logico o il nome di schema della colonna di ricerca a seconda di come è stata creata la tabella.

Per ulteriori informazioni, vedi Recuperare dati sulle proprietà di ricerca.

L'esempio seguente mostra come recuperare il contatto per tutti i record dell'account. Per i relativi record di contatti, stiamo recuperando solo contactid e fullname.

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

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

Risposta di esempio

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

Se espandi i parametri di spostamento con valori di raccolta per recuperare le tabelle correlate per i set di entità, viene restituito un solo livello di profondità se sono presenti dati. In caso contrario, la raccolta restituirà un array vuoto.

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

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

L'esempio seguente mostra come espandere le entità correlate per i set di entità utilizzando proprietà di spostamento a valore singolo e raccolta. Devi specificare il nome della relazione della tabella nella sintassi del codice.

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

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

Record di query che usano FetchXml

Passare la query FetchXml come valore stringa con codifica URL alla raccolta di set di entità utilizzando il parametro di query FetchXml.

Ad esempio, per recuperare i dati dal set di entità account, comporre una query FetchXml impostando il parametro del nome dell'elemento dell'entità sull'account.

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

La stringa con codifica URL per la query precedente è:

%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

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

Risposta di esempio

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

Passaggio successivo

Operazioni di scrittura, aggiornamento ed eliminazione dei portali con l'API Web

Vedi anche