Skip to content

Application to insert CSV file into a specified database with optimised columns lenght

Notifications You must be signed in to change notification settings

Maxime-Cllt/FileFlow

Repository files navigation

FileFlow

FileFlow

Rust Tauri Version
FileFlow FileFlow

Description

FileFlow is a simple tool that allows you to insert data from a CSV file into a table in a database. It is designed to be simple to use and to require no privilege to insert the data. Build with Rust and the Tauri framework, it is a cross-platform application that can be used on Windows, MacOS and Linux.

See in the release section for the latest version of the application.

Features

Insert data into a new table
Insert data into an existing table
Optimise the type of the columns (VARCHAR(MAX_LENGHT))
From CSV file
Don't require ANY privilege to insert the data
Generate LOAD DATA sql query to insert faster

Supported databases

MySQL MySQL PostgreSQL SQLite

Requirements

  • Rust
  • Cargo
  • pnpm

To install Rust and Cargo, you can follow the instructions on the Tauri website

Installation

  1. Clone the repository
git clone https://github.com/Maxime-Cllt/FileFlow.git
  1. Install the dependencies
cd FileFlow
pnpm install
  1. Build the application
pnpm tauri build
  1. Run the application
pnpm tauri dev

Usage

  1. Insert Data
    • Select the CSV file you want to insert into the database
    • Select the database you want to insert the data into
    • Click on the "Insert" button
    • Wait for the data to be inserted
    • Done!
  2. Generate Load data
    • Select the CSV file you want to insert into the database
    • Click on the "Load" button in the menu
    • Copy the generated SQL query
    • Run the query if your database support it
    • Done!

Information

There are two mode to insert the data into the database:

  • Optimised mode: The data is inserted into a new table with the type of the columns optimised (VARCHAR(MAX_LENGHT))
  • Fast mode: The data is inserted into an existing table with the type of the columns as they are in the CSV file

The optimised mode might take longer to insert the data but it will create a table with the type of the columns optimised.

You can also generate a LOAD DATA SQL query to insert the data faster if your database support it. It is way faster than inserting the data row by row but not all databases support it.

Contributing

If you want to contribute to the project, you can open an issue or a pull request.