第一种方法:
echo 'select goods.*,user.phone from test.goods left join test.user on user.id=goods.user_id ' |mysql -uroot >text.txt
可以将连表查询的数据放入到txt文本中
第二种方法:
mysql test -uroot -e "select * from user" > type.xls
将文件下载到本地,打开如果中文乱码,因为office默认的是gb2312编码,服务器端生成的很有可能是utf-8编码,这个时候你有两种选择:
1、在服务器端使用iconv来进行编码转换
iconv -futf8 -tgb2312 -otype1.xls type.xls
如果转换顺利,那么从server上下载下来就可以使用了。
2、转换如果不顺利,则会提示:
iconv: illegal input
sequence
at
position 1841
类似错误,如下解决:
先把type.xls下载下来,这个时候文件是utf-8编码的,用excel打开,乱码。把type.xls以文本方式打开,然后另存为,在编码选择ANSI编码保存。
跨库查询也是可以的:
mysql test -uroot -e 'select a.*,b.address from test.user a left join web_test.address b on b.user_id=a.id' >type.xls