Skip to main content

File Data Connector

The File Data Connector enables federated SQL queries on files stored by locally accessible filesystems. It supports querying individual files or entire directories, where all child files within the directory will be loaded and queried.

File formats are specified using the file_format parameter, as described in Object Store File Formats.

Example spicepod.yml

datasets:
- from: file://path/to/customer.parquet
name: customer
params:
file_format: parquet

Configuration​

from​

The from field for the File connector takes the form file://path where path is the path to the file to read from. See the examples below for examples of relative and absolute paths

name​

The dataset name. This will be used as the table name within Spice.

Example:

datasets:
- from: file://path/to/customer.parquet
name: cool_dataset
params: ...
SELECT COUNT(*) FROM cool_dataset;
+----------+
| count(*) |
+----------+
| 6001215 |
+----------+

params​

Parameter nameDescription
file_formatSpecifies the data file format. Required if the format cannot be inferred from the from path. Refer to Object Store File Formats for details.
hive_partitioning_enabledEnable partitioning using hive-style partitioning from the folder structure. Defaults to false

For CSV-specific parameters, see CSV Parameters.

Trigger data refresh on file change​

In addition to standard Data Refresh, a data refresh can also be triggered when the source file is modified. The File Data Connector uses a file system watcher to be notified the file has changed. The file watcher is disabled by default and can be enabled by setting the file_watcher parameter to enabled in the acceleration parameters.

datasets:
- from: file://path/to/my_file.csv
name: my_file
acceleration:
enabled: true
refresh_mode: full
params:
file_watcher: enabled

When the file is modified, the acceleration will be refreshed and will include the latest data.

Types​

Refer to Object Store Data Types for data type mapping from object store files to arrow data type.

Examples​

Absolute path​

In this example, path is an absolute path to the file on the filesystem.

datasets:
- from: file:///path/to/customer.parquet
name: customer
params:
file_format: parquet

Relative path​

In this example, the path is relative to the directory where the spicepod.yaml is located.

├── foo
│   └── yellow_tripdata_2024-01.parquet
└── spicepod.yaml
datasets:
- from: file://foo/yellow_tripdata_2024-01.parquet
name: trip_data
params:
file_format: parquet
Performance Considerations

When using the File Data connector without acceleration, data is loaded into memory during query execution. Ensure sufficient memory is available, including overhead for queries and the runtime, especially with concurrent queries.

Memory limitations can be mitigated by storing acceleration data on disk, which is supported by duckdb and sqlite accelerators by specifying mode: file.

Cookbook​

Refer to the File cookbook recipe to see an example of the File connector in use.