次の方法で共有


Dataverse 検索の提案

この API を使用して、より豊かな検索ボックスのエクスペリエンスをサポートできます。 たとえば、ユーザーが検索語句の各文字を入力すると、この API が呼び出され、検索フィールドのドロップダウン リストに提案されたクエリ結果が入力されます。

検索語句に加えて、返される結果は、次のパラメーターに渡される値によって影響を受ける可能性があります。

件名 タイプ Description 詳細情報
search string 必須。 検索するための語句。 検索パラメーター
entities string 既定では、検索の構成済みエンティティ全体を検索します。 entities パラメーター
filter string 返される結果を減らすためのフィルター条件。 filter パラメーター
fuzzy ブール値 あいまい検索を使用して、スペルミスを防ぎます。 既定値は false です。 fuzzy パラメーター
options string オプションは、検索語句 を検索するように構成された設定です。 たとえば、"{ 'advancedsuggestenabled': 'true' }" options パラメーター
orderby string 各句が属性名とそれに続く asc または desc で構成されるカンマ区切りの句のリスト。 orderby パラメーター
top int 取得する提案の数。 既定値は 5 です。 top パラメーター

Parameters

このセクションには、上の表によって導入されたパラメーターに関する詳細が含まれています。

search パラメーター

種類: 文字列
オプション: 無効

検索するための語句。 検索語句は、少なくとも 3 文字の長さがある必要があり、100 文字の制限があります。

entities パラメーター

種類: 文字列
オプション: 有効

既定では、検索の構成済みエンティティ全体を検索します。 このプロパティを使用して結果を絞り込みます。

filter パラメーター

種類: 文字列
オプション: 有効

フィルター条件に一致するレコードに基づいて返される結果を減らすためのフィルター条件。

fuzzy パラメーター

種類: ブール値
オプション: 有効

あいまい検索を使用して、スペルミスを防ぎます。 既定値は false です。

options パラメーター

種類: 文字列
オプション: 有効

オプションは、検索語句 を検索するように構成された設定です。 提案クエリの有効なオプションは次のとおりです。

"{ 'advancedsuggestenabled': 'true' }"

orderby パラメーター

種類: 文字列
オプション: 有効

各句が属性名とそれに続く asc または desc で構成されるカンマ区切りの句のリスト。

top パラメーター

タイプ: 整数
オプション: 有効

取得する提案の数。 既定値は 5 です。

回答

提案操作からの応答は、JSON データを含むエスケープ文字列です。

エスケープされていない応答には、次のプロパティを使用する JSON が含まれています。

件名 タイプ Description
Error ErrorDetail Azure Cognitive Search からのエラー情報を提供します。
Value SuggestResult[] 一致するレコードのコレクション。
QueryContext QueryContext 応答の一部として返されるクエリ コンテキスト。 このプロパティはバックエンド検索に使用されます。 これは今後の機能リリースに含まれ、現在は使用されていません。

応答のタイプ

応答は次のタイプを返します。

ErrorDetail

これは、クエリ API によって返される ErrorDetail と同じです。

SuggestResult

提案されたテキストを提供します。

件名 タイプ Description
Text string 提案されたテキストを提供します。
Document Dictionary<string, object> ドキュメント

QueryContext

これは、クエリ API によって返される QueryContext と同じです。

使用例

次の例は、提案操作の使用方法を示しています。 これらの各例では、値「Cont」を検索パラメーターとして渡し、上位 3 つの候補を要求します。

これは、GitHub の SDK for .NET 検索操作のサンプルからの例です。 OutputSearchSuggest 静的メソッドは、検索語句 の上位 3 つの候補を返します。

/// <summary>
/// Demonstrate suggest API
/// </summary>
/// <param name="service">The authenticated IOrganizationService instance to use.</param>
/// <param name="searchTerm">The term to use</param>
/// <returns></returns>
static void OutputSearchSuggest(IOrganizationService service, string searchTerm)
{
    Console.WriteLine("OutputSearchSuggest START\n");

    searchsuggestRequest request = new()
    {
        search = searchTerm,
        top = 3
    };

    var searchsuggestResponse = (searchsuggestResponse)service.Execute(request);

    SearchSuggestResults results = JsonConvert.DeserializeObject<SearchSuggestResults>(searchsuggestResponse.response);

    results.Value?.ForEach(suggestion =>
    {
        Console.WriteLine($"\tText:{suggestion.Text}");
        Console.WriteLine("\tDocument: ");
        foreach (string key in suggestion.Document.Keys)
        {
            Console.WriteLine($"\t\t{key}: {suggestion.Document[key]}");
        }
        Console.WriteLine();
    });

    Console.WriteLine("OutputSearchSuggest END\n");
}

出力

searchTerm を「Cont」に設定して ServiceClient クラスの認証されたインスタンスで OutputSearchSuggest メソッドを呼び出す場合。

OutputSearchSuggest(service: serviceClient, searchTerm: "Cont");

出力は次のようになります。

OutputSearchSuggest START

        Text:{crmhit}cont{/crmhit}act
        Document:
                @search.objectid: aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb
                @search.entityname: contact
                @search.objecttypecode: 2
                fullname: Yvonne McKay (sample)

        Text:{crmhit}cont{/crmhit}act
        Document:
                @search.objectid: bbbbbbbb-1111-2222-3333-cccccccccccc
                @search.entityname: contact
                @search.objecttypecode: 2
                fullname: Susanna Stubberod (sample)

        Text:{crmhit}cont{/crmhit}act
        Document:
                @search.objectid: cccccccc-2222-3333-4444-dddddddddddd
                @search.entityname: contact
                @search.objecttypecode: 2
                fullname: Nancy Anderson (sample)

OutputSearchSuggest END

サポートするクラス

OutputSearchSuggest メソッドは、次のサポートするクラスに基づいて要求を送信し、結果を処理します。

searchsuggestRequest クラスと searchsuggestResponse クラス

これらのクラスは、.NET 用 SDK の事前バインド クラスを生成するで説明されているように、Power Platform CLI pac modelbuilder build コマンドを使用して生成されます。

ErrorDetail クラス

このクラスは、クエリの例 で使用されたのと同じ ErrorDetail クラスです。

SuggestResults クラス

searchsuggestResponse.response プロパティからデータを逆シリアル化するために使用される

class SearchSuggestResults
{
   /// <summary>
   /// Provides error information from Azure Cognitive search.
   /// </summary>
   [JsonProperty(PropertyName = "Error")]
   public ErrorDetail? Error { get; set; }

   /// <summary>
   /// A collection of matching records.
   /// </summary>
   public List<SuggestResult>? Value { get; set; }

   /// <summary>
   /// The query context returned as part of response. This property is used for backend search, this is included for future feature releases, it is not currently used.
   /// </summary>
   public QueryContext? QueryContext { get; set; }
}
SuggestResult クラス

提案結果の結果オブジェクト。

public sealed class SuggestResult
{
   /// <summary>
   /// Gets or sets the text.
   /// </summary>
   [JsonProperty(PropertyName = "text")]
   public string Text { get; set; }

   /// <summary>
   /// Gets or sets document.
   /// </summary>
   [JsonProperty(PropertyName = "document")]
   public Dictionary<string, object> Document { get; set; }
}
QueryContext クラス

このクラスは、クエリの例 で使用されたのと同じ QueryContext クラスです。

参照

Dataverse レコードの検索
Dataverse の検索クエリ
Dataverse の検索のオートコンプリート
Dataverse の統計と状態を検索する
Dataverse のレガシ検索