メインコンテンツまでスキップ
バージョン: 3.2

各テーブルタイプの機能

キーカラムとソートキー

主キーテーブル重複キーテーブル集計テーブルユニークキーテーブル
キーカラムとUNIQUE制約 主キーにはUNIQUE制約とNOT NULL制約があります。重複キーにはUNIQUE制約がありません。集計キーにはUNIQUE制約があります。ユニークキーにはUNIQUE制約があります。
キーカラムとデータ変更の論理的関係 新しいデータ行の主キー値がテーブル内の既存のデータ行と同じ場合、ユニーク制約違反が発生します。その場合、新しいデータ行が既存のデータ行を置き換えます。
ユニークキーテーブルと比較して、主キーテーブルは強化された基盤ストレージエンジンを持ち、ユニークキーテーブルを置き換えることができます。
重複キーにはUNIQUE制約がありません。そのため、新しいデータ行の重複キー値がテーブル内の既存のデータ行と同じ場合、新旧両方のデータ行がテーブルに保持されます。新しいデータ行の集計キー値がテーブル内の既存のデータ行と同じ場合、新旧のデータ行は集計キーと値カラムの集計関数に基づいて集計されます。新しいデータ行のユニークキー値がテーブル内の既存のデータ行と同じ場合、新しいデータ行が既存のデータ行を置き換えます。
ユニークキーテーブルは、集計関数がreplaceである集計テーブルと見なすことができます。
キーカラムとソートキーの関係v3.0.0以降、ソートキーは主キーテーブルの主キーから分離されています。キーカラムとソートキーは結合されています。
キーカラムとソートキーがサポートするデータタイプ 数値(整数とBOOLEANを含む)、文字列、日付(DATEとDATETIME)。数値(整数、BOOLEAN、DECIMALを含む)、文字列、日付(DATEとDATETIME)。
キーカラムとパーティション/バケット列の関係 パーティション列とバケット列は主キーに含まれている必要があります。なしパーティション列とバケット列は集計キーに含まれている必要があります。パーティション列とバケット列はユニークキーに含まれている必要があります。

キーと値カラムのデータタイプ

キーカラムは以下のデータタイプをサポートします: 数値(整数、BOOLEAN、DECIMALを含む)、文字列、日付(DATEとDATETIME)。

注記

主キーテーブルのキーカラムはDECIMALデータタイプをサポートしていません。

一方、値カラムは基本的なデータタイプをサポートしており、数値、文字列、日付(DATEとDATETIME)を含みます。BITMAP、HLL、および半構造化タイプのサポートは、異なるタイプのテーブルの値カラムによって異なります。詳細は以下の通りです:

主キーテーブル重複キーテーブル集計テーブルユニークキーテーブル
BITMAPサポートサポートされていませんサポート。集計関数はbitmap_union、replace、またはreplace_if_not_nullでなければなりません。サポート
HLLサポートサポートされていませんサポート。集計関数はhll_union、replace、またはreplace_if_not_nullでなければなりません。サポート
PERCENTILEサポートサポートされていませんサポート。集計関数はpercentile_union、replace、またはreplace_if_not_nullでなければなりません。サポート
半構造化データタイプ:JSON/ARRAY/MAP/STRUCTサポートサポートサポート。集計関数はreplaceまたはreplace_if_not_nullでなければなりません。サポート

データ変更

主キーテーブル重複キーテーブル集計テーブルユニークキーテーブル
データロードによるINSERT サポート。ロードジョブで__op=0を設定してINSERTを実現
内部実装では、StarRocksはINSERTとUPDATE操作の両方をUPSERT操作と見なします。
サポートサポート(同じ集計キー値を持つデータ行は集計されます。)サポート(同じユニークキー値を持つデータ行は更新されます。)
データロードによるUPDATE サポートされていませんサポート(これは集計関数としてreplaceを使用することで実現できます。)サポート(ユニークキーテーブル自体はreplace集計関数を使用する集計テーブルと見なせます。)
データロードによるDELETE サポート。ロードジョブで__op=1を設定してDELETEを実現サポートされていません
ロードされるデータカラム値の整合性 デフォルトでは、すべてのカラム値をロードする必要があります。ただし、部分カラム更新(partial_update)が有効になっている場合や、カラムにデフォルト値がある場合は、すべてのカラム値をロードする必要はありません。デフォルトでは、すべてのカラム値をロードする必要があります。ただし、カラムにデフォルト値がある場合は、すべてのカラム値をロードする必要はありません。デフォルトでは、すべてのカラム値をロードする必要があります。ただし、集計テーブルは値カラムの集計関数をREPLACE_IF_NOT_NULLとして指定することで部分カラム更新を実現できます。詳細はaggr_typeを参照してください。また、カラムにデフォルト値がある場合は、すべてのカラム値をロードする必要はありません。デフォルトでは、すべてのカラム値をロードする必要があります。ただし、カラムにデフォルト値がある場合は、すべてのカラム値をロードする必要はありません。
DML INSERTサポート
DML UPDATE
  • フィルター条件としてのキーカラム: サポート
  • フィルター条件としての値カラム: サポート
サポートされていません
DML DELETE
  • フィルター条件としてのキーカラム: サポート
  • フィルター条件としての値カラム: サポート
  • フィルター条件としてのキーカラム: サポート
  • フィルター条件としての値カラム: サポート
注意: キーまたは値カラム自体に基づく単純なフィルター条件(=、<、>など)のみがサポートされており、関数やサブクエリなどの複雑なフィルター条件はサポートされていません。
  • フィルター条件としてのキーカラム: サポート。注意: キーカラム自体に基づく単純なフィルター条件(=、<、>など)のみがサポートされており、関数やサブクエリなどの複雑なフィルター条件はサポートされていません。
  • フィルター条件としての値カラム: サポートされていません。

他の機能との互換性

主キーテーブル重複キーテーブル集計テーブルユニークキーテーブル
ビットマップインデックス/ブルームフィルターインデックスキーカラムにインデックスを構築サポート
値カラムにインデックスを構築サポートサポートサポートされていませんサポートされていません
パーティション化/バケット化式に基づくパーティション化/リストパーティション化サポート
ランダムバケット法サポートされていませんv3.1以降でサポートサポートされていませんサポートされていません
マテリアライズドビュー非同期マテリアライズドビューサポート
同期マテリアライズドビューサポートされていませんサポートサポートサポート
その他の機能CTASサポートサポートサポートされていませんサポートされていません
バックアップとリストアv2.5以降でサポートサポート
Rocky the happy otterStarRocks Assistant

AI generated answers are based on docs and other sources. Please test answers in non-production environments.