mysql -e与awk联合导出csv文件

mysql -e 使用简介

可以执行一条 SQL 语句,例如:

mysql -uroot -p123456 -h 192.168.10.210 -P 3306 db_logs -e "show databases;"
也可以执行多条 SQL 语句,例如:
mysql -u"root" -p"123456" -e"
use "all_university"
alter table "青海大学"  add gid int(10);
update "青海大学"  set gid="469";
insert into 北大 select * from "青海大学" ;
quit"
echo "数据表导入完毕"

下面是上面代码的改进版,即 Linux Shell 版本,例如如下代码:

#!/bin/bash

user_name="root"
password="123456"

db_name="all_university"  
table_name="青海大学"       
field_value="469"      

mysql -u${user_name} -p${password} -e"
use ${db_name}
alter table ${table_name} add gid int(10);
update ${table_name} set gid=${field_value};
insert into 北大 select * from ${table_name};
quit"
echo "数据表导入完毕"

保存执行语句到 txt 文件

例如:

mysql -u"root" -p"123456" -e"select sch_name,sch_addr from all_university" > log.txt

保存执行语句到 CSV 文件

例如:

# mysql -u"root" -p"123456"  -e "
select sch_name,sch_addr,sch_profession from all_university;
quit" | awk '{print $1",",$2","$3}' > log.csv

该语句用到了Linux awk 命令,使用awk替换\t成逗号,其中的 “,” 代表逗号,为了生成逗号分隔值,即生成 CSV 文件

再例如,
假设 log.txt 文本内容如下:

2 this is a test
3 Are you like awk
This's a test
10 There are orange,apple,mongo

输入以下命令:

awk '{print $1","$3","$4}'>xiaoxu.csv log.txt

结果 xiaoxu.csv 文件生成了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值