Statistiques et statut de recherche Dataverse
La recherche Dataverse fournit deux opérations que vous pouvez utiliser pour récupérer des données sur les structures de données utilisées pour prendre en charge la recherche et vérifier si la recherche est activée.
Statistiques
Vous devrez peut-être connaître la taille de la structure de données renvoyée pour vous aider à mieux optimiser votre requête ou vos résultats de requête et vous aider à gérer la taille de votre base de données afin de gérer les coûts.
Les statistiques de recherche fournissent des informations sur :
- Taille de stockage en octets
- Taille de stockage en mégaoctets
- Nombre de documents
Exemples de statistiques
Les exemples suivants montrent comment utiliser l’API statistics
.
Cet exemple est tiré de l’exemple du SDK pour les opérations de recherche .NET sur GitHub.
/// <summary>
/// Demonstrate statistics API
/// </summary>
/// <param name="service">The authenticated IOrganizationService instance to use.</param>
/// <returns></returns>
static void OutputSearchStatistics(IOrganizationService service)
{
Console.WriteLine("OutputSearchStatistics START\n");
var searchstatisticsResponse = (searchstatisticsResponse)service.Execute(new searchstatisticsRequest());
JObject ResponseObj = (JObject)JsonConvert.DeserializeObject(value: searchstatisticsResponse.response);
SearchStatisticsResult results = ResponseObj["value"].ToObject<SearchStatisticsResult>();
Console.WriteLine($"\tStorageSizeInBytes: {results.StorageSizeInByte}");
Console.WriteLine($"\tStorageSizeInMb: {results.StorageSizeInMb}");
Console.WriteLine($"\tDocumentCount: {results.DocumentCount}");
Console.WriteLine("\nOutputSearchStatistics END");
}
Sortie
Lorsque vous appelez la méthode OutputSearchStatistics
avec une instance authentifiée de la classe ServiceClient :
OutputSearchStatistics(service: serviceClient);
Le résultat ressemble à ce qui suit :
OutputSearchStatistics START
StorageSizeInBytes: 1341090
StorageSizeInMb: 1
DocumentCount: 1309
OutputSearchStatistics END
Classes de soutien
La méthode OutputSearchStatistics
dépend des classes de soutien suivantes pour envoyer la requête et traiter le résultat :
Classes searchstatisticsRequest et searchstatisticsResponse
Ces classes sont générées à l’aide de la commande de CLI Power Platform pac modelbuilder build comme décrit dans Générer des classes à liaison anticipée pour le SDK pour .NET.
Classe SearchStatisticsResult
Utilisée pour désérialiser la propriété searchstatisticsResponse.response.value
.
class SearchStatisticsResult
{
/// <summary>
/// The storage size in Bytes
/// </summary>
[JsonProperty(PropertyName = "storagesizeinbytes")]
public long StorageSizeInByte { get; set; }
/// <summary>
/// The storage size in Megabytes
/// </summary>
[JsonProperty(PropertyName = "storagesizeinmb")]
public long StorageSizeInMb { get; set; }
/// <summary>
/// The document count
/// </summary>
[JsonProperty(PropertyName = "documentcount")]
public long DocumentCount { get; set; }
}
Status
Utilisez le statut de recherche pour savoir :
- Recherche activée ou non.
- Les tables et les colonnes activées pour la recherche.
Types de réponse de statut
L’opération d’état renvoie des données en utilisant les types suivants :
searchstatusResponse.response.value
La propriété searchstatusResponse.response
a une propriété value
avec les propriétés suivantes :
Nom | Type | Description |
---|---|---|
entitystatusresults |
EntityStatusInfo[] | Contient des informations sur l’état des tables activées pour la recherche. |
manytomanyrelationshipsyncstatus |
ManyToManyRelationshipSyncStatus[] | Contient des informations sur l’état de synchronisation des relations plusieurs à plusieurs. |
status |
Statut | Indique l’état d’une table et/ou de l’index dans son ensemble. |
lockboxstatus |
LockBoxStatus | Indique le statut de la lockbox. |
cmkstatus |
CMKStatus | Indique l’état de la clé gérée par le client. |
EntityStatusInfo
Contient des informations sur l’état des tables activées pour la recherche.
Nom | Type | Description |
---|---|---|
entitylogicalname |
chaine | Nom logique de la table |
objecttypecode |
chaine | Code de type d’objet de la table. |
primarynamefield |
string | Colonne principale de la table. |
lastdatasynctimestamp |
string | Dernière heure de synchronisation. |
lastprincipalobjectaccesssynctimestamp |
string | Heure de synchronisation du dernier accès à l’objet principal. |
entitystatus |
chaine | Statut du niveau d’entité. |
searchableindexedfieldinfomap |
Dictionary<string,FieldStatusInfo> | Le dictionnaire des noms et détails des colonnes indexées. |
FieldStatusInfo
Détails des champs indexés d’une table.
Nom | Type | Description |
---|---|---|
indexfieldname |
chaine | Nom du champ d’index. |
Status
Indique l’état d’une table et/ou de l’index dans son ensemble.
Nom | active | Description |
---|---|---|
notprovisioned |
0 | L’organisation n’est pas disponible pour la recherche. |
provisioninginprogress |
1 | Mise en service de l’organisation en cours. |
provisioned |
2 | Organisation disponible pour la recherche. |
CMKStatus
Indique l’état de la clé gérée par le client.
Pour plus d’informations : Gérer la clé de chiffrement
Nom | active | Description |
---|---|---|
Unknown |
0 | La recherche Dataverse n’est pas en service. |
Disabled |
1 | La clé gérée par le client est désactivée. |
Enabled |
2 | La clé gérée par le client est activée. |
DisablingInProgress |
3 | La clé gérée par le client est en cours de désactivation. |
EnablingInProgress |
4 | La clé gérée par le client est en cours d’activation. |
LockBoxStatus
Indique le statut de la lockbox.
Pour plus d’informations : Accéder en toute sécurité aux données client à l’aide de Customer Lockbox dans Power Platform (version préliminaire)
Nom | active | Description |
---|---|---|
Unknown |
0 | La recherche Dataverse n’est pas en service. |
Disabled |
1 | Lockbox est désactivée. |
Enabled |
2 | Lockbox est activée. |
DisablingInProgress |
3 | Lockbox est en cours de désactivation. |
EnablingInProgress |
4 | Lockbox est en cours d’activation. |
ManyToManyRelationshipSyncStatus
Contient des informations sur l’état de synchronisation des relations plusieurs à plusieurs.
Nom | Type | Description |
---|---|---|
relationshipName |
chaine | Nom de la relation. |
relationshipMetadataId |
Identificateur unique | ID de la relation. |
searchEntity |
string | Nom de la table de recherche. |
relatedEntity |
string | Nom de la table de référence. |
searchEntityIdAttribute |
string | Nom de la clé primaire de la table de recherche. |
relatedEntityIdAttribute |
string | Nom de la clé primaire de la table associée. |
intersectEntity |
string | Le nom de la table d’intersection qui prend en charge cette relation plusieurs-à-plusieurs. |
searchEntityObjectTypeCode |
int | Code de type d’objet de la table de recherche. |
lastSyncedVersion |
string | La dernière version synchronisée. |
Exemples de statuts
Les exemples suivants montrent la sortie de l’API d’état.
Cet exemple est tiré de l’exemple du SDK pour les opérations de recherche .NET sur GitHub.
/// <summary>
/// Demonstrate status API
/// </summary>
/// <param name="service">The authenticated IOrganizationService instance to use.</param>
/// <returns></returns>
static void OutputSearchStatus(IOrganizationService service)
{
Console.WriteLine("OutputSearchStatus START\n");
var searchStatusResponse = (searchstatusResponse)service.Execute(new searchstatusRequest());
JObject ResponseObj = (JObject)JsonConvert.DeserializeObject(searchStatusResponse.response);
SearchStatusResult results = ResponseObj["value"].ToObject<SearchStatusResult>();
Console.WriteLine($"\tStatus: {results.Status}");
Console.WriteLine($"\tLockboxStatus: {results.LockboxStatus}");
Console.WriteLine($"\tCMKStatus: {results.CMKStatus}");
if (results.Status == SearchStatus.Provisioned)
{
// There will be no results if status is notprovisioned
if (results.EntityStatusInfo?.Count > 0)
{
Console.WriteLine("\tEntity Status Results:\n");
results.EntityStatusInfo.ForEach(result =>
{
Console.WriteLine($"\t\tentitylogicalname: {result.EntityLogicalName}");
Console.WriteLine($"\t\tobjecttypecode: {result.ObjectTypeCode}");
Console.WriteLine($"\t\tprimarynamefield: {result.PrimaryNameField}");
Console.WriteLine($"\t\tlastdatasynctimestamp: {result.LastDataSyncTimeStamp}");
Console.WriteLine($"\t\tlastprincipalobjectaccesssynctimestamp: {result.LastPrincipalObjectAccessSyncTimeStamp}");
Console.WriteLine($"\t\tentitystatus: {result.EntityStatus}");
Console.WriteLine($"\t\tsearchableindexedfieldinfomap:");
result.SearchableIndexedFieldInfoMap.ToList().ForEach(searchableindexedfield =>
{
Console.WriteLine($"\t\t\t{searchableindexedfield.Key}\t indexfieldname:{searchableindexedfield.Value.IndexFieldName}");
});
Console.WriteLine("\n");
});
}
}
Console.WriteLine("OutputSearchStatus END\n");
}
Sortie
Lorsque vous appelez la méthode OutputSearchStatus
avec une instance authentifiée de la classe ServiceClient :
OutputSearchStatus(service: serviceClient);
Le résultat ressemble à ce qui suit :
OutputSearchStatus START
Status: Provisioned
LockboxStatus: Disabled
CMKStatus: Disabled
Entity Status Results:
entitylogicalname: account
objecttypecode: 1
primarynamefield: name
lastdatasynctimestamp: 1555508!10/16/2023 02:21:59
lastprincipalobjectaccesssynctimestamp: 0!10/16/2023 02:22:00
entitystatus: EntitySyncComplete
searchableindexedfieldinfomap:
accountid indexfieldname:a_0
accountnumber indexfieldname:a0w
address1_city indexfieldname:a0x
createdon indexfieldname:i_0
emailaddress1 indexfieldname:a0y
entityimage_url indexfieldname:h_0
modifiedon indexfieldname:j_0
name indexfieldname:d_0
ownerid indexfieldname:b_0
owningbusinessunit indexfieldname:c_0
primarycontactid indexfieldname:a0z
statecode indexfieldname:f_0
statuscode indexfieldname:g_0
telephone1 indexfieldname:a12
telephone2 indexfieldname:a13
versionnumber indexfieldname:e_0
<Additional tables removed for brevity>
OutputSearchStatus END
Classes de soutien
La méthode OutputSearchStatus
dépend des classes de soutien suivantes pour envoyer la requête et traiter le résultat :
Classes searchstatusRequest et searchstatusResponse
Ces classes sont générées à l’aide de la commande de CLI Power Platform pac modelbuilder build comme décrit dans Générer des classes à liaison anticipée pour le SDK pour .NET.
Classe SearchStatusResult
Utilisée pour désérialiser les données searchstatusResponse.response.value.
class SearchStatusResult
{
/// <summary>
/// The current search status
/// </summary>
[JsonProperty("status")]
public SearchStatus Status { get; set; }
/// <summary>
/// The current lockbox status
/// </summary>
[JsonProperty("lockboxstatus")]
public LockboxStatus LockboxStatus { get; set; }
/// <summary>
/// The current customer managed key status
/// </summary>
[JsonProperty("cmkstatus")]
public CMKStatus CMKStatus { get; set; }
/// <summary>
/// Information on enabled tables
/// </summary>
[JsonProperty("entitystatusresults")]
public List<EntityStatusInfo>? EntityStatusInfo { get; set; }
/// <summary>
/// Information about th status of synchronized many-to-many relationships
/// </summary>
[JsonProperty("manytomanyrelationshipsyncstatus")]
public List<ManyToManyRelationshipSyncStatus>? ManyToManyRelationshipSyncStatus { get; set; }
}
Énumération SearchStatus
Utilisée pour désérialiser les données Status.
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
using System.Runtime.Serialization;
[DataContract]
[JsonConverter(typeof(StringEnumConverter))]
public enum SearchStatus
{
/// <summary>
/// Organization is not provisioned for search.
/// </summary>
[EnumMember(Value = "notprovisioned")]
NotProvisioned = 0,
/// <summary>
/// Organization provisioning in progress.
/// </summary>
[EnumMember(Value = "provisioninginprogress")]
ProvisioningInProgress = 1,
/// <summary>
/// Organization provisioned for search.
/// </summary>
[EnumMember(Value = "provisioned")]
Provisioned = 2,
}
Énum LockBoxStatus
Utilisée pour désérialiser les données LockBoxStatus.
using Newtonsoft.Json.Converters;
using System.Runtime.Serialization;
using Newtonsoft.Json;
/// <summary>
/// Indicates the status of the lockbox.
/// </summary>
[DataContract]
[JsonConverter(typeof(StringEnumConverter))]
public enum LockboxStatus
{
/// <summary>
/// Indicates dataverse search is not provisioned.
/// </summary>
[EnumMember]
Unknown = 0,
/// <summary>
/// Indicates lockbox is disabled.
/// </summary>
[EnumMember]
Disabled = 1,
/// <summary>
/// Indicates lockbox is enabled.
/// </summary>
[EnumMember]
Enabled = 2,
/// <summary>
/// Indicates lockbox is disabling in progress.
/// </summary>
[EnumMember]
DisablingInProgress = 3,
/// <summary>
/// Indicates lockbox is enabling in progress.
/// </summary>
[EnumMember]
EnablingInProgress = 4,
}
Énumération CMKStatus
Utilisée pour désérialiser les données CMKStatus.
using Newtonsoft.Json.Converters;
using System.Runtime.Serialization;
using Newtonsoft.Json;
/// <summary>
/// Indicates the status of the customer managed key.
/// </summary>
[DataContract]
[JsonConverter(typeof(StringEnumConverter))]
public enum CMKStatus
{
/// <summary>
/// Indicates dataverse search is not provisioned.
/// </summary>
[EnumMember]
Unknown = 0,
/// <summary>
/// Indicates customer managed key is disabled.
/// </summary>
[EnumMember]
Disabled = 1,
/// <summary>
/// Indicates customer managed key is enabled.
/// </summary>
[EnumMember]
Enabled = 2,
/// <summary>
/// Indicates customer managed key is disabling in progress.
/// </summary>
[EnumMember]
DisablingInProgress = 3,
/// <summary>
/// Indicates customer managed key is enabling in progress.
/// </summary>
[EnumMember]
EnablingInProgress = 4,
}
Classe EntityStatusInfo
Utilisée pour désérialiser les données EntityStatusInfo.
using Newtonsoft.Json;
public sealed class EntityStatusInfo
{
/// <summary>
/// Gets or sets the entity logical name.
/// </summary>
[JsonProperty(PropertyName = "entitylogicalname")]
public string EntityLogicalName { get; set; }
/// <summary>
/// Gets or sets the object type code.
/// </summary>
[JsonProperty(PropertyName = "objecttypecode")]
public int ObjectTypeCode { get; set; }
/// <summary>
/// Gets or sets the primary field name.
/// </summary>
[JsonProperty(PropertyName = "primarynamefield")]
public string PrimaryNameField { get; set; }
/// <summary>
/// Gets or sets the last data sync time.
/// </summary>
[JsonProperty(PropertyName = "lastdatasynctimestamp")]
public string LastDataSyncTimeStamp { get; set; }
/// <summary>
/// Gets or sets the last principal object access sync time.
/// </summary>
[JsonProperty(PropertyName = "lastprincipalobjectaccesssynctimestamp")]
public string LastPrincipalObjectAccessSyncTimeStamp { get; set; }
/// <summary>
/// Gets or sets entity level status.
/// </summary>
[JsonProperty(PropertyName = "entitystatus")]
public string EntityStatus { get; set; }
/// <summary>
/// Gets or sets the dictionary of attribute name and details.
/// </summary>
[JsonProperty(PropertyName = "searchableindexedfieldinfomap")]
public IDictionary<string, FieldStatusInfo> SearchableIndexedFieldInfoMap { get; set; }
}
Classe FieldStatusInfo
Utilisée pour désérialiser les données FieldStatusInfo.
using Newtonsoft.Json;
using System.Diagnostics.CodeAnalysis;
namespace PowerApps.Samples.Search.Types;
[ExcludeFromCodeCoverage]
public sealed class FieldStatusInfo
{
/// <summary>
/// Gets or sets index field name.
/// </summary>
[JsonProperty(PropertyName = "indexfieldname")]
public string IndexFieldName { get; set; }
}
Classe ManyToManyRelationshipSyncStatus
Utilisée pour désérialiser les données ManyToManyRelationshipSyncStatus.
using Newtonsoft.Json;
public sealed class ManyToManyRelationshipSyncStatus
{
/// <summary>
/// Gets the relationship name.
/// </summary>
[JsonProperty("relationshipName")]
public string? RelationshipName { get; }
/// <summary>
/// Gets the relationship metadata id.
/// </summary>
[JsonProperty("relationshipMetadataId")]
public Guid RelationshipMetadataId { get; }
/// <summary>
/// Gets the search entity name.
/// </summary>
[JsonProperty("searchEntity")]
public string? SearchEntity { get; }
/// <summary>
/// Gets the second entity name.
/// </summary>
[JsonProperty("relatedEntity")]
public string? RelatedEntity { get; }
/// <summary>
/// Gets the search entity Id attribute.
/// </summary>
[JsonProperty("searchEntityIdAttribute")]
public string? SearchEntityIdAttribute { get; }
/// <summary>
/// Gets the related entity Id attribute.
/// </summary>
[JsonProperty("relatedEntityIdAttribute")]
public string? RelatedEntityIdAttribute { get; }
/// <summary>
/// Gets the intersect entity name.
/// </summary>
[JsonProperty("intersectEntity")]
public string? IntersectEntity { get; }
/// <summary>
/// Gets the search entity object type code.
/// </summary>
[JsonProperty("searchEntityObjectTypeCode")]
public int SearchEntityObjectTypeCode { get; }
/// <summary>
/// Gets the synced version.
/// </summary>
[JsonProperty("lastSyncedVersion")]
public string? LastSyncedDataVersion { get; }
}
Voir aussi
Rechercher des enregistrements Dataverse
Requête de recherche Dataverse
Suggestion de recherche Dataverse
Recherche par exécution automatique Dataverse
Recherche héritée Dataverse