A RetroSearch Logo

Home - News ( United States | United Kingdom | Italy | Germany ) - Football scores

Search Query:

Showing content from https://clickhouse.com/docs/sql-reference/table-functions/file/ below:

file | ClickHouse Docs

file Table Function

A table engine which provides a table-like interface to SELECT from and INSERT into files, similar to the s3 table function. Use file() when working with local files, and s3() when working with buckets in object storage such as S3, GCS, or MinIO.

The file function can be used in SELECT and INSERT queries to read from or write to files.

Syntax Arguments Parameter Description path The relative path to the file from user_files_path. Supports in read-only mode the following globs: *, ?, {abc,def} (with 'abc' and 'def' being strings) and {N..M} (with N and M being numbers). path_to_archive The relative path to a zip/tar/7z archive. Supports the same globs as path. format The format of the file. structure Structure of the table. Format: 'column1_name column1_type, column2_name column2_type, ...'. compression The existing compression type when used in a SELECT query, or the desired compression type when used in an INSERT query. Supported compression types are gz, br, xz, zst, lz4, and bz2. Returned value

A table for reading or writing data in a file.

Examples for Writing to a File Write to a TSV file

As a result, the data is written into the file test.tsv:

Partitioned write to multiple TSV files

If you specify a PARTITION BY expression when inserting data into a table function of type file(), then a separate file is created for each partition. Splitting the data into separate files helps to improve performance of read operations.

As a result, the data is written into three files: test_1.tsv, test_2.tsv, and test_3.tsv.

Examples for Reading from a File SELECT from a CSV file

First, set user_files_path in the server configuration and prepare a file test.csv:

Then, read data from test.csv into a table and select its first two rows:

Inserting data from a file into a table

Reading data from table.csv, located in archive1.zip or/and archive2.zip:

Globs in path

Paths may use globbing. Files must match the whole path pattern, not only the suffix or prefix. There is one exception that if the path refers to an existing directory and does not use globs, a * will be implicitly added to the path so all the files in the directory are selected.

Constructions with {} are similar to the remote and hdfs table functions.

Examples

Example

Suppose there are these files with the following relative paths:

Query the total number of rows in all files:

An alternative path expression which achieves the same:

Query the total number of rows in some_dir using the implicit *:

Note

If your listing of files contains number ranges with leading zeros, use the construction with braces for each digit separately or use ?.

Example

Query the total number of rows in files named file000, file001, ... , file999:

Example

Query the total number of rows from all files inside directory big_dir/ recursively:

Example

Query the total number of rows from all files file002 inside any folder in directory big_dir/ recursively:

Virtual Columns use_hive_partitioning setting

When setting use_hive_partitioning is set to 1, ClickHouse will detect Hive-style partitioning in the path (/name=value/) and will allow to use partition columns as virtual columns in the query. These virtual columns will have the same names as in the partitioned path, but starting with _.

Example

Use virtual column, created with Hive-style partitioning

Settings

RetroSearch is an open source project built by @garambo | Open a GitHub Issue

Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo

HTML: 3.2 | Encoding: UTF-8 | Version: 0.7.4