Shell实现mysql查询结果保存为txt和csv

shell 脚本实现一个查询 MySQL 数据库后将结果保存为 CSV 和 TXT 文件,可以使用 mysql 命令行工具执行 SQL 查询,并将结果导出到文件中。

1. 实现思路:

  • mysql 命令执行 SQL 查询后,默认输出的列使用制表符 (\t) 分隔。
  • 通过 --batch--skip-column-names 参数,取消了列名,并让结果更适合输出。
  • 使用 sed 's/\t/,/g' 将制表符替换为逗号,从而生成 CSV 格式的输出。
  • 对于 TXT 文件输出,保持原始的制表符格式即可,不需要使用 sed 进行替换。

2. Shell 脚本:

#!/bin/bash

# MySQL 配置
DB_HOST="localhost"
DB_USER="username"
DB_PASSWORD="password"
DB_NAME="database"

# 要执行的 SQL 查询
SQL_QUERY="SELECT * FROM table;"

# 输出文件
CSV_FILE="output.csv"
TXT_FILE="output.txt"

# 查询并将结果保存为 CSV 文件
mysql -h "$DB_HOST" -u "$DB_USER" -p"$DB_PASSWORD" -D "$DB_NAME" -e "$SQL_QUERY" \
  --batch --skip-column-names | sed 's/\t/,/g' > "$CSV_FILE"

# 查询并将结果保存为 TXT 文件
mysql -h "$DB_HOST" -u "$DB_USER" -p"$DB_PASSWORD" -D "$DB_NAME" -e "$SQL_QUERY" \
  --batch --skip-column-names > "$TXT_FILE"

# 提示文件已保存
echo "查询结果已保存为 $CSV_FILE$TXT_FILE"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值