shell:将数据库的表内容拉到文件中

现在做一个功能,需要将mysql数据库中的数据读出到一个文件中,然后放到hdfs下进行hadoop运算。


set -x
rm -rf result/enterprise*.txt
while IFS=: read oldName newName
do
        echo "SELECT e.id,e.NAME,e.cityid,e.mainCategory,ifnull(e.category,''),ifnull(e.tag,''),ifnull(e.netKeywords,''),e.certification,e.phoneLevel,p.phone FROM enterprise_${newName} e,phone_${newName} p WHERE     e.id = p.enterprise_id and e.maincategory is not null ;" | mysql -N --default-character-set=utf8  -h172.16.1.81 -P3308 -uadmin -ptonggangdasha enterprise  > result/enterprise_${newName}.txt 
#mysql -N -h172.16.1.81 -P3308 -uadmin -ptonggangdasha enterprise<<eof_a 
#SELECT e.id,e.NAME,e.cityid,e.mainCategory,e.category,e.tag,e.netKeywords,e.certification,e.phoneLevel,p.phone FROM enterprise_${newName} e,phone_${newName} p WHERE  e.id = p.enterprise_id into outfile '/tmp/enterprise_${newName}.txt' fields terminated by '|' ;
#\q;
#eof_a
done < enterprise.table


hadoop fs -rm -r  /user/hdfs/source/db/enterprise/
hadoop fs -mkdir /user/hdfs/source/db/enterprise/
hadoop fs -put result/enterprise*.txt /user/hdfs/source/db/enterprise/

用shell的方式可以很方便的将数据库的内容输出到文件。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值