Heimdall is a command-line import and export tool specially designed for MySQL. With it, you can directly export query results to files in xlsx, csv, markdown, html, json, yaml, xml, sql and other formats by writing SQL , and files in xlsx and csv formats can also be imported into database tables.
command line options
heimdall The following commands are supported
- import (alias load) to import an xlsx or csv file into a database table
- export (alias query) to export SQL query results to files in various formats
import/load
use import/load command, you can import database from xlsx or csv file into data table. The following command line options are supported:
- –host value, -H value MySQL host (default: “127.0.0.1”)
- –port value, -P value MySQL port (default: 3306)
- –user value, -u value MySQL user (default: “root”)
- –password value, -p value MySQL password
- –database value, -d value MySQL database
- –connect-timeout value database connect timeout (default: 3s)
- –debug, -D Debug mode (default: false)
- –file value, -i value, –input value [ –file value, -i value, –input value ] input excel or csv file path, this flag can be specified multiple times for importing multiple files at the same time
- –table value, -t value target table name
- –field value, -f value [ –field value, -f value ] field map, eg: excel_field:db_field, this flag can be specified multiple times
- –include value, -I value [ –include value, -I value ] include fields, if set, only these fields will be imported, this flag can be specified multiple times
- –exclude value, -E value [ –exclude value, -E value ] exclude fields, if set, these fields will be ignored, this flag can be specified multiple times
- –csv-sepertor value csv file sepertor, default is ‘,’ (default: “,”)
- –tx, -T import data using transaction, all success or all failure, only work with InnoDB or other engines that support transaction (default: false)
- –dry-run perform import tests to verify correctness of imported files, but do not commit transactions, only work with InnoDB or other engines that support transaction (default: false)
- –help, -h show help (default: false)
export/query
use export/query command, you can export SQL query results to files in various formats, currently supporting formats such as JSON/YAML/Markdown/CSV/XLSX/HTML/SQL. The following command line options are supported:
- –host value, -H value MySQL host (default: “127.0.0.1”)
- –port value, -P value MySQL port (default: 3306)
- –user value, -u value MySQL user (default: “root”)
- –password value, -p value MySQL password
- –database value, -d value MySQL database
- –connect-timeout value database connect timeout (default: 3s)
- –debug, -D Debug mode (default: false)
- –sql value, -s value SQL statement
- –format value, -f value output format, support csv, json, yaml, xml, table, html, markdown, xlsx, plain, sql (default: “csv”)
- –output value, -o value write output to a file, default output directly to STDOUT
- –streaming, -S whether to use streaming output, if using streaming output, it will not wait for the query to complete, but output line by line during the query process. The output format only supports csv/xlsx/json/plain/sql (default: false)
- –no-header, -n do not write table header (default: false)
- –query-timeout value, -t value query timeout, when the stream option is specified, this option is invalid (default: 2m0s)
- –xlsx-max-row-value The maximum number of rows per sheet in an Excel file, including the row where the header is located (default: 1048576)
- –table value When the format is sql, specify the table name
- –help, -h show help (default: false)
example
Import the content of the xlsx file into the database table people, the title area corresponds to the field area, the name corresponds to name, and the ID number corresponds to idcard:
heimdall import --host 127.0.0.1 --port 3306 --database example --user root --password root \ --table people \ --field 区域:area \ --field 姓名:name \ --field 身份证号码:idcard \ --file ~/Downloads/data.xlsx
Export the list of newly added customer companies in the last 30 days from the business library as an Excel file
heimdall export --database example --host 127.0.0.1 --user root --password root \ --sql "SELECT id, name AS '企业名称', address AS '企业地址', city_name AS '城市', district_name AS '区县', DATE_FORMAT(created_at, '%Y-%m-%d %H:%i:%s') AS '创建时间' FROM enterprise WHERE created_at > DATE_SUB(NOW(), INTERVAL 30 DAY) ORDER BY id DESC" \ --streaming \ --format xlsx \ --output 最近30天新增企业列表.xlsx
#Heimdall #Homepage #Documentation #Download #MySQL #Database #Import #Export #Tool #News Fast Delivery