注: 以下の翻訳の正確性は検証されていません。AIPを利用して英語版の原文から機械的に翻訳されたものです。
プロパティのタイプによって、バケット化する方法について追加情報を提供する必要があります。
boolean
プロパティの場合、唯一のオプションは.topValues()
です。これは、true
用のバケットとfalse
用のバケットの2つを返します。.topValues()
: 迅速な応答時間とカーディナリティの小さいプロパティ用。文字列プロパティのトップ1,000の値でバケット化されます。この制限は、返される集計が過度に大きくならないようにするためです。.exactValues()
: より正確な集計と、高カーディナリティプロパティの最大10,000のバケットを考慮する可能性。考慮されるバケットの量は、.exactValues({"maxBuckets": numBuckets})
で指定できます。ここでnumBuckets
は0から10,000の間の整数値でなければなりません。この方法の応答時間は、考慮する結果が多くなるため、長くかかることがあります。Integer
、Long
、Float
、Double
)の場合、2つのバケット化オプションがあります。
.byRanges()
では、使用するべき正確な範囲を指定できます。たとえば、.byRanges({ min: 0, max: 50 }, { min: 50, max: 100 })
を使用して、ここで指定した[0, 50]および[50, 100]の2つの範囲にオブジェクトをバケット化できます。範囲のmin
は包括的であり、max
は排他的です。min
またはmax
のいずれかを省略すると、それぞれ-∞からmax
まで、またはmin
から∞までの値を含むバケットが表示されます。.byFixedWidth()
では、各バケットの幅を指定できます。たとえば、.byFixedWidth(50)
を使用して、幅が50の範囲にオブジェクトをバケット化できます。LocalDate
プロパティの場合、簡単なバケット化のためにさまざまな便利なメソッドが提供されています。
.byYear()
.byQuarter()
.byMonth()
.byWeek()
.byDays()
は、値を日単位でバケット化します。バケット幅に使用する日数を渡すことができます。Timestamp
プロパティの場合、LocalDate
と同じバケット化オプションが適用されますが、以下の追加オプションも適用されます。
.byHours()
は、値を時間単位でバケット化します。バケット幅に使用する時間数を渡すことができます。.byMinutes()
は、値を分単位でバケット化します。バケット幅に使用する分数を渡すことができます。.bySeconds()
は、値を秒単位でバケット化します。バケット幅に使用する秒数を渡すことができます。Array
プロパティの場合、バケット化オプションは配列内の要素のタイプによって決まります。特に、Array<PropertyType>
に対してPropertyType
と同じバケット化メソッドが得られます(例:Array<boolean>
はboolean
と同じバケット化メソッドが得られます)。
Array<string>
であるemployeeSet
があり、それぞれ["US", "UK"]
と["US"]
で働いたとします。その場合、employeeSet.groupBy(e => e.pastCountries.exactValue()).count()
は{ "US": 2, "UK": 1 }
を返します。1つのプロパティでグループ化した後、オプションで.segmentBy()
メソッドを呼び出してさらにバケット化を行うことができます。これにより、2つの検索可能プロパティでバケット化された3次元の集計を計算できます。たとえば、次のようにして従業員を開始日と役割でグループ化できます:
オブジェクトセットをグルーピングした後、各バケットで集約メトリックを計算するためのさまざまな集約メソッドを呼び出すことができます。プロパティが必要なメソッドは、searchable とマークされたプロパティのみを受け入れます。可能な集約方法は次のとおりです:
.count()
は各バケット内のオブジェクト数を単純に返します.average()
は指定された数値、タイムスタンプ、日付プロパティの平均数を返します.max()
は指定された数値、タイムスタンプ、日付プロパティの最大値を返します.min()
は指定された数値、タイムスタンプ、日付プロパティの最小値を返します.sum()
は指定された数値プロパティの値の合計を返します.cardinality()
は指定されたプロパティの異なる値の近似数を返しますこれらのメソッドのいずれかを呼び出すと、TwoDimensionalAggregation
または ThreeDimensionalAggregation
のいずれかが返されます。最終的な集約メソッドのいずれかを呼び出す前に .segmentBy()
を呼び出した場合、ThreeDimensionalAggregation
が返されます。
これらの集約タイプの構造、有効なバケットタイプを含む、詳しくはこちらをご覧ください。
結果の集約は Promise
でラップされていることに注意してください。集約を計算するためには、リモートサービスからデータをロードする必要があるためです。Promise
の結果を展開するためには、async/await ↗ の構文を使用できます。
以下は、集約をロードして結果として返す完全な例です。