IoTDB supports three methods for data import:
import-data.sh/bat script in the tools directory to manually import CSV, SQL, or TsFile (open-source time-series file format) data into IoTDB.TsFile Auto-Loading FeatureTsFile SQL| Short | Full Parameter | Description | Required | Default |
|---|---|---|---|---|
-ft | --file_type | File type: csv, sql, tsfile. | Yes | - |
-h | --host | IoTDB server hostname. | No | 127.0.0.1 |
-p | --port | IoTDB server port. | No | 6667 |
-u | --username | Username. | No | root |
-pw | --password | Password. | No | TimechoDB@2021(Before V2.0.6 it is root ) |
-s | --source | Local path to the file/directory to import. Supported formats: CSV, SQL, TsFile. Unsupported formats trigger error: The file name must end with "csv", "sql", or "tsfile"! | Yes | - |
-tn | --thread_num | Maximum parallel threads | No | 8 Range: 0 to Integer.Max(2147483647). |
-tz | --timezone | Timezone (e.g., +08:00, -01:00). | No | System default |
-help | --help | Display help (general or format-specific: -help csv). | No | - |
# Unix/OS X > tools/import-data.sh -ft<format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s <source> [-fd <fail_dir>] [-lpf <lines_per_failed_file>] [-aligned <use the aligned interface>] [-ti <type_infer>] [-tp <timestamp precision (ms/us/ns)>] [-tz <timezone>] [-batch <batch_size>] [-tn <thread_num>] # Windows # Before version V2.0.4.x > tools\import-data.bat -ft<format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s <source> [-fd <fail_dir>] [-lpf <lines_per_failed_file>] [-aligned <use the aligned interface>] [-ti <type_infer>] [-tp <timestamp precision (ms/us/ns)>] [-tz <timezone>] [-batch <batch_size>] [-tn <thread_num>] # V2.0.4.x and later versions > tools\windows\import-data.bat -ft<format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s <source> [-fd <fail_dir>] [-lpf <lines_per_failed_file>] [-aligned <use the aligned interface>] [-ti <type_infer>] [-tp <timestamp precision (ms/us/ns)>] [-tz <timezone>] [-batch <batch_size>] [-tn <thread_num>]
| Short | Full Parameter | Description | Required | Default |
|---|---|---|---|---|
-fd | --fail_dir | Directory to save failed files. | No | YOUR_CSV_FILE_PATH |
-lpf | --lines_per_failed_file | Max lines per failed file. | No | 100000 Range: 0 to Integer.Max(2147483647). |
-aligned | --use_aligned | Import as aligned time series. | No | false |
-batch | --batch_size | Rows processed per API call. | No | 100000 Range: 0 to Integer.Max(2147483647). |
-ti | --type_infer | Type mapping (e.g., BOOLEAN=text,INT=long). | No | - |
-tp | --timestamp_precision | Timestamp precision: ms, us, ns. | No | ms |
# Valid Example > tools/import-data.sh -ft csv -h 127.0.0.1 -p 6667 -u root -pw TimechoDB@2021 -s /path/sql -fd /path/failure/dir -lpf 100 -aligned true -ti "BOOLEAN=text,INT=long,FLOAT=double" -tp ms -tz +08:00 -batch 5000 -tn 4 # Error Example > tools/import-data.sh -ft csv -s /non_path error: Source file or directory /non_path does not exist > tools/import-data.sh -ft csv -s /path/sql -tn 0 error: Invalid thread number '0'. Please set a positive integer. # Note: Before version V2.0.6, the default value for the -pw parameter was root.
-- Headers without data types Time,root.test.t1.str,root.test.t2.str,root.test.t2.var 1970-01-01T08:00:00.001+08:00,"123hello world","123\,abc",100 1970-01-01T08:00:00.002+08:00,"123",, -- Headers with data types (Text-type data supports both quoted and unquoted formats) Time,root.test.t1.str(TEXT),root.test.t2.str(TEXT),root.test.t2.var(INT32) 1970-01-01T08:00:00.001+08:00,"123hello world","123\,abc",100 1970-01-01T08:00:00.002+08:00,123,hello world,123 1970-01-01T08:00:00.003+08:00,"123",, 1970-01-01T08:00:00.004+08:00,123,,12
-- Headers without data types Time,Device,str,var 1970-01-01T08:00:00.001+08:00,root.test.t1,"123hello world", 1970-01-01T08:00:00.002+08:00,root.test.t1,"123", 1970-01-01T08:00:00.001+08:00,root.test.t2,"123\,abc",100 -- Headers with data types (Text-type data supports both quoted and unquoted formats) Time,Device,str(TEXT),var(INT32) 1970-01-01T08:00:00.001+08:00,root.test.t1,"123hello world", 1970-01-01T08:00:00.002+08:00,root.test.t1,"123", 1970-01-01T08:00:00.001+08:00,root.test.t2,"123\,abc",100 1970-01-01T08:00:00.002+08:00,root.test.t1,hello world,123
# Unix/OS X > tools/import-data.sh -ft<format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s<source> [-fd <fail_dir>] [-lpf <lines_per_failed_file>] [-tz <timezone>] [-batch <batch_size>] [-tn <thread_num>] # Windows # Before version V2.0.4.x > tools\import-data.bat -ft<format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s<source> [-fd <fail_dir>] [-lpf <lines_per_failed_file>] [-tz <timezone>] [-batch <batch_size>] [-tn <thread_num>] # V2.0.4.x and later versions > tools\windows\import-data.bat -ft<format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s<source> [-fd <fail_dir>] [-lpf <lines_per_failed_file>] [-tz <timezone>] [-batch <batch_size>] [-tn <thread_num>]
| Short | Full Parameter | Description | Required | Default |
|---|---|---|---|---|
-fd | --fail_dir | Directory to save failed files. | No | YOUR_CSV_FILE_PATH |
-lpf | --lines_per_failed_file | Max lines per failed file. | No | 100000 Range: 0 to Integer.Max(2147483647). |
-batch | --batch_size | Rows processed per API call. | No | 100000 Range: 0 to Integer.Max(2147483647). |
# Valid Example > tools/import-data.sh -ft sql -h 127.0.0.1 -p 6667 -u root -pw TimechoDB@2021 -s /path/sql -fd /path/failure/dir -lpf 500 -tz +08:00 -batch 100000 -tn 4 # Error Example > tools/import-data.sh -ft sql -s /path/sql -fd /non_path error: Source file or directory /path/sql does not exist > tools/import-data.sh -ft sql -s /path/sql -tn 0 error: Invalid thread number '0'. Please set a positive integer. # Note: Before version V2.0.6, the default value for the -pw parameter was root.
# Unix/OS X > tools/import-data.sh -ft <format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s <source> -os <on_success> [-sd <success_dir>] -of <on_fail> [-fd <fail_dir>] [-tn <thread_num> ] [-tz <timezone>] [-tp <timestamp precision (ms/us/ns)>] # Windows # Before version V2.0.4.x > tools\import-data.bat -ft <format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s <source> -os <on_success> [-sd <success_dir>] -of <on_fail> [-fd <fail_dir>] [-tn <thread_num> ] [-tz <timezone>] [-tp <timestamp precision (ms/us/ns)>] # V2.0.4.x and later versions > tools\windows\import-data.bat -ft <format> [-h <host>] [-p <port>] [-u <username>] [-pw <password>] -s <source> -os <on_success> [-sd <success_dir>] -of <on_fail> [-fd <fail_dir>] [-tn <thread_num> ] [-tz <timezone>] [-tp <timestamp precision (ms/us/ns)>]
| Short | Full Parameter | Description | Required | Default |
|---|---|---|---|---|
-os | --on_success | Action for successful files:none: Do not delete the file.mv: Move the successful file to the target directory.cp:Create a hard link (copy) of the successful file to the target directory.delete:Delete the file. | Yes | - |
-sd | --success_dir | Target directory for mv/cp actions on success. Required if -os is mv/cp. The file name will be flattened and concatenated with the original file name. | Conditional | ${EXEC_DIR}/success |
-of | --on_fail | Action for failed files:none:Skip the file.mv:Move the failed file to the target directory.cp:Create a hard link (copy) of the failed file to the target directory.delete:Delete the file.. | Yes | - |
-fd | --fail_dir | Target directory for mv/cp actions on failure. Required if -of is mv/cp. The file name will be flattened and concatenated with the original file name. | Conditional | ${EXEC_DIR}/fail |
-tp | --timestamp_precision | TsFile timestamp precision: ms, us, ns. For non-remote TsFile imports: Use -tp to specify the timestamp precision of the TsFile. The system will manually verify if the timestamp precision matches the server. If it does not match, an error will be returned. For remote TsFile imports: Use -tp to specify the timestamp precision of the TsFile. The Pipe system will automatically verify if the timestamp precision matches. If it does not match, a Pipe error will be returned. | No | ms |
# Valid Example > tools/import-data.sh -ft tsfile -h 127.0.0.1 -p 6667 -u root -pw TimechoDB@2021 -s /path/sql -os mv -of cp -sd /path/success/dir -fd /path/failure/dir -tn 8 -tz +08:00 -tp ms # Error Example > tools/import-data.sh -ft tsfile -s /path/sql -os mv -of cp -fd /path/failure/dir -tn 8 error: Missing option --success_dir (or -sd) when --on_success is 'mv' or 'cp' > tools/import-data.sh -ft tsfile -s /path/sql -os mv -of cp -sd /path/success/dir -fd /path/failure/dir -tn 0 error: Invalid thread number '0'. Please set a positive integer. # Note: Before version V2.0.6, the default value for the -pw parameter was root.
This feature enables IoTDB to automatically monitor a specified directory for new TsFiles and load them into the database without manual intervention.
Add the following parameters to iotdb-system.properties (template: iotdb-system.properties.template):
| Parameter | Description | Value Range | Required | Default | Hot-Load? |
|---|---|---|---|---|---|
load_active_listening_enable | Enable auto-loading. | true/false | Optional | true | Yes |
load_active_listening_dirs | Directories to monitor (subdirectories included). Multiple paths separated by commas. | String | Optional | ext/load/pending | Yes |
load_active_listening_fail_dir | Directory to store failed TsFiles. Only can set one. | String | Optional | ext/load/failed | Yes |
load_active_listening_max_thread_num | Maximum Threads for TsFile Loading Tasks:The default value for this parameter, when commented out, is max(1, CPU cores / 2). If the value set by the user falls outside the range [1, CPU cores / 2], it will be reset to the default value of max(1, CPU cores / 2). | 1 to Long.MAX_VALUE | Optional | max(1, CPU_CORES / 2) | No (restart required) |
load_active_listening_check_interval_seconds | Active Listening Polling Interval (in seconds):The active listening feature for TsFiles is implemented through polling the target directory. This configuration specifies the time interval between two consecutive checks of the load_active_listening_dirs. After each check, the next check will be performed after load_active_listening_check_interval_seconds seconds. If the polling interval set by the user is less than 1, it will be reset to the default value of 5 seconds. | 1 to Long.MAX_VALUE | Optional | 5 | No (restart required) |
.mods files, move .mods files to the monitored directory before their corresponding TsFiles. Ensure .mods and TsFiles are in the same directory.load_active_listening_fail_dir does not overlap with load_active_listening_dirs or its subdirectories.IoTDB supports importing one or multiple TsFile files containing time series into another running IoTDB instance directly via SQL execution through the CLI.
load '<path/dir>' with ( 'attribute-key1'='attribute-value1', 'attribute-key2'='attribute-value2', )
<path/dir> : The path to a TsFile or a folder containing multiple TsFiles.<attributes>: Optional parameters, as described below.| Key | Key Description | Value Type | Value Range | Value is Required | Default Value |
|---|---|---|---|---|---|
database-level | When the database corresponding to the TsFile does not exist, the database hierarchy level can be specified via the database-level parameter. The default is the level set in iotdb-common.properties. For example, setting level=1 means the prefix path of level 1 in all time series in the TsFile will be used as the database. | Integer | [1: Integer.MAX_VALUE] | No | 1 |
on-success | Action for successfully loaded TsFiles: delete (delete the TsFile after successful import) or none (retain the TsFile in the source folder). | String | delete / none | No | delete |
model | Specifies whether the TsFile uses the table model or tree model. | String | tree / table | No | Aligns with -sql_dialect |
database-name | Table model only: Target database for import. Automatically created if it does not exist. The database-name must not include the root. prefix (an error will occur if included). | String | - | No | null |
convert-on-type-mismatch | Whether to perform type conversion during loading if data types in the TsFile mismatch the target schema. | Boolean | true / false | No | true |
verify | Whether to validate the schema before loading the TsFile. | Boolean | true / false | No | true |
tablet-conversion-threshold | Size threshold (in bytes) for converting TsFiles into tablet format during loading. Default: -1 (no conversion for any TsFile). | Integer | [-1,0 :Integer.MAX_VALUE] | No | -1 |
async | Whether to enable asynchronous loading. If enabled, TsFiles are moved to an active-load directory and loaded into the database-name asynchronously. | Boolean | true / false | No | false |
-- Before import IoTDB> show databases +-------------+-----------------------+---------------------+-------------------+---------------------+ | Database|SchemaReplicationFactor|DataReplicationFactor|TimePartitionOrigin|TimePartitionInterval| +-------------+-----------------------+---------------------+-------------------+---------------------+ |root.__system| 1| 1| 0| 604800000| +-------------+-----------------------+---------------------+-------------------+---------------------+ -- Import tsfile by excuting load sql IoTDB> load '/home/dump1.tsfile' with ( 'on-success'='none') Msg: The statement is executed successfully. -- Verify whether the import was successful IoTDB> select * from root.testdb.** +-----------------------------+------------------------------------+---------------------------------+-------------------------------+ | Time|root.testdb.device.model.temperature|root.testdb.device.model.humidity|root.testdb.device.model.status| +-----------------------------+------------------------------------+---------------------------------+-------------------------------+ |2025-04-17T10:35:47.218+08:00| 22.3| 19.4| true| +-----------------------------+------------------------------------+---------------------------------+-------------------------------+