Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/seipan/csql

CLI tool to insert CSV data into a specified database.
https://github.com/seipan/csql

csv csv-parser mysql postgresql sql

Last synced: 2 months ago
JSON representation

CLI tool to insert CSV data into a specified database.

Awesome Lists containing this project

README

        

![Last commit](https://img.shields.io/github/last-commit/seipan/csql?style=flat-square)
![Repository Stars](https://img.shields.io/github/stars/seipan/csql?style=flat-square)
![Issues](https://img.shields.io/github/issues/seipan/csql?style=flat-square)
![Open Issues](https://img.shields.io/github/issues-raw/seipan/csql?style=flat-square)
[![go](https://github.com/seipan/csql/actions/workflows/go.yml/badge.svg)](https://github.com/seipan/csql/actions/workflows/go.yml)
![codecov](https://codecov.io/gh/seipan/csql/graph/badge.svg?token=6TCAKD8LY7)

eyecatch

# csql

⭐ CLI tool to insert CSV data into a specified database. ⭐




## Install
```
go install github.com/seipan/csql@latest
```

## Usage
command option
```
Usage:
csql [flags]

Flags:
-c, --check check csv format
-d, --dsn string DSN for Connecting Database
-h, --help help for csql
-p, --path string FilePath for Parsing CSVFile
-q, --query output query
-t, --type string Database Type
```
Type, DSN, and path can be specified not only from command-line arguments but also from the .csql.yaml file. Below is an example.
```
type: mysql
dsn: hogehoge
filepath: ./test.csv
```
### ```--dsn```
dsn represents the Data Source Name of the database into which you want to insert CSV data.
### ```--path``` option
path represents the file path of the CSV you want to analyze this time.
### ```--type``` option
type represents the type of the database. Currently, it supports mariaDB, mysql, postgres, and sqlite3.
### ```--check``` option
if success patern
```
csql --check --path=./testdata/csv/test01.csv --type=mysql --dsn=hogehoge

___________ ____ __
/ ____/ ___// __ \ / /
/ / \__ \/ / / / / /
/ /___ ___/ / /_/ / / /___
\____//____/\___\_\/_____/

csv format is correct
```
failed pattern
```
csql --check --path=./testdata/csv/test02.csv --type=mysql --dsn=hogehoge

___________ ____ __
/ ____/ ___// __ \ / /
/ / \__ \/ / / / / /
/ /___ ___/ / /_/ / / /___
\____//____/\___\_\/_____/

csv format is incorrect : table name is empty
exit status 1
```

### ```--query``` option
```
csql --query --path=./testdata/csv/test01.csv --type=mysql --dsn="hoge:hoge@tcp(hoge:3306)/hoge?charset=utf8&parseTime=true"

___________ ____ __
/ ____/ ___// __ \ / /
/ / \__ \/ / / / / /
/ /___ ___/ / /_/ / / /___
\____//____/\___\_\/_____/

INSERT INTO user (name, id, email) VALUES (?, ?, ?)
```
### ```insert``` option
```
csql --path=./testdata/csv/test01.csv --type=mysql --dsn="hoge:hoge@tcp(localhost:3308)/hoge?parseTime=true&collation=utf8mb4_bin"

___________ ____ __
/ ____/ ___// __ \ / /
/ / \__ \/ / / / / /
/ /___ ___/ / /_/ / / /___
\____//____/\___\_\/_____/

insert 2 rows
Inserting: | 100%%
```
## License
Code licensed under
[the MIT License](https://github.com/seipan/csql/blob/main/LICENSE).

## Author
[seipan](https://github.com/seipan).