首页 > 数据库技术 > 详细

利用Shell脚本将MySQL表中的数据转化为json格式

时间:2015-12-29 20:57:19      阅读:358      评论:0      收藏:0      [点我收藏+]

脚本如下:

#!/bin/bash
mysql -s -phello test >1.log <<EOF
desc t1;
EOF
lines="concat_ws(‘,‘,"
count=`cat 1.log|wc -l`
linenum=0
while read line
do
 coloumname=`echo $line |awk {print $1}`
 let linenum=linenum+1
  if [ $linenum -eq 1 ];then
    lines=$lines"concat_ws(‘:‘,‘{"‘"$coloumname"‘"‘,if("$coloumname" is null or $coloumname=‘‘,‘null‘,concat(‘"‘"‘"‘,$coloumname,‘"‘"‘"‘)))"
 elif [ $linenum -eq $count ];then
    lines=$lines",concat_ws(‘:‘,‘"‘"$coloumname"‘"‘,if("$coloumname" is null or $coloumname=‘‘,‘null}‘,concat(‘"‘"‘"‘,$coloumname,‘"‘"‘"}‘))))"
 else
    lines=$lines",concat_ws(‘:‘,‘"‘"$coloumname"‘"‘,if("$coloumname" is null or $coloumname=‘‘,‘null‘,concat(‘"‘"‘"‘,$coloumname,‘"‘"‘"‘)))"
  fi
done < 1.log
echo $lines

表t1中的数据如下:

mysql> select * from t1;
+------+-------+
| id   | name  |
+------+-------+
|    1 |       |
|    1 | NULL  |
|    2 | hello |
+------+-------+
3 rows in set (0.00 sec)

脚本执行的结果如下:

concat_ws(,,concat_ws(:,{"id",if(id is null or id=‘‘,null,concat(",id,"))),concat_ws(:,"name",if(name is null or name=‘‘,null},concat(",name,"}))))

在MySQL中执行的结果如下:

mysql> select concat_ws(,,concat_ws(:,{"id",if(id is null or id=‘‘,null,concat(",id,"))),concat_ws(:,"name",if(name is null or name=‘‘,null},concat(",name,"})))) json_format from t1;
+---------------------------+
| json_format               |
+---------------------------+
| {"id":"1","name":null}    |
| {"id":"1","name":null}    |
| {"id":"2","name":"hello"} |
+---------------------------+
3 rows in set (0.00 sec)

 

技巧:关于shell脚本中单引号和双引号的区别

shell脚本中的单引号和双引号一样都是字符串的界定符,而不是字符的界定符。

单引号用于保持引号内所有字符的字面值,即使引号内的\和回车也不例外,但是字符串中不能出现单引号。(注意是所有,只是单引号本身不能够出现在其中)。

双引号用于保持引号内所有字符的字面值(回车也不例外),但以下情况除外:

  • $加变量名可以取变量的值

  • 反引号仍表示命令替换

  • \$表示$的字面值

  • \`表示`的字面值

  • \"表示"的字面值

  • \\表示\的字面值

  • 除以上情况之外,在其它字符前面的\无特殊含义,只表示字面值。

利用Shell脚本将MySQL表中的数据转化为json格式

原文:http://www.cnblogs.com/ivictor/p/5086802.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!