Stream Load
1. Stream Load は、CSV 形式のファイルの最初の数行に含まれる列名を識別したり、データ読み取り時に最初の数行をスキップすることをサポートしていますか?
Stream Load は、CSV 形式のファイルの最初の数行に含まれる列名を識別することをサポートしていません。Stream Load は、最初の数行を他の行と同様に通常のデータとして扱います。
バージョン 2.5 以前では、Stream Load はデータ読み取り時に CSV ファイルの最初の数行をスキップすることをサポートしていません。ロードしたい CSV ファイルの最初の数行に列名が含まれている場合、次のいずれかのアクションを取ってください。
- データをエクスポートするために使用するツールの設定を変更します。その後、最初の数行に列名が含まれていない CSV ファイルとしてデータを再エクスポートします。
sed -i '1d' filename
などのコマンドを使用して、CSV ファイルの最初の数行を削除します。- ロードコマンドまたはステートメントで、
-H "where: <column_name> != '<column_name>'"
を使用して、CSV ファイルの最初の数行をフィルタリングします。<column_name>
は最初の数行に含まれる列名のいずれかです。StarRocks は最初にソースデータを変換し、その後にフィルタリングを行います。そのため、最初の数行の列名が対応するデータ型に変換できない場合、それらにはNULL
値が返されます。これは、StarRocks のテーブルにNOT NULL
に設定された列を含めることができないことを意味します。 - ロードコマンドまたはステートメントで、
-H "max_filter_ratio:0.01"
を追加して、1% 以下の最大エラー許容値を設定し、最初の数行のデータ変換失敗を無視できるようにします。この場合、ErrorURL
がエラーロウを示すために返されても、Stream Load ジョブは成功することができます。max_filter_ratio
を大きな値に設定しないでください。大きな値に設定すると、重要なデータ品質の問題が見逃される可能性があります。
バージョン 3.0 以降、Stream Load は skip_header
パラメータをサポートしており、CSV ファイルの最初の数行をスキップするかどうかを指定できます。詳細については、CSV parameters を参照してください。
2. パーティション列にロードするデータが標準の DATE または INT 型ではありません。例えば、データが 202106.00 のような形式の場合、Stream Load を使用してデータをロードする際にどのように変換すればよいですか?
StarRocks はロード時にデータを変換することをサポートしています。詳細については、Transform data at loading を参照してください。
例えば、TEST
という名前の CSV 形式のファイルをロードしたいとし、そのファイルが NO
、DATE
、VERSION
、PRICE
の 4 列で構成されており、その中の DATE
列のデータが 202106.00 のような非標準形式であるとします。StarRocks で DATE
をパーティション列として使用したい場合、まず次の 4 列で構成される StarRocks テーブルを作成する必要があります: NO
、VERSION
、PRICE
、DATE
。次に、StarRocks テーブルの DATE
列のデータ型を DATE、DATETIME、または INT として指定する必要があります。最後に、Stream Load ジョブを作成する際に、ロードコマンドまたはステートメントで次の設定を指定して、ソース DATE
列のデータ型を宛先列のデータ型に変換します。
-H "columns: NO,DATE_1, VERSION, PRICE, DATE=LEFT(DATE_1,6)"
上記の例では、DATE_1
は宛先 DATE
列にマッピングされる一時的な名前の列と見なすことができ、宛先 DATE
列にロードされる最終結果は left()
関数によって計算されます。まずソース列の一時的な名前をリストし、その後に関数を使用してデータを変換する必要があります。サポートされている関数はスカラー関数で、非集計関数やウィンドウ関数を含みます。
3. Stream Load ジョブが "body exceed max size: 10737418240, limit: 10737418240" エラーを報告した場合、どうすればよいですか?
ソースデータファイルのサイズが 10 GB を超えており、これは Stream Load がサポートする最大ファイルサイズです。次のいずれかのアクションを取ってください。
seq -w 0 n
を使用して、ソースデータファイルを小さなファイルに分割します。curl -XPOST http://be_host:http_port/api/update_config?streaming_load_max_mb=<file_size>
を使用して、BE configuration itemstreaming_load_max_mb
の値を調整し、最大ファイルサイズを増やします。